tx · BXuQw62kqrEgy4G6BHtEkXhgQQ2F9ysv22HMnF63nMqd

3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx:  -0.01000000 Waves

2023.01.03 00:12 [3453338] smart account 3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx > SELF 0.00000000 Waves

{ "type": 13, "id": "BXuQw62kqrEgy4G6BHtEkXhgQQ2F9ysv22HMnF63nMqd", "fee": 1000000, "feeAssetId": null, "timestamp": 1672694001523, "version": 1, "sender": "3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx", "senderPublicKey": "ERKkYKnafViKTn8uQkz9XhvosihQ5XyXkRCm2ztrjZey", "proofs": [ "8ssqZCRSEmBV286LKxYLHndBqzCU5CiHAb6uAF3zx4zsZHuT1SYSW4ci6K3AgUyiZHbqf71ztT8Hrcoc1DGEfjt" ], "script": "base64:BgIICAISABIAEgAKAA9wcmljZU9yYWNsZUFkZHICIzNQNUJmZDU4UFBmTnZCTTJIeThRZmJjRHFNZU50emc3S2ZQAA9jb2xsYXRlcmFsTGltaXQJAGgCAICt4gQAgMLXLwALb3JhY2xlSW5kZXgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCCQERQGV4dHJOYXRpdmUoMTA2MikBBQ9wcmljZU9yYWNsZUFkZHICC3ByaWNlX2luZGV4AhRFcnJvcjogTm8gcHJpY2UgZGF0YQAQb3JhY2xlSW5kZXhCbG9jawkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEFD3ByaWNlT3JhY2xlQWRkcgkArAICAgxwcmljZV9pbmRleF8JAKQDAQULb3JhY2xlSW5kZXgCFEVycm9yOiBObyBwcmljZSBkYXRhABNvcmFjbGVXYXZlc1ByaWNlVVNECQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgkBEUBleHRyTmF0aXZlKDEwNjIpAQUPcHJpY2VPcmFjbGVBZGRyCQCsAgICBnByaWNlXwkApAMBBRBvcmFjbGVJbmRleEJsb2NrAhRFcnJvcjogTm8gcHJpY2UgZGF0YQAHdG9rZW5JZAkAoQgBAgd0b2tlbklkARBnZXRUb2tlblF1YW50aXR5AAQHJG1hdGNoMAkA7AcBCQETdmFsdWVPckVycm9yTWVzc2FnZQIFB3Rva2VuSWQCEUVycm9yOiBObyB0b2tlbklkAwkAAQIFByRtYXRjaDACBUFzc2V0BAVhc3NldAUHJG1hdGNoMAgFBWFzc2V0CHF1YW50aXR5CQACAQISQ2FuIG5vdCBmaW5kIHRva2VuAQ1nZXRDb2xsYXRlcmFsAAgJAO8HAQUEdGhpcwdyZWd1bGFyARJnZXRDb2xsYXRlcmFsSW5VU0QACQBrAwgJAO8HAQUEdGhpcwdyZWd1bGFyBRNvcmFjbGVXYXZlc1ByaWNlVVNEAMCEPQEPZ2V0QmFja2luZ1JhdGlvAAkAawMJARJnZXRDb2xsYXRlcmFsSW5VU0QAAJBOCQEQZ2V0VG9rZW5RdWFudGl0eQADAWkBC2NvbnN0cnVjdG9yAAMJAQIhPQIFB3Rva2VuSWQFBHVuaXQJAAIBAipFcnJvcjogQ29uc3RydWN0b3IgYWxyZWFkeSBoYXMgYmVlbiBjYWxsZWQEBWlzc3VlCQDCCAUCBFRlc3QCBFRlc3QAAAAIBgQCaWQJALgIAQUFaXNzdWUJAJQKAgkAzAgCBQVpc3N1ZQkAzAgCCQELQmluYXJ5RW50cnkCAgd0b2tlbklkBQJpZAUDbmlsBQR1bml0AWkBD3N3YXBXYXZlc1RvVGVzdAADCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAiNFcnJvcjogT25seSBvbmUgcGF5bWVudCBpcyByZXF1aXJlZAQDcG10CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAADCQEJaXNEZWZpbmVkAQgFA3BtdAdhc3NldElkCQACAQIvRXJyb3I6IE9ubHkgV2F2ZXMgdG9rZW4gaXMgYWxsb3dlZCBmb3Igc3dhcHBpbmcDCQBmAgkAZAIICQDvBwEFBHRoaXMHcmVndWxhcggFA3BtdAZhbW91bnQFD2NvbGxhdGVyYWxMaW1pdAkAAgECIEVycm9yOiBDb2xsYXRlcmFsIGxpbWl0IGV4Y2VlZGVkBBBhbW91bnRXaXRob3V0RmVlCQBrAwgFA3BtdAZhbW91bnQFE29yYWNsZVdhdmVzUHJpY2VVU0QAwIQ9BAxyZXR1cm5BbW91bnQJAGsDBRBhbW91bnRXaXRob3V0RmVlAOMHAOgHCQDMCAIJAQdSZWlzc3VlAwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBQd0b2tlbklkAhJFcnJvcjogbm8gdG9rZW4gaWQFDHJldHVybkFtb3VudAYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQxyZXR1cm5BbW91bnQFB3Rva2VuSWQFA25pbAFpAQ9zd2FwVGVzdFRvV2F2ZXMAAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABCQACAQIjRXJyb3I6IE9ubHkgb25lIHBheW1lbnQgaXMgcmVxdWlyZWQEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAAAwkBAiE9AggFA3BtdAdhc3NldElkBQd0b2tlbklkCQACAQIuRXJyb3I6IE9ubHkgVGVzdCB0b2tlbiBpcyBhbGxvd2VkIGZvciBzd2FwcGluZwQQYW1vdW50V2l0aG91dEZlZQkAawMIBQNwbXQGYW1vdW50AMCEPQUTb3JhY2xlV2F2ZXNQcmljZVVTRAQCYnIJAQ9nZXRCYWNraW5nUmF0aW8ABAVzaGFyZQMJAGYCAKxNBQJicgkAZQIA6AcJAGkCCQBlAgCQTgUCYnIACwMJAGYCAIRSBQJicgDfBwDjBwQMcmV0dXJuQW1vdW50CQBrAwUQYW1vdW50V2l0aG91dEZlZQUFc2hhcmUA6AcJAMwIAgkBBEJ1cm4CCQETdmFsdWVPckVycm9yTWVzc2FnZQIFB3Rva2VuSWQCEkVycm9yOiBubyB0b2tlbiBpZAgFA3BtdAZhbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQxyZXR1cm5BbW91bnQFBHVuaXQFA25pbAAIKcME", "chainId": 87, "height": 3453338, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: F9EQZChnRzNFHNEn1u3rTnqrPHsfzsG8ADJ71iZP8c2J Next: 7bYhJxByYftZdK35nQrnNZcpa4GFJR732CwcvvkxvKWz Diff:
OldNewDifferences
33 {-# CONTENT_TYPE DAPP #-}
44 let priceOracleAddr = "3P5Bfd58PPfNvBM2Hy8QfbcDqMeNtzg7KfP"
55
6-let wavesStakingAddr = Address(base58'3PGobRuQzBY9VbeKLaZqrcQtW26wrE9jFm7')
7-
8-let contractAddr = Address(base58'3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx')
6+let collateralLimit = (10000000 * 100000000)
97
108 let oracleIndex = valueOrErrorMessage(getInteger(addressFromStringValue(priceOracleAddr), "price_index"), "Error: No price data")
119
2321 }
2422
2523
26-func getCollateral () = wavesBalance(contractAddr).regular
24+func getCollateral () = wavesBalance(this).regular
2725
2826
29-func getCollateralInUSD () = fraction(wavesBalance(contractAddr).regular, oracleWavesPriceUSD, 1000000)
27+func getCollateralInUSD () = fraction(wavesBalance(this).regular, oracleWavesPriceUSD, 1000000)
3028
3129
3230 func getBackingRatio () = fraction(getCollateralInUSD(), 10000, getTokenQuantity())
5048 let pmt = value(i.payments[0])
5149 if (isDefined(pmt.assetId))
5250 then throw("Error: Only Waves token is allowed for swapping")
53- else {
54- let amountWithoutFee = fraction(pmt.amount, oracleWavesPriceUSD, 1000000)
55- let returnAmount = fraction(amountWithoutFee, 995, 1000)
51+ else if (((wavesBalance(this).regular + pmt.amount) > collateralLimit))
52+ then throw("Error: Collateral limit exceeded")
53+ else {
54+ let amountWithoutFee = fraction(pmt.amount, oracleWavesPriceUSD, 1000000)
55+ let returnAmount = fraction(amountWithoutFee, 995, 1000)
5656 [Reissue(valueOrErrorMessage(tokenId, "Error: no token id"), returnAmount, true), ScriptTransfer(i.caller, returnAmount, tokenId)]
57- }
57+ }
5858 }
5959
6060
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let priceOracleAddr = "3P5Bfd58PPfNvBM2Hy8QfbcDqMeNtzg7KfP"
55
6-let wavesStakingAddr = Address(base58'3PGobRuQzBY9VbeKLaZqrcQtW26wrE9jFm7')
7-
8-let contractAddr = Address(base58'3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx')
6+let collateralLimit = (10000000 * 100000000)
97
108 let oracleIndex = valueOrErrorMessage(getInteger(addressFromStringValue(priceOracleAddr), "price_index"), "Error: No price data")
119
1210 let oracleIndexBlock = valueOrErrorMessage(getInteger(addressFromStringValue(priceOracleAddr), ("price_index_" + toString(oracleIndex))), "Error: No price data")
1311
1412 let oracleWavesPriceUSD = valueOrErrorMessage(getInteger(addressFromStringValue(priceOracleAddr), ("price_" + toString(oracleIndexBlock))), "Error: No price data")
1513
1614 let tokenId = getBinary("tokenId")
1715
1816 func getTokenQuantity () = match assetInfo(valueOrErrorMessage(tokenId, "Error: No tokenId")) {
1917 case asset: Asset =>
2018 asset.quantity
2119 case _ =>
2220 throw("Can not find token")
2321 }
2422
2523
26-func getCollateral () = wavesBalance(contractAddr).regular
24+func getCollateral () = wavesBalance(this).regular
2725
2826
29-func getCollateralInUSD () = fraction(wavesBalance(contractAddr).regular, oracleWavesPriceUSD, 1000000)
27+func getCollateralInUSD () = fraction(wavesBalance(this).regular, oracleWavesPriceUSD, 1000000)
3028
3129
3230 func getBackingRatio () = fraction(getCollateralInUSD(), 10000, getTokenQuantity())
3331
3432
3533 @Callable(i)
3634 func constructor () = if ((tokenId != unit))
3735 then throw("Error: Constructor already has been called")
3836 else {
3937 let issue = Issue("Test", "Test", 0, 8, true)
4038 let id = calculateAssetId(issue)
4139 $Tuple2([issue, BinaryEntry("tokenId", id)], unit)
4240 }
4341
4442
4543
4644 @Callable(i)
4745 func swapWavesToTest () = if ((size(i.payments) != 1))
4846 then throw("Error: Only one payment is required")
4947 else {
5048 let pmt = value(i.payments[0])
5149 if (isDefined(pmt.assetId))
5250 then throw("Error: Only Waves token is allowed for swapping")
53- else {
54- let amountWithoutFee = fraction(pmt.amount, oracleWavesPriceUSD, 1000000)
55- let returnAmount = fraction(amountWithoutFee, 995, 1000)
51+ else if (((wavesBalance(this).regular + pmt.amount) > collateralLimit))
52+ then throw("Error: Collateral limit exceeded")
53+ else {
54+ let amountWithoutFee = fraction(pmt.amount, oracleWavesPriceUSD, 1000000)
55+ let returnAmount = fraction(amountWithoutFee, 995, 1000)
5656 [Reissue(valueOrErrorMessage(tokenId, "Error: no token id"), returnAmount, true), ScriptTransfer(i.caller, returnAmount, tokenId)]
57- }
57+ }
5858 }
5959
6060
6161
6262 @Callable(i)
6363 func swapTestToWaves () = if ((size(i.payments) != 1))
6464 then throw("Error: Only one payment is required")
6565 else {
6666 let pmt = value(i.payments[0])
6767 if ((pmt.assetId != tokenId))
6868 then throw("Error: Only Test token is allowed for swapping")
6969 else {
7070 let amountWithoutFee = fraction(pmt.amount, 1000000, oracleWavesPriceUSD)
7171 let br = getBackingRatio()
7272 let share = if ((9900 > br))
7373 then (1000 - ((10000 - br) / 11))
7474 else if ((10500 > br))
7575 then 991
7676 else 995
7777 let returnAmount = fraction(amountWithoutFee, share, 1000)
7878 [Burn(valueOrErrorMessage(tokenId, "Error: no token id"), pmt.amount), ScriptTransfer(i.caller, returnAmount, unit)]
7979 }
8080 }
8181
8282

github/deemru/w8io/6500d08 
31.84 ms