@haven-fi/solauto-sdk 1.0.597 → 1.0.598
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -20,7 +20,7 @@ interface ApplyDebtAdjustmentResult {
|
|
20
20
|
intermediaryLiqUtilizationRateBps: number;
|
21
21
|
}
|
22
22
|
export declare function applyDebtAdjustmentUsd(debtAdjustmentUsd: number, pos: PositionValues, liqThreshold: number, fees?: RebalanceFeesBps): ApplyDebtAdjustmentResult;
|
23
|
-
export declare function getDebtAdjustment(
|
23
|
+
export declare function getDebtAdjustment(liqThresholdBps: number, pos: PositionValues, targetLiqUtilizationRateBps: number, fees?: RebalanceFeesBps): DebtAdjustment;
|
24
24
|
export interface RebalanceValues extends DebtAdjustment {
|
25
25
|
rebalanceDirection: RebalanceDirection;
|
26
26
|
tokenBalanceChange?: TokenBalanceChange;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"rebalanceValues.d.ts","sourceRoot":"","sources":["../../../src/services/rebalance/rebalanceValues.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAEnB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAO1D,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE/C,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,cAAc;IAC7B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,SAAS,EAAE,cAAc,CAAC;IAC1B,iCAAiC,EAAE,MAAM,CAAC;CAC3C;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,UAAU,yBAAyB;IACjC,MAAM,EAAE,cAAc,CAAC;IACvB,iCAAiC,EAAE,MAAM,CAAC;CAC3C;AAED,wBAAgB,sBAAsB,CACpC,iBAAiB,EAAE,MAAM,EACzB,GAAG,EAAE,cAAc,EACnB,YAAY,EAAE,MAAM,EACpB,IAAI,CAAC,EAAE,gBAAgB,GACtB,yBAAyB,
|
1
|
+
{"version":3,"file":"rebalanceValues.d.ts","sourceRoot":"","sources":["../../../src/services/rebalance/rebalanceValues.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAEnB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAO1D,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE/C,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,cAAc;IAC7B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,SAAS,EAAE,cAAc,CAAC;IAC1B,iCAAiC,EAAE,MAAM,CAAC;CAC3C;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,UAAU,yBAAyB;IACjC,MAAM,EAAE,cAAc,CAAC;IACvB,iCAAiC,EAAE,MAAM,CAAC;CAC3C;AAED,wBAAgB,sBAAsB,CACpC,iBAAiB,EAAE,MAAM,EACzB,GAAG,EAAE,cAAc,EACnB,YAAY,EAAE,MAAM,EACpB,IAAI,CAAC,EAAE,gBAAgB,GACtB,yBAAyB,CA8B3B;AAED,wBAAgB,iBAAiB,CAC/B,eAAe,EAAE,MAAM,EACvB,GAAG,EAAE,cAAc,EACnB,2BAA2B,EAAE,MAAM,EACnC,IAAI,CAAC,EAAE,gBAAgB,GACtB,cAAc,CAgChB;AAqED,MAAM,WAAW,eAAgB,SAAQ,cAAc;IACrD,kBAAkB,EAAE,kBAAkB,CAAC;IACvC,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;IACxC,qBAAqB,EAAE,OAAO,CAAC;CAChC;AAED,wBAAgB,kBAAkB,CAChC,eAAe,EAAE,iBAAiB,EAClC,2BAA2B,CAAC,EAAE,MAAM,EACpC,aAAa,CAAC,EAAE,cAAc,EAC9B,QAAQ,CAAC,EAAE,MAAM,GAChB,eAAe,CA6CjB"}
|
@@ -24,9 +24,10 @@ function applyDebtAdjustmentUsd(debtAdjustmentUsd, pos, liqThreshold, fees) {
|
|
24
24
|
}
|
25
25
|
return { newPos, intermediaryLiqUtilizationRateBps };
|
26
26
|
}
|
27
|
-
function getDebtAdjustment(
|
28
|
-
const isBoost = (0, utils_1.getLiqUtilzationRateBps)(pos.supplyUsd, pos.debtUsd,
|
27
|
+
function getDebtAdjustment(liqThresholdBps, pos, targetLiqUtilizationRateBps, fees) {
|
28
|
+
const isBoost = (0, utils_1.getLiqUtilzationRateBps)(pos.supplyUsd, pos.debtUsd, liqThresholdBps) <
|
29
29
|
targetLiqUtilizationRateBps;
|
30
|
+
const liqThreshold = (0, utils_1.fromBps)(liqThresholdBps);
|
30
31
|
const targetUtilizationRate = (0, utils_1.fromBps)(targetLiqUtilizationRateBps);
|
31
32
|
const actualizedFee = 1.0 - (0, utils_1.fromBps)(fees?.solauto ?? 0);
|
32
33
|
const flFee = (0, utils_1.fromBps)(fees?.flashLoan ?? 0);
|
@@ -107,7 +108,7 @@ function getRebalanceValues(solautoPosition, targetLiqUtilizationRateBps, solaut
|
|
107
108
|
lpBorrow: solautoPosition.state().debt.borrowFeeBps,
|
108
109
|
flashLoan: flFeeBps ?? 0,
|
109
110
|
};
|
110
|
-
const debtAdjustment = getDebtAdjustment(
|
111
|
+
const debtAdjustment = getDebtAdjustment(solautoPosition.state().liqThresholdBps, position, targetRate, fees);
|
111
112
|
const repayingCloseToMaxLtv = rebalanceDirection === generated_1.RebalanceDirection.Repay &&
|
112
113
|
targetRate >=
|
113
114
|
(0, utils_1.maxRepayToBps)(solautoPosition.state().maxLtvBps, solautoPosition.state().liqThresholdBps);
|
package/package.json
CHANGED
@@ -38,14 +38,15 @@ export function applyDebtAdjustmentUsd(
|
|
38
38
|
debtAdjustmentUsd: number,
|
39
39
|
pos: PositionValues,
|
40
40
|
liqThreshold: number,
|
41
|
-
fees?: RebalanceFeesBps
|
41
|
+
fees?: RebalanceFeesBps
|
42
42
|
): ApplyDebtAdjustmentResult {
|
43
43
|
const newPos = { ...pos };
|
44
44
|
const isBoost = debtAdjustmentUsd > 0;
|
45
45
|
|
46
46
|
const daMinusSolautoFees =
|
47
47
|
debtAdjustmentUsd - debtAdjustmentUsd * fromBps(fees?.solauto ?? 0);
|
48
|
-
const daWithFlashLoan =
|
48
|
+
const daWithFlashLoan =
|
49
|
+
debtAdjustmentUsd * (1.0 + fromBps(fees?.flashLoan ?? 0));
|
49
50
|
|
50
51
|
let intermediaryLiqUtilizationRateBps = 0;
|
51
52
|
if (isBoost) {
|
@@ -71,14 +72,15 @@ export function applyDebtAdjustmentUsd(
|
|
71
72
|
}
|
72
73
|
|
73
74
|
export function getDebtAdjustment(
|
74
|
-
|
75
|
+
liqThresholdBps: number,
|
75
76
|
pos: PositionValues,
|
76
77
|
targetLiqUtilizationRateBps: number,
|
77
|
-
fees?: RebalanceFeesBps
|
78
|
+
fees?: RebalanceFeesBps
|
78
79
|
): DebtAdjustment {
|
79
80
|
const isBoost =
|
80
|
-
getLiqUtilzationRateBps(pos.supplyUsd, pos.debtUsd,
|
81
|
+
getLiqUtilzationRateBps(pos.supplyUsd, pos.debtUsd, liqThresholdBps) <
|
81
82
|
targetLiqUtilizationRateBps;
|
83
|
+
const liqThreshold = fromBps(liqThresholdBps);
|
82
84
|
|
83
85
|
const targetUtilizationRate = fromBps(targetLiqUtilizationRateBps);
|
84
86
|
const actualizedFee = 1.0 - fromBps(fees?.solauto ?? 0);
|
@@ -185,7 +187,7 @@ export function getRebalanceValues(
|
|
185
187
|
solautoPosition: SolautoPositionEx,
|
186
188
|
targetLiqUtilizationRateBps?: number,
|
187
189
|
solautoFeeBps?: SolautoFeesBps,
|
188
|
-
flFeeBps?: number
|
190
|
+
flFeeBps?: number
|
189
191
|
): RebalanceValues {
|
190
192
|
const tokenBalanceChange = getTokenBalanceChange();
|
191
193
|
|
@@ -211,7 +213,7 @@ export function getRebalanceValues(
|
|
211
213
|
};
|
212
214
|
|
213
215
|
const debtAdjustment = getDebtAdjustment(
|
214
|
-
|
216
|
+
solautoPosition.state().liqThresholdBps,
|
215
217
|
position,
|
216
218
|
targetRate,
|
217
219
|
fees
|