@curvefi/api 2.52.1 → 2.52.3
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.
package/lib/constants/aliases.js
CHANGED
|
@@ -73,7 +73,7 @@ export var ALIASES_AVALANCHE = lowerCaseValues({
|
|
|
73
73
|
"eywa_factory": '0x37F22A0B028f2152e6CAcef210e0C4d3b875f367',
|
|
74
74
|
"crypto_factory": '0xF18056Bbd320E96A48e3Fbf8bC061322531aac99',
|
|
75
75
|
"tricrypto_factory": '0x0c0e5f2fF0ff18a3be9b835635039256dC4B4963',
|
|
76
|
-
"stable_ng_factory": '
|
|
76
|
+
"stable_ng_factory": '0x1764ee18e8B3ccA4787249Ceb249356192594585',
|
|
77
77
|
"factory_admin": "",
|
|
78
78
|
});
|
|
79
79
|
export var ALIASES_ARBITRUM = lowerCaseValues({
|
package/lib/factory/constants.js
CHANGED
|
@@ -147,6 +147,8 @@ export var implementationABIDictAvalanche = lowerCaseKeys({
|
|
|
147
147
|
"0x7D86446dDb609eD0F5f8684AcF30380a356b2B4c": Plain4BalancesABI,
|
|
148
148
|
"0x0eb0F1FaF5F509Ac53fA224477509EAD167cf410": Plain4ETHABI,
|
|
149
149
|
"0xCE94D3E5b0D80565D7B713A687b39a3Dc81780BA": Plain4OptimizedABI,
|
|
150
|
+
"0xa7Ba18EeFcD9513230987eC2faB6711AF5AbD9c2": PlainStableSwapNGABI,
|
|
151
|
+
"0x7C2085419BE6a04f4ad88ea91bC9F5C6E6C463D8": MetaStableSwapNGABI,
|
|
150
152
|
});
|
|
151
153
|
export var implementationABIDictArbitrum = lowerCaseKeys({
|
|
152
154
|
"0x09672362833d8f703D5395ef3252D4Bfa51c15ca": MetaUSDABI,
|
package/lib/factory/deploy.js
CHANGED
|
@@ -161,7 +161,7 @@ implementationIdx, emaTime, // seconds
|
|
|
161
161
|
oracleAddresses, methodNames, estimateGas) {
|
|
162
162
|
if (emaTime === void 0) { emaTime = 600; }
|
|
163
163
|
return __awaiter(void 0, void 0, void 0, function () {
|
|
164
|
-
var _oracleAddresses, _methodNames, _A, _fee, _coins, contractAddress, contract, methodIds, args, gas, gasLimit;
|
|
164
|
+
var _oracleAddresses, _methodNames, _A, _fee, _offpegFeeMultiplier, _coins, contractAddress, contract, methodIds, args, gas, gasLimit;
|
|
165
165
|
var _a;
|
|
166
166
|
return __generator(this, function (_b) {
|
|
167
167
|
switch (_b.label) {
|
|
@@ -204,6 +204,7 @@ oracleAddresses, methodNames, estimateGas) {
|
|
|
204
204
|
throw Error("emaTime must be > 0. Passed emaTime = ".concat(emaTime));
|
|
205
205
|
_A = parseUnits(A, 0);
|
|
206
206
|
_fee = parseUnits(fee, 8);
|
|
207
|
+
_offpegFeeMultiplier = parseUnits(offpegFeeMultiplier, 10);
|
|
207
208
|
_coins = coins;
|
|
208
209
|
contractAddress = curve.constants.ALIASES.stable_ng_factory;
|
|
209
210
|
contract = curve.contracts[contractAddress].contract;
|
|
@@ -216,8 +217,7 @@ oracleAddresses, methodNames, estimateGas) {
|
|
|
216
217
|
methodIds.push(ethers.id(item).substring(0, 10));
|
|
217
218
|
}
|
|
218
219
|
});
|
|
219
|
-
args = [name, symbol, _coins, _A, _fee,
|
|
220
|
-
console.log(args);
|
|
220
|
+
args = [name, symbol, _coins, _A, _fee, _offpegFeeMultiplier, emaTime, implementationIdx, assetTypes, methodIds, _oracleAddresses];
|
|
221
221
|
return [4 /*yield*/, (_a = contract.deploy_plain_pool).estimateGas.apply(_a, __spreadArray(__spreadArray([], args, false), [curve.constantOptions], false))];
|
|
222
222
|
case 1:
|
|
223
223
|
gas = _b.sent();
|
|
@@ -466,7 +466,7 @@ var PoolTemplate = /** @class */ (function () {
|
|
|
466
466
|
case 6:
|
|
467
467
|
_c.trys.push([6, 13, , 15]);
|
|
468
468
|
contract = curve.contracts[curve.constants.ALIASES.stable_calc].contract;
|
|
469
|
-
if (!(curve.constants.ALIASES.stable_calc === curve.constants.ZERO_ADDRESS)) return [3 /*break*/, 8];
|
|
469
|
+
if (!(curve.constants.ALIASES.stable_calc === curve.constants.ZERO_ADDRESS || this.id.startsWith("factory-stable-ng"))) return [3 /*break*/, 8];
|
|
470
470
|
return [4 /*yield*/, this._pureCalcLpTokenAmount(_amounts, isDeposit, useUnderlying)];
|
|
471
471
|
case 7: return [2 /*return*/, _c.sent()];
|
|
472
472
|
case 8:
|
|
@@ -2996,44 +2996,56 @@ var PoolTemplate = /** @class */ (function () {
|
|
|
2996
2996
|
};
|
|
2997
2997
|
PoolTemplate.prototype._swapRequired = function (i, j, _amount, isUnderlying) {
|
|
2998
2998
|
return __awaiter(this, void 0, void 0, function () {
|
|
2999
|
-
var
|
|
2999
|
+
var contract, basePool, secondPool, contract_1, contract, basePool;
|
|
3000
3000
|
return __generator(this, function (_c) {
|
|
3001
3001
|
switch (_c.label) {
|
|
3002
3002
|
case 0:
|
|
3003
|
-
poolAddress = this.address;
|
|
3004
|
-
contract = this.isCrypto ? curve.contracts[curve.constants.ALIASES.crypto_calc].contract : curve.contracts[curve.constants.ALIASES.stable_calc].contract;
|
|
3005
3003
|
if (!this.isCrypto) return [3 /*break*/, 9];
|
|
3004
|
+
contract = curve.contracts[curve.constants.ALIASES.crypto_calc].contract;
|
|
3006
3005
|
if (!(this.isMeta && isUnderlying)) return [3 /*break*/, 6];
|
|
3007
3006
|
basePool = new PoolTemplate(this.basePool);
|
|
3008
3007
|
if (!(this.wrappedCoins.length === 3)) return [3 /*break*/, 2];
|
|
3009
|
-
return [4 /*yield*/, contract.get_dx_tricrypto_meta_underlying(
|
|
3008
|
+
return [4 /*yield*/, contract.get_dx_tricrypto_meta_underlying(this.address, i, j, _amount, this.wrappedCoins.length, basePool.address, basePool.lpToken, curve.constantOptions)];
|
|
3010
3009
|
case 1: return [2 /*return*/, _c.sent()];
|
|
3011
3010
|
case 2:
|
|
3012
3011
|
if (!basePool.isFake) return [3 /*break*/, 4];
|
|
3013
3012
|
secondPool = new PoolTemplate(basePool.basePool);
|
|
3014
|
-
return [4 /*yield*/, contract.get_dx_double_meta_underlying(
|
|
3013
|
+
return [4 /*yield*/, contract.get_dx_double_meta_underlying(this.address, i, j, _amount, basePool.address, basePool.zap, secondPool.address, secondPool.lpToken, curve.constantOptions)];
|
|
3015
3014
|
case 3: return [2 /*return*/, _c.sent()];
|
|
3016
|
-
case 4: return [4 /*yield*/, contract.get_dx_meta_underlying(
|
|
3015
|
+
case 4: return [4 /*yield*/, contract.get_dx_meta_underlying(this.address, i, j, _amount, this.underlyingCoins.length, basePool.address, basePool.lpToken, curve.constantOptions)];
|
|
3017
3016
|
case 5: return [2 /*return*/, _c.sent()];
|
|
3018
|
-
case 6: return [4 /*yield*/, contract.get_dx(
|
|
3017
|
+
case 6: return [4 /*yield*/, contract.get_dx(this.address, i, j, _amount, this.wrappedCoins.length, curve.constantOptions)];
|
|
3019
3018
|
case 7: return [2 /*return*/, _c.sent()];
|
|
3020
|
-
case 8: return [3 /*break*/,
|
|
3019
|
+
case 8: return [3 /*break*/, 25];
|
|
3021
3020
|
case 9:
|
|
3021
|
+
if (!this.id.startsWith("factory-stable-ng")) return [3 /*break*/, 16];
|
|
3022
|
+
contract_1 = curve.contracts[this.address].contract;
|
|
3022
3023
|
if (!this.isMeta) return [3 /*break*/, 14];
|
|
3023
|
-
basePool = new PoolTemplate(this.basePool);
|
|
3024
3024
|
if (!isUnderlying) return [3 /*break*/, 11];
|
|
3025
|
-
return [4 /*yield*/,
|
|
3025
|
+
return [4 /*yield*/, contract_1.get_dx_underlying(i, j, _amount, curve.constantOptions)];
|
|
3026
3026
|
case 10: return [2 /*return*/, _c.sent()];
|
|
3027
|
-
case 11: return [4 /*yield*/,
|
|
3027
|
+
case 11: return [4 /*yield*/, contract_1.get_dx(i, j, _amount, curve.constantOptions)];
|
|
3028
3028
|
case 12: return [2 /*return*/, _c.sent()];
|
|
3029
|
-
case 13: return [3 /*break*/,
|
|
3030
|
-
case 14:
|
|
3031
|
-
if (!(isUnderlying && this.isLending)) return [3 /*break*/, 16];
|
|
3032
|
-
return [4 /*yield*/, contract.get_dx_underlying(poolAddress, i, j, _amount, this.underlyingCoins.length, curve.constantOptions)];
|
|
3029
|
+
case 13: return [3 /*break*/, 16];
|
|
3030
|
+
case 14: return [4 /*yield*/, contract_1.get_dx(i, j, _amount)];
|
|
3033
3031
|
case 15: return [2 /*return*/, _c.sent()];
|
|
3034
|
-
case 16:
|
|
3032
|
+
case 16:
|
|
3033
|
+
contract = curve.contracts[curve.constants.ALIASES.stable_calc].contract;
|
|
3034
|
+
if (!this.isMeta) return [3 /*break*/, 21];
|
|
3035
|
+
basePool = new PoolTemplate(this.basePool);
|
|
3036
|
+
if (!isUnderlying) return [3 /*break*/, 18];
|
|
3037
|
+
return [4 /*yield*/, contract.get_dx_meta_underlying(this.address, i, j, _amount, this.underlyingCoins.length, basePool.address, basePool.lpToken, curve.constantOptions)];
|
|
3035
3038
|
case 17: return [2 /*return*/, _c.sent()];
|
|
3036
|
-
case 18: return [
|
|
3039
|
+
case 18: return [4 /*yield*/, contract.get_dx_meta(this.address, i, j, _amount, this.wrappedCoins.length, basePool.address, curve.constantOptions)];
|
|
3040
|
+
case 19: return [2 /*return*/, _c.sent()];
|
|
3041
|
+
case 20: return [3 /*break*/, 25];
|
|
3042
|
+
case 21:
|
|
3043
|
+
if (!(isUnderlying && this.isLending)) return [3 /*break*/, 23];
|
|
3044
|
+
return [4 /*yield*/, contract.get_dx_underlying(this.address, i, j, _amount, this.underlyingCoins.length, curve.constantOptions)];
|
|
3045
|
+
case 22: return [2 /*return*/, _c.sent()];
|
|
3046
|
+
case 23: return [4 /*yield*/, contract.get_dx(this.address, i, j, _amount, this.wrappedCoins.length, curve.constantOptions)];
|
|
3047
|
+
case 24: return [2 /*return*/, _c.sent()];
|
|
3048
|
+
case 25: return [2 /*return*/];
|
|
3037
3049
|
}
|
|
3038
3050
|
});
|
|
3039
3051
|
});
|