@gainsnetwork/sdk 0.2.20-rc2 → 0.2.21

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.
Files changed (46) hide show
  1. package/lib/constants.d.ts +2 -0
  2. package/lib/constants.js +3 -1
  3. package/lib/contracts/types/generated/GFarmTradingStorageV5.d.ts +1911 -0
  4. package/lib/contracts/types/generated/GFarmTradingStorageV5.js +2 -0
  5. package/lib/contracts/types/generated/GNSBorrowingFees.d.ts +1067 -0
  6. package/lib/contracts/types/generated/GNSBorrowingFees.js +2 -0
  7. package/lib/contracts/types/generated/GNSMultiCollatDiamond.d.ts +1131 -477
  8. package/lib/contracts/types/generated/GNSNftRewardsV6.d.ts +533 -0
  9. package/lib/contracts/types/generated/GNSNftRewardsV6.js +2 -0
  10. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.d.ts +613 -0
  11. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.js +2 -0
  12. package/lib/contracts/types/generated/GNSTrading.d.ts +758 -0
  13. package/lib/contracts/types/generated/GNSTrading.js +2 -0
  14. package/lib/contracts/types/generated/GNSTradingCallbacks.d.ts +875 -0
  15. package/lib/contracts/types/generated/GNSTradingCallbacks.js +2 -0
  16. package/lib/contracts/types/generated/GNSTradingStorage.d.ts +1387 -0
  17. package/lib/contracts/types/generated/GNSTradingStorage.js +2 -0
  18. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.d.ts +83 -0
  19. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.js +2691 -0
  20. package/lib/contracts/types/generated/factories/GNSBorrowingFees__factory.d.ts +124 -0
  21. package/lib/contracts/types/generated/factories/GNSBorrowingFees__factory.js +1784 -0
  22. package/lib/contracts/types/generated/factories/GNSMultiCollatDiamond__factory.d.ts +28 -81
  23. package/lib/contracts/types/generated/factories/GNSMultiCollatDiamond__factory.js +3174 -1417
  24. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.d.ts +100 -0
  25. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.js +1116 -0
  26. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.d.ts +100 -0
  27. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.js +1003 -0
  28. package/lib/contracts/types/generated/factories/GNSTradingCallbacks__factory.d.ts +113 -0
  29. package/lib/contracts/types/generated/factories/GNSTradingCallbacks__factory.js +1428 -0
  30. package/lib/contracts/types/generated/factories/GNSTradingStorage__factory.d.ts +96 -0
  31. package/lib/contracts/types/generated/factories/GNSTradingStorage__factory.js +2241 -0
  32. package/lib/contracts/types/generated/factories/GNSTrading__factory.d.ts +95 -0
  33. package/lib/contracts/types/generated/factories/GNSTrading__factory.js +1071 -0
  34. package/lib/contracts/types/index.d.ts +4 -0
  35. package/lib/contracts/types/index.js +6 -1
  36. package/lib/contracts/utils/openTrades.js +13 -2
  37. package/lib/trade/fees/borrowing/index.d.ts +0 -1
  38. package/lib/trade/fees/borrowing/index.js +9 -7
  39. package/lib/trade/liquidation.d.ts +6 -1
  40. package/lib/trade/liquidation.js +37 -3
  41. package/lib/trade/pnl.d.ts +4 -2
  42. package/lib/trade/pnl.js +4 -2
  43. package/lib/trade/spread.d.ts +18 -2
  44. package/lib/trade/spread.js +69 -8
  45. package/lib/trade/types.d.ts +17 -1
  46. package/package.json +1 -1
@@ -35,6 +35,26 @@ export declare namespace IGNSDiamondLoupe {
35
35
  };
36
36
  }
37
37
  export declare namespace IPairsStorage {
38
+ type GroupLiquidationParamsStruct = {
39
+ maxLiqSpreadP: PromiseOrValue<BigNumberish>;
40
+ startLiqThresholdP: PromiseOrValue<BigNumberish>;
41
+ endLiqThresholdP: PromiseOrValue<BigNumberish>;
42
+ startLeverage: PromiseOrValue<BigNumberish>;
43
+ endLeverage: PromiseOrValue<BigNumberish>;
44
+ };
45
+ type GroupLiquidationParamsStructOutput = [
46
+ number,
47
+ number,
48
+ number,
49
+ number,
50
+ number
51
+ ] & {
52
+ maxLiqSpreadP: number;
53
+ startLiqThresholdP: number;
54
+ endLiqThresholdP: number;
55
+ startLeverage: number;
56
+ endLeverage: number;
57
+ };
38
58
  type FeeStruct = {
39
59
  name: PromiseOrValue<string>;
40
60
  openFeeP: PromiseOrValue<BigNumberish>;
@@ -193,23 +213,32 @@ export declare namespace IPriceImpact {
193
213
  oiShortUsd: BigNumber;
194
214
  };
195
215
  type OiWindowUpdateStruct = {
216
+ trader: PromiseOrValue<string>;
217
+ index: PromiseOrValue<BigNumberish>;
196
218
  windowsDuration: PromiseOrValue<BigNumberish>;
197
219
  pairIndex: PromiseOrValue<BigNumberish>;
198
220
  windowId: PromiseOrValue<BigNumberish>;
199
221
  long: PromiseOrValue<boolean>;
222
+ open: PromiseOrValue<boolean>;
200
223
  openInterestUsd: PromiseOrValue<BigNumberish>;
201
224
  };
202
225
  type OiWindowUpdateStructOutput = [
226
+ string,
227
+ number,
203
228
  number,
204
229
  BigNumber,
205
230
  BigNumber,
206
231
  boolean,
232
+ boolean,
207
233
  BigNumber
208
234
  ] & {
235
+ trader: string;
236
+ index: number;
209
237
  windowsDuration: number;
210
238
  pairIndex: BigNumber;
211
239
  windowId: BigNumber;
212
240
  long: boolean;
241
+ open: boolean;
213
242
  openInterestUsd: BigNumber;
214
243
  };
215
244
  type OiWindowsSettingsStruct = {
@@ -230,6 +259,18 @@ export declare namespace IPriceImpact {
230
259
  onePercentDepthAboveUsd: BigNumber;
231
260
  onePercentDepthBelowUsd: BigNumber;
232
261
  };
262
+ type PairFactorsStruct = {
263
+ protectionCloseFactor: PromiseOrValue<BigNumberish>;
264
+ protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>;
265
+ cumulativeFactor: PromiseOrValue<BigNumberish>;
266
+ __placeholder: PromiseOrValue<BigNumberish>;
267
+ };
268
+ type PairFactorsStructOutput = [number, number, number, BigNumber] & {
269
+ protectionCloseFactor: number;
270
+ protectionCloseFactorBlocks: number;
271
+ cumulativeFactor: number;
272
+ __placeholder: BigNumber;
273
+ };
233
274
  }
234
275
  export declare namespace ITradingStorage {
235
276
  type IdStruct = {
@@ -317,6 +358,8 @@ export declare namespace ITradingStorage {
317
358
  maxSlippageP: PromiseOrValue<BigNumberish>;
318
359
  lastOiUpdateTs: PromiseOrValue<BigNumberish>;
319
360
  collateralPriceUsd: PromiseOrValue<BigNumberish>;
361
+ contractsVersion: PromiseOrValue<BigNumberish>;
362
+ lastPosIncreaseBlock: PromiseOrValue<BigNumberish>;
320
363
  __placeholder: PromiseOrValue<BigNumberish>;
321
364
  };
322
365
  type TradeInfoStructOutput = [
@@ -326,6 +369,8 @@ export declare namespace ITradingStorage {
326
369
  number,
327
370
  number,
328
371
  number,
372
+ number,
373
+ number,
329
374
  number
330
375
  ] & {
331
376
  createdBlock: number;
@@ -334,6 +379,8 @@ export declare namespace ITradingStorage {
334
379
  maxSlippageP: number;
335
380
  lastOiUpdateTs: number;
336
381
  collateralPriceUsd: number;
382
+ contractsVersion: number;
383
+ lastPosIncreaseBlock: number;
337
384
  __placeholder: number;
338
385
  };
339
386
  type CollateralStruct = {
@@ -367,6 +414,109 @@ export declare namespace ITradingStorage {
367
414
  __placeholder: BigNumber;
368
415
  };
369
416
  }
417
+ export declare namespace IUpdateLeverage {
418
+ type UpdateLeverageValuesStruct = {
419
+ newLeverage: PromiseOrValue<BigNumberish>;
420
+ newCollateralAmount: PromiseOrValue<BigNumberish>;
421
+ liqPrice: PromiseOrValue<BigNumberish>;
422
+ govFeeCollateral: PromiseOrValue<BigNumberish>;
423
+ };
424
+ type UpdateLeverageValuesStructOutput = [
425
+ BigNumber,
426
+ BigNumber,
427
+ BigNumber,
428
+ BigNumber
429
+ ] & {
430
+ newLeverage: BigNumber;
431
+ newCollateralAmount: BigNumber;
432
+ liqPrice: BigNumber;
433
+ govFeeCollateral: BigNumber;
434
+ };
435
+ }
436
+ export declare namespace IUpdatePositionSize {
437
+ type DecreasePositionSizeValuesStruct = {
438
+ positionSizeCollateralDelta: PromiseOrValue<BigNumberish>;
439
+ existingPositionSizeCollateral: PromiseOrValue<BigNumberish>;
440
+ existingLiqPrice: PromiseOrValue<BigNumberish>;
441
+ priceAfterImpact: PromiseOrValue<BigNumberish>;
442
+ existingPnlCollateral: PromiseOrValue<BigNumberish>;
443
+ borrowingFeeCollateral: PromiseOrValue<BigNumberish>;
444
+ vaultFeeCollateral: PromiseOrValue<BigNumberish>;
445
+ gnsStakingFeeCollateral: PromiseOrValue<BigNumberish>;
446
+ availableCollateralInDiamond: PromiseOrValue<BigNumberish>;
447
+ collateralSentToTrader: PromiseOrValue<BigNumberish>;
448
+ newCollateralAmount: PromiseOrValue<BigNumberish>;
449
+ newLeverage: PromiseOrValue<BigNumberish>;
450
+ };
451
+ type DecreasePositionSizeValuesStructOutput = [
452
+ BigNumber,
453
+ BigNumber,
454
+ BigNumber,
455
+ BigNumber,
456
+ BigNumber,
457
+ BigNumber,
458
+ BigNumber,
459
+ BigNumber,
460
+ BigNumber,
461
+ BigNumber,
462
+ BigNumber,
463
+ number
464
+ ] & {
465
+ positionSizeCollateralDelta: BigNumber;
466
+ existingPositionSizeCollateral: BigNumber;
467
+ existingLiqPrice: BigNumber;
468
+ priceAfterImpact: BigNumber;
469
+ existingPnlCollateral: BigNumber;
470
+ borrowingFeeCollateral: BigNumber;
471
+ vaultFeeCollateral: BigNumber;
472
+ gnsStakingFeeCollateral: BigNumber;
473
+ availableCollateralInDiamond: BigNumber;
474
+ collateralSentToTrader: BigNumber;
475
+ newCollateralAmount: BigNumber;
476
+ newLeverage: number;
477
+ };
478
+ type IncreasePositionSizeValuesStruct = {
479
+ positionSizeCollateralDelta: PromiseOrValue<BigNumberish>;
480
+ existingPositionSizeCollateral: PromiseOrValue<BigNumberish>;
481
+ newPositionSizeCollateral: PromiseOrValue<BigNumberish>;
482
+ newCollateralAmount: PromiseOrValue<BigNumberish>;
483
+ newLeverage: PromiseOrValue<BigNumberish>;
484
+ priceAfterImpact: PromiseOrValue<BigNumberish>;
485
+ existingPnlCollateral: PromiseOrValue<BigNumberish>;
486
+ newOpenPrice: PromiseOrValue<BigNumberish>;
487
+ borrowingFeeCollateral: PromiseOrValue<BigNumberish>;
488
+ openingFeesCollateral: PromiseOrValue<BigNumberish>;
489
+ existingLiqPrice: PromiseOrValue<BigNumberish>;
490
+ newLiqPrice: PromiseOrValue<BigNumberish>;
491
+ };
492
+ type IncreasePositionSizeValuesStructOutput = [
493
+ BigNumber,
494
+ BigNumber,
495
+ BigNumber,
496
+ BigNumber,
497
+ BigNumber,
498
+ BigNumber,
499
+ BigNumber,
500
+ BigNumber,
501
+ BigNumber,
502
+ BigNumber,
503
+ BigNumber,
504
+ BigNumber
505
+ ] & {
506
+ positionSizeCollateralDelta: BigNumber;
507
+ existingPositionSizeCollateral: BigNumber;
508
+ newPositionSizeCollateral: BigNumber;
509
+ newCollateralAmount: BigNumber;
510
+ newLeverage: BigNumber;
511
+ priceAfterImpact: BigNumber;
512
+ existingPnlCollateral: BigNumber;
513
+ newOpenPrice: BigNumber;
514
+ borrowingFeeCollateral: BigNumber;
515
+ openingFeesCollateral: BigNumber;
516
+ existingLiqPrice: BigNumber;
517
+ newLiqPrice: BigNumber;
518
+ };
519
+ }
370
520
  export declare namespace ITradingCallbacks {
371
521
  type AggregatorAnswerStruct = {
372
522
  orderId: ITradingStorage.IdStruct;
@@ -391,6 +541,56 @@ export declare namespace ITradingCallbacks {
391
541
  high: BigNumber;
392
542
  low: BigNumber;
393
543
  };
544
+ type ValuesStruct = {
545
+ positionSizeCollateral: PromiseOrValue<BigNumberish>;
546
+ gnsPriceCollateral: PromiseOrValue<BigNumberish>;
547
+ profitP: PromiseOrValue<BigNumberish>;
548
+ executionPrice: PromiseOrValue<BigNumberish>;
549
+ liqPrice: PromiseOrValue<BigNumberish>;
550
+ amountSentToTrader: PromiseOrValue<BigNumberish>;
551
+ reward1: PromiseOrValue<BigNumberish>;
552
+ reward2: PromiseOrValue<BigNumberish>;
553
+ reward3: PromiseOrValue<BigNumberish>;
554
+ collateralPrecisionDelta: PromiseOrValue<BigNumberish>;
555
+ collateralPriceUsd: PromiseOrValue<BigNumberish>;
556
+ exactExecution: PromiseOrValue<boolean>;
557
+ closingFeeCollateral: PromiseOrValue<BigNumberish>;
558
+ triggerFeeCollateral: PromiseOrValue<BigNumberish>;
559
+ collateralLeftInStorage: PromiseOrValue<BigNumberish>;
560
+ };
561
+ type ValuesStructOutput = [
562
+ BigNumber,
563
+ BigNumber,
564
+ BigNumber,
565
+ BigNumber,
566
+ BigNumber,
567
+ BigNumber,
568
+ BigNumber,
569
+ BigNumber,
570
+ BigNumber,
571
+ BigNumber,
572
+ BigNumber,
573
+ boolean,
574
+ BigNumber,
575
+ BigNumber,
576
+ BigNumber
577
+ ] & {
578
+ positionSizeCollateral: BigNumber;
579
+ gnsPriceCollateral: BigNumber;
580
+ profitP: BigNumber;
581
+ executionPrice: BigNumber;
582
+ liqPrice: BigNumber;
583
+ amountSentToTrader: BigNumber;
584
+ reward1: BigNumber;
585
+ reward2: BigNumber;
586
+ reward3: BigNumber;
587
+ collateralPrecisionDelta: BigNumber;
588
+ collateralPriceUsd: BigNumber;
589
+ exactExecution: boolean;
590
+ closingFeeCollateral: BigNumber;
591
+ triggerFeeCollateral: BigNumber;
592
+ collateralLeftInStorage: BigNumber;
593
+ };
394
594
  }
395
595
  export declare namespace IBorrowingFees {
396
596
  type BorrowingDataStruct = {
@@ -514,6 +714,8 @@ export declare namespace IBorrowingFees {
514
714
  long: PromiseOrValue<boolean>;
515
715
  collateral: PromiseOrValue<BigNumberish>;
516
716
  leverage: PromiseOrValue<BigNumberish>;
717
+ useBorrowingFees: PromiseOrValue<boolean>;
718
+ liquidationParams: IPairsStorage.GroupLiquidationParamsStruct;
517
719
  };
518
720
  type LiqPriceInputStructOutput = [
519
721
  number,
@@ -523,7 +725,9 @@ export declare namespace IBorrowingFees {
523
725
  BigNumber,
524
726
  boolean,
525
727
  BigNumber,
526
- number
728
+ BigNumber,
729
+ boolean,
730
+ IPairsStorage.GroupLiquidationParamsStructOutput
527
731
  ] & {
528
732
  collateralIndex: number;
529
733
  trader: string;
@@ -532,7 +736,9 @@ export declare namespace IBorrowingFees {
532
736
  openPrice: BigNumber;
533
737
  long: boolean;
534
738
  collateral: BigNumber;
535
- leverage: number;
739
+ leverage: BigNumber;
740
+ useBorrowingFees: boolean;
741
+ liquidationParams: IPairsStorage.GroupLiquidationParamsStructOutput;
536
742
  };
537
743
  type BorrowingGroupParamsStruct = {
538
744
  feePerBlock: PromiseOrValue<BigNumberish>;
@@ -563,14 +769,21 @@ export declare namespace IBorrowingFees {
563
769
  };
564
770
  }
565
771
  export declare namespace IPriceAggregator {
566
- type UniV3PoolInfoStruct = {
772
+ type LiquidityPoolInfoStruct = {
567
773
  pool: PromiseOrValue<string>;
568
774
  isGnsToken0InLp: PromiseOrValue<boolean>;
775
+ poolType: PromiseOrValue<BigNumberish>;
569
776
  __placeholder: PromiseOrValue<BigNumberish>;
570
777
  };
571
- type UniV3PoolInfoStructOutput = [string, boolean, BigNumber] & {
778
+ type LiquidityPoolInfoStructOutput = [
779
+ string,
780
+ boolean,
781
+ number,
782
+ BigNumber
783
+ ] & {
572
784
  pool: string;
573
785
  isGnsToken0InLp: boolean;
786
+ poolType: number;
574
787
  __placeholder: BigNumber;
575
788
  };
576
789
  type OrderStruct = {
@@ -613,6 +826,14 @@ export declare namespace IPriceAggregator {
613
826
  low: BigNumber;
614
827
  ts: BigNumber;
615
828
  };
829
+ type LiquidityPoolInputStruct = {
830
+ pool: PromiseOrValue<string>;
831
+ poolType: PromiseOrValue<BigNumberish>;
832
+ };
833
+ type LiquidityPoolInputStructOutput = [string, number] & {
834
+ pool: string;
835
+ poolType: number;
836
+ };
616
837
  }
617
838
  export declare namespace BufferChainlink {
618
839
  type BufferStruct = {
@@ -646,6 +867,28 @@ export declare namespace Chainlink {
646
867
  buf: BufferChainlink.BufferStructOutput;
647
868
  };
648
869
  }
870
+ export declare namespace IOtc {
871
+ type OtcConfigStruct = {
872
+ gnsTreasury: PromiseOrValue<string>;
873
+ treasuryShareP: PromiseOrValue<BigNumberish>;
874
+ stakingShareP: PromiseOrValue<BigNumberish>;
875
+ burnShareP: PromiseOrValue<BigNumberish>;
876
+ premiumP: PromiseOrValue<BigNumberish>;
877
+ };
878
+ type OtcConfigStructOutput = [
879
+ string,
880
+ BigNumber,
881
+ BigNumber,
882
+ BigNumber,
883
+ BigNumber
884
+ ] & {
885
+ gnsTreasury: string;
886
+ treasuryShareP: BigNumber;
887
+ stakingShareP: BigNumber;
888
+ burnShareP: BigNumber;
889
+ premiumP: BigNumber;
890
+ };
891
+ }
649
892
  export interface GNSMultiCollatDiamondInterface extends utils.Interface {
650
893
  functions: {
651
894
  "diamondCut((address,uint8,bytes4[])[],address,bytes)": FunctionFragment;
@@ -663,14 +906,18 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
663
906
  "fees(uint256)": FunctionFragment;
664
907
  "feesCount()": FunctionFragment;
665
908
  "getAllPairsRestrictedMaxLeverage()": FunctionFragment;
909
+ "getGroupLiquidationParams(uint256)": FunctionFragment;
910
+ "getPairLiquidationParams(uint256)": FunctionFragment;
666
911
  "groups(uint256)": FunctionFragment;
667
912
  "groupsCount()": FunctionFragment;
913
+ "initializeGroupLiquidationParams((uint40,uint40,uint40,uint24,uint24)[])": FunctionFragment;
668
914
  "isPairIndexListed(uint256)": FunctionFragment;
669
915
  "isPairListed(string,string)": FunctionFragment;
670
916
  "pairCloseFeeP(uint256)": FunctionFragment;
671
917
  "pairCustomMaxLeverage(uint256)": FunctionFragment;
672
918
  "pairJob(uint256)": FunctionFragment;
673
919
  "pairMaxLeverage(uint256)": FunctionFragment;
920
+ "pairMinFeeUsd(uint256)": FunctionFragment;
674
921
  "pairMinLeverage(uint256)": FunctionFragment;
675
922
  "pairMinPositionSizeUsd(uint256)": FunctionFragment;
676
923
  "pairOpenFeeP(uint256)": FunctionFragment;
@@ -680,6 +927,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
680
927
  "pairs(uint256)": FunctionFragment;
681
928
  "pairsBackend(uint256)": FunctionFragment;
682
929
  "pairsCount()": FunctionFragment;
930
+ "setGroupLiquidationParams(uint256,(uint40,uint40,uint40,uint24,uint24))": FunctionFragment;
683
931
  "setPairCustomMaxLeverages(uint256[],uint256[])": FunctionFragment;
684
932
  "updateFees(uint256[],(string,uint256,uint256,uint256,uint256,uint256)[])": FunctionFragment;
685
933
  "updateGroups(uint256[],(string,bytes32,uint256,uint256)[])": FunctionFragment;
@@ -718,52 +966,60 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
718
966
  "setFeeTiers(uint256[],(uint32,uint32)[])": FunctionFragment;
719
967
  "setGroupVolumeMultipliers(uint256[],uint256[])": FunctionFragment;
720
968
  "updateTraderPoints(address,uint256,uint256)": FunctionFragment;
721
- "addPriceImpactOpenInterest(uint256,uint256,bool)": FunctionFragment;
969
+ "addPriceImpactOpenInterest(address,uint32,uint256,bool)": FunctionFragment;
722
970
  "getOiWindow(uint48,uint256,uint256)": FunctionFragment;
723
971
  "getOiWindows(uint48,uint256,uint256[])": FunctionFragment;
724
972
  "getOiWindowsSettings()": FunctionFragment;
725
973
  "getPairDepth(uint256)": FunctionFragment;
726
974
  "getPairDepths(uint256[])": FunctionFragment;
975
+ "getPairFactors(uint256[])": FunctionFragment;
727
976
  "getPriceImpactOi(uint256,bool)": FunctionFragment;
728
- "getTradePriceImpact(uint256,uint256,bool,uint256)": FunctionFragment;
977
+ "getTradePriceImpact(uint256,uint256,bool,uint256,bool,bool,uint256,uint8)": FunctionFragment;
978
+ "initializePairFactors(uint16[],uint40[],uint32[],uint40[])": FunctionFragment;
729
979
  "initializePriceImpact(uint48,uint48)": FunctionFragment;
730
- "removePriceImpactOpenInterest(uint256,uint256,bool,uint48)": FunctionFragment;
980
+ "setCumulativeFactors(uint16[],uint40[])": FunctionFragment;
731
981
  "setPairDepths(uint256[],uint128[],uint128[])": FunctionFragment;
732
982
  "setPriceImpactWindowsCount(uint48)": FunctionFragment;
733
983
  "setPriceImpactWindowsDuration(uint48)": FunctionFragment;
984
+ "setProtectionCloseFactorBlocks(uint16[],uint32[])": FunctionFragment;
985
+ "setProtectionCloseFactors(uint16[],uint40[])": FunctionFragment;
734
986
  "addCollateral(address,address)": FunctionFragment;
735
987
  "closePendingOrder((address,uint32))": FunctionFragment;
736
988
  "closeTrade((address,uint32))": FunctionFragment;
737
989
  "getAllPendingOrders(uint256,uint256)": FunctionFragment;
738
990
  "getAllTradeInfos(uint256,uint256)": FunctionFragment;
739
991
  "getAllTrades(uint256,uint256)": FunctionFragment;
992
+ "getAllTradesLiquidationParams(uint256,uint256)": FunctionFragment;
740
993
  "getCollateral(uint8)": FunctionFragment;
741
994
  "getCollateralIndex(address)": FunctionFragment;
742
995
  "getCollaterals()": FunctionFragment;
743
996
  "getCollateralsCount()": FunctionFragment;
744
997
  "getCounters(address,uint8)": FunctionFragment;
998
+ "getCurrentContractsVersion()": FunctionFragment;
745
999
  "getGToken(uint8)": FunctionFragment;
746
- "getPendingOpenOrderType(uint8)": FunctionFragment;
747
1000
  "getPendingOrder((address,uint32))": FunctionFragment;
748
1001
  "getPendingOrders(address)": FunctionFragment;
749
- "getPnlPercent(uint64,uint64,bool,uint24)": FunctionFragment;
750
1002
  "getTrade(address,uint32)": FunctionFragment;
751
1003
  "getTradeInfo(address,uint32)": FunctionFragment;
752
1004
  "getTradeInfos(address)": FunctionFragment;
1005
+ "getTradeLiquidationParams(address,uint32)": FunctionFragment;
753
1006
  "getTradePendingOrderBlock((address,uint32),uint8)": FunctionFragment;
754
1007
  "getTraderStored(address)": FunctionFragment;
755
1008
  "getTraders(uint32,uint32)": FunctionFragment;
756
1009
  "getTrades(address)": FunctionFragment;
1010
+ "getTradesLiquidationParams(address)": FunctionFragment;
757
1011
  "getTradingActivated()": FunctionFragment;
758
1012
  "initializeTradingStorage(address,address,address[],address[])": FunctionFragment;
759
1013
  "isCollateralActive(uint8)": FunctionFragment;
760
1014
  "isCollateralListed(uint8)": FunctionFragment;
761
1015
  "storePendingOrder(((address,uint32,uint16,uint24,bool,bool,uint8,uint8,uint120,uint64,uint64,uint64,uint192),address,uint32,bool,uint8,uint32,uint16))": FunctionFragment;
762
- "storeTrade((address,uint32,uint16,uint24,bool,bool,uint8,uint8,uint120,uint64,uint64,uint64,uint192),(uint32,uint32,uint32,uint16,uint48,uint48,uint48))": FunctionFragment;
1016
+ "storeTrade((address,uint32,uint16,uint24,bool,bool,uint8,uint8,uint120,uint64,uint64,uint64,uint192),(uint32,uint32,uint32,uint16,uint48,uint48,uint8,uint32,uint8))": FunctionFragment;
763
1017
  "toggleCollateralActiveState(uint8)": FunctionFragment;
764
1018
  "updateGToken(address,address)": FunctionFragment;
765
1019
  "updateOpenOrderDetails((address,uint32),uint64,uint64,uint64,uint16)": FunctionFragment;
766
1020
  "updateTradeCollateralAmount((address,uint32),uint120)": FunctionFragment;
1021
+ "updateTradeMaxClosingSlippageP((address,uint32),uint16)": FunctionFragment;
1022
+ "updateTradePosition((address,uint32),uint120,uint24,uint64,bool)": FunctionFragment;
767
1023
  "updateTradeSl((address,uint32),uint64)": FunctionFragment;
768
1024
  "updateTradeTp((address,uint32),uint64)": FunctionFragment;
769
1025
  "updateTradingActivated(uint8)": FunctionFragment;
@@ -775,35 +1031,43 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
775
1031
  "initializeTriggerRewards(uint16)": FunctionFragment;
776
1032
  "updateTriggerTimeoutBlocks(uint16)": FunctionFragment;
777
1033
  "cancelOpenOrder(uint32)": FunctionFragment;
778
- "closeTradeMarket(uint32)": FunctionFragment;
779
- "closeTradeMarketTimeout((address,uint32))": FunctionFragment;
1034
+ "cancelOrderAfterTimeout(uint32)": FunctionFragment;
1035
+ "closeTradeMarket(uint32,uint64)": FunctionFragment;
1036
+ "decreasePositionSize(uint32,uint120,uint24,uint64)": FunctionFragment;
780
1037
  "delegatedTradingAction(address,bytes)": FunctionFragment;
781
1038
  "getByPassTriggerLink(address)": FunctionFragment;
782
1039
  "getMarketOrdersTimeoutBlocks()": FunctionFragment;
783
1040
  "getTradingDelegate(address)": FunctionFragment;
784
1041
  "getWrappedNativeToken()": FunctionFragment;
1042
+ "increasePositionSize(uint32,uint120,uint24,uint64,uint16)": FunctionFragment;
785
1043
  "initializeTrading(uint16,address[])": FunctionFragment;
786
1044
  "isWrappedNativeToken(address)": FunctionFragment;
787
1045
  "openTrade((address,uint32,uint16,uint24,bool,bool,uint8,uint8,uint120,uint64,uint64,uint64,uint192),uint16,address)": FunctionFragment;
788
- "openTradeMarketTimeout((address,uint32))": FunctionFragment;
789
1046
  "openTradeNative((address,uint32,uint16,uint24,bool,bool,uint8,uint8,uint120,uint64,uint64,uint64,uint192),uint16,address)": FunctionFragment;
790
1047
  "removeTradingDelegate()": FunctionFragment;
791
1048
  "setTradingDelegate(address)": FunctionFragment;
792
1049
  "triggerOrder(uint256)": FunctionFragment;
793
1050
  "updateByPassTriggerLink(address[],bool[])": FunctionFragment;
1051
+ "updateLeverage(uint32,uint24)": FunctionFragment;
794
1052
  "updateMarketOrdersTimeoutBlocks(uint16)": FunctionFragment;
1053
+ "updateMaxClosingSlippageP(uint32,uint16)": FunctionFragment;
795
1054
  "updateOpenOrder(uint32,uint64,uint64,uint64,uint16)": FunctionFragment;
796
1055
  "updateSl(uint32,uint64)": FunctionFragment;
797
1056
  "updateTp(uint32,uint64)": FunctionFragment;
798
1057
  "claimPendingGovFees()": FunctionFragment;
799
1058
  "closeTradeMarketCallback(((address,uint32),uint256,uint64,uint64,uint64,uint64))": FunctionFragment;
1059
+ "decreasePositionSizeMarketCallback(((address,uint32),uint256,uint64,uint64,uint64,uint64))": FunctionFragment;
800
1060
  "executeTriggerCloseOrderCallback(((address,uint32),uint256,uint64,uint64,uint64,uint64))": FunctionFragment;
801
1061
  "executeTriggerOpenOrderCallback(((address,uint32),uint256,uint64,uint64,uint64,uint64))": FunctionFragment;
802
1062
  "getPendingGovFeesCollateral(uint8)": FunctionFragment;
803
1063
  "getVaultClosingFeeP()": FunctionFragment;
1064
+ "increasePositionSizeMarketCallback(((address,uint32),uint256,uint64,uint64,uint64,uint64))": FunctionFragment;
804
1065
  "initializeCallbacks(uint8)": FunctionFragment;
805
1066
  "openTradeMarketCallback(((address,uint32),uint256,uint64,uint64,uint64,uint64))": FunctionFragment;
1067
+ "updateLeverageCallback(((address,uint32),uint256,uint64,uint64,uint64,uint64))": FunctionFragment;
806
1068
  "updateVaultClosingFeeP(uint8)": FunctionFragment;
1069
+ "validateTriggerCloseOrderCallback((address,uint32),uint8,uint64,uint64,uint64)": FunctionFragment;
1070
+ "validateTriggerOpenOrderCallback((address,uint32),uint8,uint64,uint64,uint64)": FunctionFragment;
807
1071
  "getAllBorrowingPairs(uint8)": FunctionFragment;
808
1072
  "getBorrowingGroup(uint8,uint16)": FunctionFragment;
809
1073
  "getBorrowingGroupOi(uint8,uint16)": FunctionFragment;
@@ -820,8 +1084,9 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
820
1084
  "getPairOiCollateral(uint8,uint16,bool)": FunctionFragment;
821
1085
  "getPairOisCollateral(uint8,uint16)": FunctionFragment;
822
1086
  "getTradeBorrowingFee((uint8,address,uint16,uint32,bool,uint256,uint256))": FunctionFragment;
823
- "getTradeLiquidationPrice((uint8,address,uint16,uint32,uint64,bool,uint256,uint24))": FunctionFragment;
1087
+ "getTradeLiquidationPrice((uint8,address,uint16,uint32,uint64,bool,uint256,uint256,bool,(uint40,uint40,uint40,uint24,uint24)))": FunctionFragment;
824
1088
  "handleTradeBorrowingCallback(uint8,address,uint16,uint32,uint256,bool,bool)": FunctionFragment;
1089
+ "resetTradeBorrowingFees(uint8,address,uint16,uint32,bool)": FunctionFragment;
825
1090
  "setBorrowingGroupParams(uint8,uint16,(uint32,uint72,uint48))": FunctionFragment;
826
1091
  "setBorrowingGroupParamsArray(uint8,uint16[],(uint32,uint72,uint48)[])": FunctionFragment;
827
1092
  "setBorrowingPairParams(uint8,uint16,(uint16,uint32,uint48,uint72))": FunctionFragment;
@@ -832,49 +1097,45 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
832
1097
  "fulfill(bytes32,uint256)": FunctionFragment;
833
1098
  "getChainlinkToken()": FunctionFragment;
834
1099
  "getCollateralFromUsdNormalizedValue(uint8,uint256)": FunctionFragment;
835
- "getCollateralGnsUniV3Pool(uint8)": FunctionFragment;
1100
+ "getCollateralGnsLiquidityPool(uint8)": FunctionFragment;
836
1101
  "getCollateralPriceUsd(uint8)": FunctionFragment;
837
1102
  "getCollateralUsdPriceFeed(uint8)": FunctionFragment;
838
1103
  "getGnsPriceCollateralAddress(address)": FunctionFragment;
839
1104
  "getGnsPriceCollateralIndex(uint8)": FunctionFragment;
840
1105
  "getGnsPriceUsd(uint8)": FunctionFragment;
841
1106
  "getLimitJobId()": FunctionFragment;
842
- "getLinkFee(uint8,uint16,uint256)": FunctionFragment;
1107
+ "getLinkFee(uint8,address,uint16,uint256)": FunctionFragment;
843
1108
  "getLinkUsdPriceFeed()": FunctionFragment;
844
1109
  "getMarketJobId()": FunctionFragment;
845
1110
  "getMinAnswers()": FunctionFragment;
846
1111
  "getOracle(uint256)": FunctionFragment;
847
1112
  "getOracles()": FunctionFragment;
848
1113
  "getPendingRequest(bytes32)": FunctionFragment;
849
- "getPrice(uint8,uint16,(address,uint32),uint8,uint256,uint256)": FunctionFragment;
1114
+ "getPrice(uint8,uint16,(address,uint32),(address,uint32),uint8,uint256,uint256)": FunctionFragment;
850
1115
  "getPriceAggregatorOrder(bytes32)": FunctionFragment;
851
1116
  "getPriceAggregatorOrderAnswers((address,uint32))": FunctionFragment;
852
1117
  "getRequestCount()": FunctionFragment;
853
1118
  "getTwapInterval()": FunctionFragment;
854
1119
  "getUsdNormalizedValue(uint8,uint256)": FunctionFragment;
855
- "initializePriceAggregator(address,address,uint24,uint8,address[],bytes32[2],uint8[],address[],address[])": FunctionFragment;
1120
+ "initializePriceAggregator(address,address,uint24,uint8,address[],bytes32[2],uint8[],(address,uint8)[],address[])": FunctionFragment;
856
1121
  "removeOracle(uint256)": FunctionFragment;
857
1122
  "replaceOracle(uint256,address)": FunctionFragment;
858
1123
  "setLimitJobId(bytes32)": FunctionFragment;
859
1124
  "setMarketJobId(bytes32)": FunctionFragment;
860
- "updateCollateralGnsUniV3Pool(uint8,address)": FunctionFragment;
1125
+ "updateCollateralGnsLiquidityPool(uint8,(address,uint8))": FunctionFragment;
861
1126
  "updateCollateralUsdPriceFeed(uint8,address)": FunctionFragment;
862
1127
  "updateLinkUsdPriceFeed(address)": FunctionFragment;
863
1128
  "updateMinAnswers(uint8)": FunctionFragment;
864
1129
  "updateTwapInterval(uint24)": FunctionFragment;
865
- "copyAllState(uint8,address[])": FunctionFragment;
866
- "copyBorrowingFeesGroups(uint8)": FunctionFragment;
867
- "copyBorrowingFeesPairs(uint8)": FunctionFragment;
868
- "copyLimits(uint8,uint256)": FunctionFragment;
869
- "copyPairOis(uint8)": FunctionFragment;
870
- "copyTraderDelegations(uint8,address[])": FunctionFragment;
871
- "copyTrades(uint8,uint16)": FunctionFragment;
872
- "getCollateralStageState(uint8,uint8)": FunctionFragment;
873
- "getCollateralState(uint8)": FunctionFragment;
874
- "markAsDone(uint8)": FunctionFragment;
875
- "transferBalance(uint8)": FunctionFragment;
1130
+ "addOtcCollateralBalance(uint8,uint256)": FunctionFragment;
1131
+ "getOtcBalance(uint8)": FunctionFragment;
1132
+ "getOtcConfig()": FunctionFragment;
1133
+ "getOtcRate(uint8)": FunctionFragment;
1134
+ "initializeOtc((address,uint64,uint64,uint64,uint64))": FunctionFragment;
1135
+ "sellGnsForCollateral(uint8,uint256)": FunctionFragment;
1136
+ "updateOtcConfig((address,uint64,uint64,uint64,uint64))": FunctionFragment;
876
1137
  };
877
- getFunction(nameOrSignatureOrTopic: "diamondCut" | "facetAddress" | "facetAddresses" | "facetFunctionSelectors" | "facets" | "getAddresses" | "hasRole" | "initialize" | "setRoles" | "addFees" | "addGroups" | "addPairs" | "fees" | "feesCount" | "getAllPairsRestrictedMaxLeverage" | "groups" | "groupsCount" | "isPairIndexListed" | "isPairListed" | "pairCloseFeeP" | "pairCustomMaxLeverage" | "pairJob" | "pairMaxLeverage" | "pairMinLeverage" | "pairMinPositionSizeUsd" | "pairOpenFeeP" | "pairOracleFeeP" | "pairSpreadP" | "pairTriggerOrderFeeP" | "pairs" | "pairsBackend" | "pairsCount" | "setPairCustomMaxLeverages" | "updateFees" | "updateGroups" | "updatePairs" | "claimAllyRewards" | "claimReferrerRewards" | "distributeReferralReward" | "getAllyDetails" | "getReferralsAllyFeeP" | "getReferralsOpenFeeP" | "getReferralsStartReferrerFeeP" | "getReferralsTargetVolumeUsd" | "getReferrerDetails" | "getReferrerFeeP" | "getReferrersReferred" | "getTraderActiveReferrer" | "getTraderLastReferrer" | "getTradersReferred" | "initializeReferrals" | "registerPotentialReferrer" | "unwhitelistAllies" | "unwhitelistReferrers" | "updateAllyFeeP" | "updateReferralsOpenFeeP" | "updateReferralsTargetVolumeUsd" | "updateStartReferrerFeeP" | "whitelistAllies" | "whitelistReferrers" | "calculateFeeAmount" | "getFeeTier" | "getFeeTiersCount" | "getFeeTiersTraderDailyInfo" | "getFeeTiersTraderInfo" | "getGroupVolumeMultiplier" | "initializeFeeTiers" | "setFeeTiers" | "setGroupVolumeMultipliers" | "updateTraderPoints" | "addPriceImpactOpenInterest" | "getOiWindow" | "getOiWindows" | "getOiWindowsSettings" | "getPairDepth" | "getPairDepths" | "getPriceImpactOi" | "getTradePriceImpact" | "initializePriceImpact" | "removePriceImpactOpenInterest" | "setPairDepths" | "setPriceImpactWindowsCount" | "setPriceImpactWindowsDuration" | "addCollateral" | "closePendingOrder" | "closeTrade" | "getAllPendingOrders" | "getAllTradeInfos" | "getAllTrades" | "getCollateral" | "getCollateralIndex" | "getCollaterals" | "getCollateralsCount" | "getCounters" | "getGToken" | "getPendingOpenOrderType" | "getPendingOrder" | "getPendingOrders" | "getPnlPercent" | "getTrade" | "getTradeInfo" | "getTradeInfos" | "getTradePendingOrderBlock" | "getTraderStored" | "getTraders" | "getTrades" | "getTradingActivated" | "initializeTradingStorage" | "isCollateralActive" | "isCollateralListed" | "storePendingOrder" | "storeTrade" | "toggleCollateralActiveState" | "updateGToken" | "updateOpenOrderDetails" | "updateTradeCollateralAmount" | "updateTradeSl" | "updateTradeTp" | "updateTradingActivated" | "claimPendingTriggerRewards" | "distributeTriggerReward" | "getTriggerPendingRewardsGns" | "getTriggerTimeoutBlocks" | "hasActiveOrder" | "initializeTriggerRewards" | "updateTriggerTimeoutBlocks" | "cancelOpenOrder" | "closeTradeMarket" | "closeTradeMarketTimeout" | "delegatedTradingAction" | "getByPassTriggerLink" | "getMarketOrdersTimeoutBlocks" | "getTradingDelegate" | "getWrappedNativeToken" | "initializeTrading" | "isWrappedNativeToken" | "openTrade" | "openTradeMarketTimeout" | "openTradeNative" | "removeTradingDelegate" | "setTradingDelegate" | "triggerOrder" | "updateByPassTriggerLink" | "updateMarketOrdersTimeoutBlocks" | "updateOpenOrder" | "updateSl" | "updateTp" | "claimPendingGovFees" | "closeTradeMarketCallback" | "executeTriggerCloseOrderCallback" | "executeTriggerOpenOrderCallback" | "getPendingGovFeesCollateral" | "getVaultClosingFeeP" | "initializeCallbacks" | "openTradeMarketCallback" | "updateVaultClosingFeeP" | "getAllBorrowingPairs" | "getBorrowingGroup" | "getBorrowingGroupOi" | "getBorrowingGroupPendingAccFees" | "getBorrowingGroups" | "getBorrowingInitialAccFees" | "getBorrowingPair" | "getBorrowingPairGroupIndex" | "getBorrowingPairGroups" | "getBorrowingPairOi" | "getBorrowingPairPendingAccFees" | "getPairMaxOi" | "getPairMaxOiCollateral" | "getPairOiCollateral" | "getPairOisCollateral" | "getTradeBorrowingFee" | "getTradeLiquidationPrice" | "handleTradeBorrowingCallback" | "setBorrowingGroupParams" | "setBorrowingGroupParamsArray" | "setBorrowingPairParams" | "setBorrowingPairParamsArray" | "withinMaxBorrowingGroupOi" | "addOracle" | "claimBackLink" | "fulfill" | "getChainlinkToken" | "getCollateralFromUsdNormalizedValue" | "getCollateralGnsUniV3Pool" | "getCollateralPriceUsd" | "getCollateralUsdPriceFeed" | "getGnsPriceCollateralAddress" | "getGnsPriceCollateralIndex" | "getGnsPriceUsd" | "getLimitJobId" | "getLinkFee" | "getLinkUsdPriceFeed" | "getMarketJobId" | "getMinAnswers" | "getOracle" | "getOracles" | "getPendingRequest" | "getPrice" | "getPriceAggregatorOrder" | "getPriceAggregatorOrderAnswers" | "getRequestCount" | "getTwapInterval" | "getUsdNormalizedValue" | "initializePriceAggregator" | "removeOracle" | "replaceOracle" | "setLimitJobId" | "setMarketJobId" | "updateCollateralGnsUniV3Pool" | "updateCollateralUsdPriceFeed" | "updateLinkUsdPriceFeed" | "updateMinAnswers" | "updateTwapInterval" | "copyAllState" | "copyBorrowingFeesGroups" | "copyBorrowingFeesPairs" | "copyLimits" | "copyPairOis" | "copyTraderDelegations" | "copyTrades" | "getCollateralStageState" | "getCollateralState" | "markAsDone" | "transferBalance"): FunctionFragment;
1138
+ getFunction(nameOrSignatureOrTopic: "diamondCut" | "facetAddress" | "facetAddresses" | "facetFunctionSelectors" | "facets" | "getAddresses" | "hasRole" | "initialize" | "setRoles" | "addFees" | "addGroups" | "addPairs" | "fees" | "feesCount" | "getAllPairsRestrictedMaxLeverage" | "getGroupLiquidationParams" | "getPairLiquidationParams" | "groups" | "groupsCount" | "initializeGroupLiquidationParams" | "isPairIndexListed" | "isPairListed" | "pairCloseFeeP" | "pairCustomMaxLeverage" | "pairJob" | "pairMaxLeverage" | "pairMinFeeUsd" | "pairMinLeverage" | "pairMinPositionSizeUsd" | "pairOpenFeeP" | "pairOracleFeeP" | "pairSpreadP" | "pairTriggerOrderFeeP" | "pairs" | "pairsBackend" | "pairsCount" | "setGroupLiquidationParams" | "setPairCustomMaxLeverages" | "updateFees" | "updateGroups" | "updatePairs" | "claimAllyRewards" | "claimReferrerRewards" | "distributeReferralReward" | "getAllyDetails" | "getReferralsAllyFeeP" | "getReferralsOpenFeeP" | "getReferralsStartReferrerFeeP" | "getReferralsTargetVolumeUsd" | "getReferrerDetails" | "getReferrerFeeP" | "getReferrersReferred" | "getTraderActiveReferrer" | "getTraderLastReferrer" | "getTradersReferred" | "initializeReferrals" | "registerPotentialReferrer" | "unwhitelistAllies" | "unwhitelistReferrers" | "updateAllyFeeP" | "updateReferralsOpenFeeP" | "updateReferralsTargetVolumeUsd" | "updateStartReferrerFeeP" | "whitelistAllies" | "whitelistReferrers" | "calculateFeeAmount" | "getFeeTier" | "getFeeTiersCount" | "getFeeTiersTraderDailyInfo" | "getFeeTiersTraderInfo" | "getGroupVolumeMultiplier" | "initializeFeeTiers" | "setFeeTiers" | "setGroupVolumeMultipliers" | "updateTraderPoints" | "addPriceImpactOpenInterest" | "getOiWindow" | "getOiWindows" | "getOiWindowsSettings" | "getPairDepth" | "getPairDepths" | "getPairFactors" | "getPriceImpactOi" | "getTradePriceImpact" | "initializePairFactors" | "initializePriceImpact" | "setCumulativeFactors" | "setPairDepths" | "setPriceImpactWindowsCount" | "setPriceImpactWindowsDuration" | "setProtectionCloseFactorBlocks" | "setProtectionCloseFactors" | "addCollateral" | "closePendingOrder" | "closeTrade" | "getAllPendingOrders" | "getAllTradeInfos" | "getAllTrades" | "getAllTradesLiquidationParams" | "getCollateral" | "getCollateralIndex" | "getCollaterals" | "getCollateralsCount" | "getCounters" | "getCurrentContractsVersion" | "getGToken" | "getPendingOrder" | "getPendingOrders" | "getTrade" | "getTradeInfo" | "getTradeInfos" | "getTradeLiquidationParams" | "getTradePendingOrderBlock" | "getTraderStored" | "getTraders" | "getTrades" | "getTradesLiquidationParams" | "getTradingActivated" | "initializeTradingStorage" | "isCollateralActive" | "isCollateralListed" | "storePendingOrder" | "storeTrade" | "toggleCollateralActiveState" | "updateGToken" | "updateOpenOrderDetails" | "updateTradeCollateralAmount" | "updateTradeMaxClosingSlippageP" | "updateTradePosition" | "updateTradeSl" | "updateTradeTp" | "updateTradingActivated" | "claimPendingTriggerRewards" | "distributeTriggerReward" | "getTriggerPendingRewardsGns" | "getTriggerTimeoutBlocks" | "hasActiveOrder" | "initializeTriggerRewards" | "updateTriggerTimeoutBlocks" | "cancelOpenOrder" | "cancelOrderAfterTimeout" | "closeTradeMarket" | "decreasePositionSize" | "delegatedTradingAction" | "getByPassTriggerLink" | "getMarketOrdersTimeoutBlocks" | "getTradingDelegate" | "getWrappedNativeToken" | "increasePositionSize" | "initializeTrading" | "isWrappedNativeToken" | "openTrade" | "openTradeNative" | "removeTradingDelegate" | "setTradingDelegate" | "triggerOrder" | "updateByPassTriggerLink" | "updateLeverage" | "updateMarketOrdersTimeoutBlocks" | "updateMaxClosingSlippageP" | "updateOpenOrder" | "updateSl" | "updateTp" | "claimPendingGovFees" | "closeTradeMarketCallback" | "decreasePositionSizeMarketCallback" | "executeTriggerCloseOrderCallback" | "executeTriggerOpenOrderCallback" | "getPendingGovFeesCollateral" | "getVaultClosingFeeP" | "increasePositionSizeMarketCallback" | "initializeCallbacks" | "openTradeMarketCallback" | "updateLeverageCallback" | "updateVaultClosingFeeP" | "validateTriggerCloseOrderCallback" | "validateTriggerOpenOrderCallback" | "getAllBorrowingPairs" | "getBorrowingGroup" | "getBorrowingGroupOi" | "getBorrowingGroupPendingAccFees" | "getBorrowingGroups" | "getBorrowingInitialAccFees" | "getBorrowingPair" | "getBorrowingPairGroupIndex" | "getBorrowingPairGroups" | "getBorrowingPairOi" | "getBorrowingPairPendingAccFees" | "getPairMaxOi" | "getPairMaxOiCollateral" | "getPairOiCollateral" | "getPairOisCollateral" | "getTradeBorrowingFee" | "getTradeLiquidationPrice" | "handleTradeBorrowingCallback" | "resetTradeBorrowingFees" | "setBorrowingGroupParams" | "setBorrowingGroupParamsArray" | "setBorrowingPairParams" | "setBorrowingPairParamsArray" | "withinMaxBorrowingGroupOi" | "addOracle" | "claimBackLink" | "fulfill" | "getChainlinkToken" | "getCollateralFromUsdNormalizedValue" | "getCollateralGnsLiquidityPool" | "getCollateralPriceUsd" | "getCollateralUsdPriceFeed" | "getGnsPriceCollateralAddress" | "getGnsPriceCollateralIndex" | "getGnsPriceUsd" | "getLimitJobId" | "getLinkFee" | "getLinkUsdPriceFeed" | "getMarketJobId" | "getMinAnswers" | "getOracle" | "getOracles" | "getPendingRequest" | "getPrice" | "getPriceAggregatorOrder" | "getPriceAggregatorOrderAnswers" | "getRequestCount" | "getTwapInterval" | "getUsdNormalizedValue" | "initializePriceAggregator" | "removeOracle" | "replaceOracle" | "setLimitJobId" | "setMarketJobId" | "updateCollateralGnsLiquidityPool" | "updateCollateralUsdPriceFeed" | "updateLinkUsdPriceFeed" | "updateMinAnswers" | "updateTwapInterval" | "addOtcCollateralBalance" | "getOtcBalance" | "getOtcConfig" | "getOtcRate" | "initializeOtc" | "sellGnsForCollateral" | "updateOtcConfig"): FunctionFragment;
878
1139
  encodeFunctionData(functionFragment: "diamondCut", values: [
879
1140
  IDiamondStorage.FacetCutStruct[],
880
1141
  PromiseOrValue<string>,
@@ -898,14 +1159,18 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
898
1159
  encodeFunctionData(functionFragment: "fees", values: [PromiseOrValue<BigNumberish>]): string;
899
1160
  encodeFunctionData(functionFragment: "feesCount", values?: undefined): string;
900
1161
  encodeFunctionData(functionFragment: "getAllPairsRestrictedMaxLeverage", values?: undefined): string;
1162
+ encodeFunctionData(functionFragment: "getGroupLiquidationParams", values: [PromiseOrValue<BigNumberish>]): string;
1163
+ encodeFunctionData(functionFragment: "getPairLiquidationParams", values: [PromiseOrValue<BigNumberish>]): string;
901
1164
  encodeFunctionData(functionFragment: "groups", values: [PromiseOrValue<BigNumberish>]): string;
902
1165
  encodeFunctionData(functionFragment: "groupsCount", values?: undefined): string;
1166
+ encodeFunctionData(functionFragment: "initializeGroupLiquidationParams", values: [IPairsStorage.GroupLiquidationParamsStruct[]]): string;
903
1167
  encodeFunctionData(functionFragment: "isPairIndexListed", values: [PromiseOrValue<BigNumberish>]): string;
904
1168
  encodeFunctionData(functionFragment: "isPairListed", values: [PromiseOrValue<string>, PromiseOrValue<string>]): string;
905
1169
  encodeFunctionData(functionFragment: "pairCloseFeeP", values: [PromiseOrValue<BigNumberish>]): string;
906
1170
  encodeFunctionData(functionFragment: "pairCustomMaxLeverage", values: [PromiseOrValue<BigNumberish>]): string;
907
1171
  encodeFunctionData(functionFragment: "pairJob", values: [PromiseOrValue<BigNumberish>]): string;
908
1172
  encodeFunctionData(functionFragment: "pairMaxLeverage", values: [PromiseOrValue<BigNumberish>]): string;
1173
+ encodeFunctionData(functionFragment: "pairMinFeeUsd", values: [PromiseOrValue<BigNumberish>]): string;
909
1174
  encodeFunctionData(functionFragment: "pairMinLeverage", values: [PromiseOrValue<BigNumberish>]): string;
910
1175
  encodeFunctionData(functionFragment: "pairMinPositionSizeUsd", values: [PromiseOrValue<BigNumberish>]): string;
911
1176
  encodeFunctionData(functionFragment: "pairOpenFeeP", values: [PromiseOrValue<BigNumberish>]): string;
@@ -915,6 +1180,10 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
915
1180
  encodeFunctionData(functionFragment: "pairs", values: [PromiseOrValue<BigNumberish>]): string;
916
1181
  encodeFunctionData(functionFragment: "pairsBackend", values: [PromiseOrValue<BigNumberish>]): string;
917
1182
  encodeFunctionData(functionFragment: "pairsCount", values?: undefined): string;
1183
+ encodeFunctionData(functionFragment: "setGroupLiquidationParams", values: [
1184
+ PromiseOrValue<BigNumberish>,
1185
+ IPairsStorage.GroupLiquidationParamsStruct
1186
+ ]): string;
918
1187
  encodeFunctionData(functionFragment: "setPairCustomMaxLeverages", values: [PromiseOrValue<BigNumberish>[], PromiseOrValue<BigNumberish>[]]): string;
919
1188
  encodeFunctionData(functionFragment: "updateFees", values: [PromiseOrValue<BigNumberish>[], IPairsStorage.FeeStruct[]]): string;
920
1189
  encodeFunctionData(functionFragment: "updateGroups", values: [PromiseOrValue<BigNumberish>[], IPairsStorage.GroupStruct[]]): string;
@@ -973,6 +1242,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
973
1242
  PromiseOrValue<BigNumberish>
974
1243
  ]): string;
975
1244
  encodeFunctionData(functionFragment: "addPriceImpactOpenInterest", values: [
1245
+ PromiseOrValue<string>,
976
1246
  PromiseOrValue<BigNumberish>,
977
1247
  PromiseOrValue<BigNumberish>,
978
1248
  PromiseOrValue<boolean>
@@ -990,20 +1260,26 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
990
1260
  encodeFunctionData(functionFragment: "getOiWindowsSettings", values?: undefined): string;
991
1261
  encodeFunctionData(functionFragment: "getPairDepth", values: [PromiseOrValue<BigNumberish>]): string;
992
1262
  encodeFunctionData(functionFragment: "getPairDepths", values: [PromiseOrValue<BigNumberish>[]]): string;
1263
+ encodeFunctionData(functionFragment: "getPairFactors", values: [PromiseOrValue<BigNumberish>[]]): string;
993
1264
  encodeFunctionData(functionFragment: "getPriceImpactOi", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<boolean>]): string;
994
1265
  encodeFunctionData(functionFragment: "getTradePriceImpact", values: [
995
1266
  PromiseOrValue<BigNumberish>,
996
1267
  PromiseOrValue<BigNumberish>,
997
1268
  PromiseOrValue<boolean>,
998
- PromiseOrValue<BigNumberish>
999
- ]): string;
1000
- encodeFunctionData(functionFragment: "initializePriceImpact", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1001
- encodeFunctionData(functionFragment: "removePriceImpactOpenInterest", values: [
1002
- PromiseOrValue<BigNumberish>,
1003
1269
  PromiseOrValue<BigNumberish>,
1004
1270
  PromiseOrValue<boolean>,
1271
+ PromiseOrValue<boolean>,
1272
+ PromiseOrValue<BigNumberish>,
1005
1273
  PromiseOrValue<BigNumberish>
1006
1274
  ]): string;
1275
+ encodeFunctionData(functionFragment: "initializePairFactors", values: [
1276
+ PromiseOrValue<BigNumberish>[],
1277
+ PromiseOrValue<BigNumberish>[],
1278
+ PromiseOrValue<BigNumberish>[],
1279
+ PromiseOrValue<BigNumberish>[]
1280
+ ]): string;
1281
+ encodeFunctionData(functionFragment: "initializePriceImpact", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1282
+ encodeFunctionData(functionFragment: "setCumulativeFactors", values: [PromiseOrValue<BigNumberish>[], PromiseOrValue<BigNumberish>[]]): string;
1007
1283
  encodeFunctionData(functionFragment: "setPairDepths", values: [
1008
1284
  PromiseOrValue<BigNumberish>[],
1009
1285
  PromiseOrValue<BigNumberish>[],
@@ -1011,34 +1287,33 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1011
1287
  ]): string;
1012
1288
  encodeFunctionData(functionFragment: "setPriceImpactWindowsCount", values: [PromiseOrValue<BigNumberish>]): string;
1013
1289
  encodeFunctionData(functionFragment: "setPriceImpactWindowsDuration", values: [PromiseOrValue<BigNumberish>]): string;
1290
+ encodeFunctionData(functionFragment: "setProtectionCloseFactorBlocks", values: [PromiseOrValue<BigNumberish>[], PromiseOrValue<BigNumberish>[]]): string;
1291
+ encodeFunctionData(functionFragment: "setProtectionCloseFactors", values: [PromiseOrValue<BigNumberish>[], PromiseOrValue<BigNumberish>[]]): string;
1014
1292
  encodeFunctionData(functionFragment: "addCollateral", values: [PromiseOrValue<string>, PromiseOrValue<string>]): string;
1015
1293
  encodeFunctionData(functionFragment: "closePendingOrder", values: [ITradingStorage.IdStruct]): string;
1016
1294
  encodeFunctionData(functionFragment: "closeTrade", values: [ITradingStorage.IdStruct]): string;
1017
1295
  encodeFunctionData(functionFragment: "getAllPendingOrders", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1018
1296
  encodeFunctionData(functionFragment: "getAllTradeInfos", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1019
1297
  encodeFunctionData(functionFragment: "getAllTrades", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1298
+ encodeFunctionData(functionFragment: "getAllTradesLiquidationParams", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1020
1299
  encodeFunctionData(functionFragment: "getCollateral", values: [PromiseOrValue<BigNumberish>]): string;
1021
1300
  encodeFunctionData(functionFragment: "getCollateralIndex", values: [PromiseOrValue<string>]): string;
1022
1301
  encodeFunctionData(functionFragment: "getCollaterals", values?: undefined): string;
1023
1302
  encodeFunctionData(functionFragment: "getCollateralsCount", values?: undefined): string;
1024
1303
  encodeFunctionData(functionFragment: "getCounters", values: [PromiseOrValue<string>, PromiseOrValue<BigNumberish>]): string;
1304
+ encodeFunctionData(functionFragment: "getCurrentContractsVersion", values?: undefined): string;
1025
1305
  encodeFunctionData(functionFragment: "getGToken", values: [PromiseOrValue<BigNumberish>]): string;
1026
- encodeFunctionData(functionFragment: "getPendingOpenOrderType", values: [PromiseOrValue<BigNumberish>]): string;
1027
1306
  encodeFunctionData(functionFragment: "getPendingOrder", values: [ITradingStorage.IdStruct]): string;
1028
1307
  encodeFunctionData(functionFragment: "getPendingOrders", values: [PromiseOrValue<string>]): string;
1029
- encodeFunctionData(functionFragment: "getPnlPercent", values: [
1030
- PromiseOrValue<BigNumberish>,
1031
- PromiseOrValue<BigNumberish>,
1032
- PromiseOrValue<boolean>,
1033
- PromiseOrValue<BigNumberish>
1034
- ]): string;
1035
1308
  encodeFunctionData(functionFragment: "getTrade", values: [PromiseOrValue<string>, PromiseOrValue<BigNumberish>]): string;
1036
1309
  encodeFunctionData(functionFragment: "getTradeInfo", values: [PromiseOrValue<string>, PromiseOrValue<BigNumberish>]): string;
1037
1310
  encodeFunctionData(functionFragment: "getTradeInfos", values: [PromiseOrValue<string>]): string;
1311
+ encodeFunctionData(functionFragment: "getTradeLiquidationParams", values: [PromiseOrValue<string>, PromiseOrValue<BigNumberish>]): string;
1038
1312
  encodeFunctionData(functionFragment: "getTradePendingOrderBlock", values: [ITradingStorage.IdStruct, PromiseOrValue<BigNumberish>]): string;
1039
1313
  encodeFunctionData(functionFragment: "getTraderStored", values: [PromiseOrValue<string>]): string;
1040
1314
  encodeFunctionData(functionFragment: "getTraders", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1041
1315
  encodeFunctionData(functionFragment: "getTrades", values: [PromiseOrValue<string>]): string;
1316
+ encodeFunctionData(functionFragment: "getTradesLiquidationParams", values: [PromiseOrValue<string>]): string;
1042
1317
  encodeFunctionData(functionFragment: "getTradingActivated", values?: undefined): string;
1043
1318
  encodeFunctionData(functionFragment: "initializeTradingStorage", values: [
1044
1319
  PromiseOrValue<string>,
@@ -1060,6 +1335,14 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1060
1335
  PromiseOrValue<BigNumberish>
1061
1336
  ]): string;
1062
1337
  encodeFunctionData(functionFragment: "updateTradeCollateralAmount", values: [ITradingStorage.IdStruct, PromiseOrValue<BigNumberish>]): string;
1338
+ encodeFunctionData(functionFragment: "updateTradeMaxClosingSlippageP", values: [ITradingStorage.IdStruct, PromiseOrValue<BigNumberish>]): string;
1339
+ encodeFunctionData(functionFragment: "updateTradePosition", values: [
1340
+ ITradingStorage.IdStruct,
1341
+ PromiseOrValue<BigNumberish>,
1342
+ PromiseOrValue<BigNumberish>,
1343
+ PromiseOrValue<BigNumberish>,
1344
+ PromiseOrValue<boolean>
1345
+ ]): string;
1063
1346
  encodeFunctionData(functionFragment: "updateTradeSl", values: [ITradingStorage.IdStruct, PromiseOrValue<BigNumberish>]): string;
1064
1347
  encodeFunctionData(functionFragment: "updateTradeTp", values: [ITradingStorage.IdStruct, PromiseOrValue<BigNumberish>]): string;
1065
1348
  encodeFunctionData(functionFragment: "updateTradingActivated", values: [PromiseOrValue<BigNumberish>]): string;
@@ -1071,13 +1354,26 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1071
1354
  encodeFunctionData(functionFragment: "initializeTriggerRewards", values: [PromiseOrValue<BigNumberish>]): string;
1072
1355
  encodeFunctionData(functionFragment: "updateTriggerTimeoutBlocks", values: [PromiseOrValue<BigNumberish>]): string;
1073
1356
  encodeFunctionData(functionFragment: "cancelOpenOrder", values: [PromiseOrValue<BigNumberish>]): string;
1074
- encodeFunctionData(functionFragment: "closeTradeMarket", values: [PromiseOrValue<BigNumberish>]): string;
1075
- encodeFunctionData(functionFragment: "closeTradeMarketTimeout", values: [ITradingStorage.IdStruct]): string;
1357
+ encodeFunctionData(functionFragment: "cancelOrderAfterTimeout", values: [PromiseOrValue<BigNumberish>]): string;
1358
+ encodeFunctionData(functionFragment: "closeTradeMarket", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1359
+ encodeFunctionData(functionFragment: "decreasePositionSize", values: [
1360
+ PromiseOrValue<BigNumberish>,
1361
+ PromiseOrValue<BigNumberish>,
1362
+ PromiseOrValue<BigNumberish>,
1363
+ PromiseOrValue<BigNumberish>
1364
+ ]): string;
1076
1365
  encodeFunctionData(functionFragment: "delegatedTradingAction", values: [PromiseOrValue<string>, PromiseOrValue<BytesLike>]): string;
1077
1366
  encodeFunctionData(functionFragment: "getByPassTriggerLink", values: [PromiseOrValue<string>]): string;
1078
1367
  encodeFunctionData(functionFragment: "getMarketOrdersTimeoutBlocks", values?: undefined): string;
1079
1368
  encodeFunctionData(functionFragment: "getTradingDelegate", values: [PromiseOrValue<string>]): string;
1080
1369
  encodeFunctionData(functionFragment: "getWrappedNativeToken", values?: undefined): string;
1370
+ encodeFunctionData(functionFragment: "increasePositionSize", values: [
1371
+ PromiseOrValue<BigNumberish>,
1372
+ PromiseOrValue<BigNumberish>,
1373
+ PromiseOrValue<BigNumberish>,
1374
+ PromiseOrValue<BigNumberish>,
1375
+ PromiseOrValue<BigNumberish>
1376
+ ]): string;
1081
1377
  encodeFunctionData(functionFragment: "initializeTrading", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<string>[]]): string;
1082
1378
  encodeFunctionData(functionFragment: "isWrappedNativeToken", values: [PromiseOrValue<string>]): string;
1083
1379
  encodeFunctionData(functionFragment: "openTrade", values: [
@@ -1085,7 +1381,6 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1085
1381
  PromiseOrValue<BigNumberish>,
1086
1382
  PromiseOrValue<string>
1087
1383
  ]): string;
1088
- encodeFunctionData(functionFragment: "openTradeMarketTimeout", values: [ITradingStorage.IdStruct]): string;
1089
1384
  encodeFunctionData(functionFragment: "openTradeNative", values: [
1090
1385
  ITradingStorage.TradeStruct,
1091
1386
  PromiseOrValue<BigNumberish>,
@@ -1095,7 +1390,9 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1095
1390
  encodeFunctionData(functionFragment: "setTradingDelegate", values: [PromiseOrValue<string>]): string;
1096
1391
  encodeFunctionData(functionFragment: "triggerOrder", values: [PromiseOrValue<BigNumberish>]): string;
1097
1392
  encodeFunctionData(functionFragment: "updateByPassTriggerLink", values: [PromiseOrValue<string>[], PromiseOrValue<boolean>[]]): string;
1393
+ encodeFunctionData(functionFragment: "updateLeverage", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1098
1394
  encodeFunctionData(functionFragment: "updateMarketOrdersTimeoutBlocks", values: [PromiseOrValue<BigNumberish>]): string;
1395
+ encodeFunctionData(functionFragment: "updateMaxClosingSlippageP", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1099
1396
  encodeFunctionData(functionFragment: "updateOpenOrder", values: [
1100
1397
  PromiseOrValue<BigNumberish>,
1101
1398
  PromiseOrValue<BigNumberish>,
@@ -1107,13 +1404,30 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1107
1404
  encodeFunctionData(functionFragment: "updateTp", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1108
1405
  encodeFunctionData(functionFragment: "claimPendingGovFees", values?: undefined): string;
1109
1406
  encodeFunctionData(functionFragment: "closeTradeMarketCallback", values: [ITradingCallbacks.AggregatorAnswerStruct]): string;
1407
+ encodeFunctionData(functionFragment: "decreasePositionSizeMarketCallback", values: [ITradingCallbacks.AggregatorAnswerStruct]): string;
1110
1408
  encodeFunctionData(functionFragment: "executeTriggerCloseOrderCallback", values: [ITradingCallbacks.AggregatorAnswerStruct]): string;
1111
1409
  encodeFunctionData(functionFragment: "executeTriggerOpenOrderCallback", values: [ITradingCallbacks.AggregatorAnswerStruct]): string;
1112
1410
  encodeFunctionData(functionFragment: "getPendingGovFeesCollateral", values: [PromiseOrValue<BigNumberish>]): string;
1113
1411
  encodeFunctionData(functionFragment: "getVaultClosingFeeP", values?: undefined): string;
1412
+ encodeFunctionData(functionFragment: "increasePositionSizeMarketCallback", values: [ITradingCallbacks.AggregatorAnswerStruct]): string;
1114
1413
  encodeFunctionData(functionFragment: "initializeCallbacks", values: [PromiseOrValue<BigNumberish>]): string;
1115
1414
  encodeFunctionData(functionFragment: "openTradeMarketCallback", values: [ITradingCallbacks.AggregatorAnswerStruct]): string;
1415
+ encodeFunctionData(functionFragment: "updateLeverageCallback", values: [ITradingCallbacks.AggregatorAnswerStruct]): string;
1116
1416
  encodeFunctionData(functionFragment: "updateVaultClosingFeeP", values: [PromiseOrValue<BigNumberish>]): string;
1417
+ encodeFunctionData(functionFragment: "validateTriggerCloseOrderCallback", values: [
1418
+ ITradingStorage.IdStruct,
1419
+ PromiseOrValue<BigNumberish>,
1420
+ PromiseOrValue<BigNumberish>,
1421
+ PromiseOrValue<BigNumberish>,
1422
+ PromiseOrValue<BigNumberish>
1423
+ ]): string;
1424
+ encodeFunctionData(functionFragment: "validateTriggerOpenOrderCallback", values: [
1425
+ ITradingStorage.IdStruct,
1426
+ PromiseOrValue<BigNumberish>,
1427
+ PromiseOrValue<BigNumberish>,
1428
+ PromiseOrValue<BigNumberish>,
1429
+ PromiseOrValue<BigNumberish>
1430
+ ]): string;
1117
1431
  encodeFunctionData(functionFragment: "getAllBorrowingPairs", values: [PromiseOrValue<BigNumberish>]): string;
1118
1432
  encodeFunctionData(functionFragment: "getBorrowingGroup", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1119
1433
  encodeFunctionData(functionFragment: "getBorrowingGroupOi", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
@@ -1156,6 +1470,13 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1156
1470
  PromiseOrValue<boolean>,
1157
1471
  PromiseOrValue<boolean>
1158
1472
  ]): string;
1473
+ encodeFunctionData(functionFragment: "resetTradeBorrowingFees", values: [
1474
+ PromiseOrValue<BigNumberish>,
1475
+ PromiseOrValue<string>,
1476
+ PromiseOrValue<BigNumberish>,
1477
+ PromiseOrValue<BigNumberish>,
1478
+ PromiseOrValue<boolean>
1479
+ ]): string;
1159
1480
  encodeFunctionData(functionFragment: "setBorrowingGroupParams", values: [
1160
1481
  PromiseOrValue<BigNumberish>,
1161
1482
  PromiseOrValue<BigNumberish>,
@@ -1187,7 +1508,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1187
1508
  encodeFunctionData(functionFragment: "fulfill", values: [PromiseOrValue<BytesLike>, PromiseOrValue<BigNumberish>]): string;
1188
1509
  encodeFunctionData(functionFragment: "getChainlinkToken", values?: undefined): string;
1189
1510
  encodeFunctionData(functionFragment: "getCollateralFromUsdNormalizedValue", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1190
- encodeFunctionData(functionFragment: "getCollateralGnsUniV3Pool", values: [PromiseOrValue<BigNumberish>]): string;
1511
+ encodeFunctionData(functionFragment: "getCollateralGnsLiquidityPool", values: [PromiseOrValue<BigNumberish>]): string;
1191
1512
  encodeFunctionData(functionFragment: "getCollateralPriceUsd", values: [PromiseOrValue<BigNumberish>]): string;
1192
1513
  encodeFunctionData(functionFragment: "getCollateralUsdPriceFeed", values: [PromiseOrValue<BigNumberish>]): string;
1193
1514
  encodeFunctionData(functionFragment: "getGnsPriceCollateralAddress", values: [PromiseOrValue<string>]): string;
@@ -1196,6 +1517,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1196
1517
  encodeFunctionData(functionFragment: "getLimitJobId", values?: undefined): string;
1197
1518
  encodeFunctionData(functionFragment: "getLinkFee", values: [
1198
1519
  PromiseOrValue<BigNumberish>,
1520
+ PromiseOrValue<string>,
1199
1521
  PromiseOrValue<BigNumberish>,
1200
1522
  PromiseOrValue<BigNumberish>
1201
1523
  ]): string;
@@ -1209,6 +1531,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1209
1531
  PromiseOrValue<BigNumberish>,
1210
1532
  PromiseOrValue<BigNumberish>,
1211
1533
  ITradingStorage.IdStruct,
1534
+ ITradingStorage.IdStruct,
1212
1535
  PromiseOrValue<BigNumberish>,
1213
1536
  PromiseOrValue<BigNumberish>,
1214
1537
  PromiseOrValue<BigNumberish>
@@ -1229,29 +1552,28 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1229
1552
  PromiseOrValue<BytesLike>
1230
1553
  ],
1231
1554
  PromiseOrValue<BigNumberish>[],
1232
- PromiseOrValue<string>[],
1555
+ IPriceAggregator.LiquidityPoolInputStruct[],
1233
1556
  PromiseOrValue<string>[]
1234
1557
  ]): string;
1235
1558
  encodeFunctionData(functionFragment: "removeOracle", values: [PromiseOrValue<BigNumberish>]): string;
1236
1559
  encodeFunctionData(functionFragment: "replaceOracle", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<string>]): string;
1237
1560
  encodeFunctionData(functionFragment: "setLimitJobId", values: [PromiseOrValue<BytesLike>]): string;
1238
1561
  encodeFunctionData(functionFragment: "setMarketJobId", values: [PromiseOrValue<BytesLike>]): string;
1239
- encodeFunctionData(functionFragment: "updateCollateralGnsUniV3Pool", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<string>]): string;
1562
+ encodeFunctionData(functionFragment: "updateCollateralGnsLiquidityPool", values: [
1563
+ PromiseOrValue<BigNumberish>,
1564
+ IPriceAggregator.LiquidityPoolInputStruct
1565
+ ]): string;
1240
1566
  encodeFunctionData(functionFragment: "updateCollateralUsdPriceFeed", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<string>]): string;
1241
1567
  encodeFunctionData(functionFragment: "updateLinkUsdPriceFeed", values: [PromiseOrValue<string>]): string;
1242
1568
  encodeFunctionData(functionFragment: "updateMinAnswers", values: [PromiseOrValue<BigNumberish>]): string;
1243
1569
  encodeFunctionData(functionFragment: "updateTwapInterval", values: [PromiseOrValue<BigNumberish>]): string;
1244
- encodeFunctionData(functionFragment: "copyAllState", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<string>[]]): string;
1245
- encodeFunctionData(functionFragment: "copyBorrowingFeesGroups", values: [PromiseOrValue<BigNumberish>]): string;
1246
- encodeFunctionData(functionFragment: "copyBorrowingFeesPairs", values: [PromiseOrValue<BigNumberish>]): string;
1247
- encodeFunctionData(functionFragment: "copyLimits", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1248
- encodeFunctionData(functionFragment: "copyPairOis", values: [PromiseOrValue<BigNumberish>]): string;
1249
- encodeFunctionData(functionFragment: "copyTraderDelegations", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<string>[]]): string;
1250
- encodeFunctionData(functionFragment: "copyTrades", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1251
- encodeFunctionData(functionFragment: "getCollateralStageState", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1252
- encodeFunctionData(functionFragment: "getCollateralState", values: [PromiseOrValue<BigNumberish>]): string;
1253
- encodeFunctionData(functionFragment: "markAsDone", values: [PromiseOrValue<BigNumberish>]): string;
1254
- encodeFunctionData(functionFragment: "transferBalance", values: [PromiseOrValue<BigNumberish>]): string;
1570
+ encodeFunctionData(functionFragment: "addOtcCollateralBalance", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1571
+ encodeFunctionData(functionFragment: "getOtcBalance", values: [PromiseOrValue<BigNumberish>]): string;
1572
+ encodeFunctionData(functionFragment: "getOtcConfig", values?: undefined): string;
1573
+ encodeFunctionData(functionFragment: "getOtcRate", values: [PromiseOrValue<BigNumberish>]): string;
1574
+ encodeFunctionData(functionFragment: "initializeOtc", values: [IOtc.OtcConfigStruct]): string;
1575
+ encodeFunctionData(functionFragment: "sellGnsForCollateral", values: [PromiseOrValue<BigNumberish>, PromiseOrValue<BigNumberish>]): string;
1576
+ encodeFunctionData(functionFragment: "updateOtcConfig", values: [IOtc.OtcConfigStruct]): string;
1255
1577
  decodeFunctionResult(functionFragment: "diamondCut", data: BytesLike): Result;
1256
1578
  decodeFunctionResult(functionFragment: "facetAddress", data: BytesLike): Result;
1257
1579
  decodeFunctionResult(functionFragment: "facetAddresses", data: BytesLike): Result;
@@ -1267,14 +1589,18 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1267
1589
  decodeFunctionResult(functionFragment: "fees", data: BytesLike): Result;
1268
1590
  decodeFunctionResult(functionFragment: "feesCount", data: BytesLike): Result;
1269
1591
  decodeFunctionResult(functionFragment: "getAllPairsRestrictedMaxLeverage", data: BytesLike): Result;
1592
+ decodeFunctionResult(functionFragment: "getGroupLiquidationParams", data: BytesLike): Result;
1593
+ decodeFunctionResult(functionFragment: "getPairLiquidationParams", data: BytesLike): Result;
1270
1594
  decodeFunctionResult(functionFragment: "groups", data: BytesLike): Result;
1271
1595
  decodeFunctionResult(functionFragment: "groupsCount", data: BytesLike): Result;
1596
+ decodeFunctionResult(functionFragment: "initializeGroupLiquidationParams", data: BytesLike): Result;
1272
1597
  decodeFunctionResult(functionFragment: "isPairIndexListed", data: BytesLike): Result;
1273
1598
  decodeFunctionResult(functionFragment: "isPairListed", data: BytesLike): Result;
1274
1599
  decodeFunctionResult(functionFragment: "pairCloseFeeP", data: BytesLike): Result;
1275
1600
  decodeFunctionResult(functionFragment: "pairCustomMaxLeverage", data: BytesLike): Result;
1276
1601
  decodeFunctionResult(functionFragment: "pairJob", data: BytesLike): Result;
1277
1602
  decodeFunctionResult(functionFragment: "pairMaxLeverage", data: BytesLike): Result;
1603
+ decodeFunctionResult(functionFragment: "pairMinFeeUsd", data: BytesLike): Result;
1278
1604
  decodeFunctionResult(functionFragment: "pairMinLeverage", data: BytesLike): Result;
1279
1605
  decodeFunctionResult(functionFragment: "pairMinPositionSizeUsd", data: BytesLike): Result;
1280
1606
  decodeFunctionResult(functionFragment: "pairOpenFeeP", data: BytesLike): Result;
@@ -1284,6 +1610,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1284
1610
  decodeFunctionResult(functionFragment: "pairs", data: BytesLike): Result;
1285
1611
  decodeFunctionResult(functionFragment: "pairsBackend", data: BytesLike): Result;
1286
1612
  decodeFunctionResult(functionFragment: "pairsCount", data: BytesLike): Result;
1613
+ decodeFunctionResult(functionFragment: "setGroupLiquidationParams", data: BytesLike): Result;
1287
1614
  decodeFunctionResult(functionFragment: "setPairCustomMaxLeverages", data: BytesLike): Result;
1288
1615
  decodeFunctionResult(functionFragment: "updateFees", data: BytesLike): Result;
1289
1616
  decodeFunctionResult(functionFragment: "updateGroups", data: BytesLike): Result;
@@ -1328,36 +1655,42 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1328
1655
  decodeFunctionResult(functionFragment: "getOiWindowsSettings", data: BytesLike): Result;
1329
1656
  decodeFunctionResult(functionFragment: "getPairDepth", data: BytesLike): Result;
1330
1657
  decodeFunctionResult(functionFragment: "getPairDepths", data: BytesLike): Result;
1658
+ decodeFunctionResult(functionFragment: "getPairFactors", data: BytesLike): Result;
1331
1659
  decodeFunctionResult(functionFragment: "getPriceImpactOi", data: BytesLike): Result;
1332
1660
  decodeFunctionResult(functionFragment: "getTradePriceImpact", data: BytesLike): Result;
1661
+ decodeFunctionResult(functionFragment: "initializePairFactors", data: BytesLike): Result;
1333
1662
  decodeFunctionResult(functionFragment: "initializePriceImpact", data: BytesLike): Result;
1334
- decodeFunctionResult(functionFragment: "removePriceImpactOpenInterest", data: BytesLike): Result;
1663
+ decodeFunctionResult(functionFragment: "setCumulativeFactors", data: BytesLike): Result;
1335
1664
  decodeFunctionResult(functionFragment: "setPairDepths", data: BytesLike): Result;
1336
1665
  decodeFunctionResult(functionFragment: "setPriceImpactWindowsCount", data: BytesLike): Result;
1337
1666
  decodeFunctionResult(functionFragment: "setPriceImpactWindowsDuration", data: BytesLike): Result;
1667
+ decodeFunctionResult(functionFragment: "setProtectionCloseFactorBlocks", data: BytesLike): Result;
1668
+ decodeFunctionResult(functionFragment: "setProtectionCloseFactors", data: BytesLike): Result;
1338
1669
  decodeFunctionResult(functionFragment: "addCollateral", data: BytesLike): Result;
1339
1670
  decodeFunctionResult(functionFragment: "closePendingOrder", data: BytesLike): Result;
1340
1671
  decodeFunctionResult(functionFragment: "closeTrade", data: BytesLike): Result;
1341
1672
  decodeFunctionResult(functionFragment: "getAllPendingOrders", data: BytesLike): Result;
1342
1673
  decodeFunctionResult(functionFragment: "getAllTradeInfos", data: BytesLike): Result;
1343
1674
  decodeFunctionResult(functionFragment: "getAllTrades", data: BytesLike): Result;
1675
+ decodeFunctionResult(functionFragment: "getAllTradesLiquidationParams", data: BytesLike): Result;
1344
1676
  decodeFunctionResult(functionFragment: "getCollateral", data: BytesLike): Result;
1345
1677
  decodeFunctionResult(functionFragment: "getCollateralIndex", data: BytesLike): Result;
1346
1678
  decodeFunctionResult(functionFragment: "getCollaterals", data: BytesLike): Result;
1347
1679
  decodeFunctionResult(functionFragment: "getCollateralsCount", data: BytesLike): Result;
1348
1680
  decodeFunctionResult(functionFragment: "getCounters", data: BytesLike): Result;
1681
+ decodeFunctionResult(functionFragment: "getCurrentContractsVersion", data: BytesLike): Result;
1349
1682
  decodeFunctionResult(functionFragment: "getGToken", data: BytesLike): Result;
1350
- decodeFunctionResult(functionFragment: "getPendingOpenOrderType", data: BytesLike): Result;
1351
1683
  decodeFunctionResult(functionFragment: "getPendingOrder", data: BytesLike): Result;
1352
1684
  decodeFunctionResult(functionFragment: "getPendingOrders", data: BytesLike): Result;
1353
- decodeFunctionResult(functionFragment: "getPnlPercent", data: BytesLike): Result;
1354
1685
  decodeFunctionResult(functionFragment: "getTrade", data: BytesLike): Result;
1355
1686
  decodeFunctionResult(functionFragment: "getTradeInfo", data: BytesLike): Result;
1356
1687
  decodeFunctionResult(functionFragment: "getTradeInfos", data: BytesLike): Result;
1688
+ decodeFunctionResult(functionFragment: "getTradeLiquidationParams", data: BytesLike): Result;
1357
1689
  decodeFunctionResult(functionFragment: "getTradePendingOrderBlock", data: BytesLike): Result;
1358
1690
  decodeFunctionResult(functionFragment: "getTraderStored", data: BytesLike): Result;
1359
1691
  decodeFunctionResult(functionFragment: "getTraders", data: BytesLike): Result;
1360
1692
  decodeFunctionResult(functionFragment: "getTrades", data: BytesLike): Result;
1693
+ decodeFunctionResult(functionFragment: "getTradesLiquidationParams", data: BytesLike): Result;
1361
1694
  decodeFunctionResult(functionFragment: "getTradingActivated", data: BytesLike): Result;
1362
1695
  decodeFunctionResult(functionFragment: "initializeTradingStorage", data: BytesLike): Result;
1363
1696
  decodeFunctionResult(functionFragment: "isCollateralActive", data: BytesLike): Result;
@@ -1368,6 +1701,8 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1368
1701
  decodeFunctionResult(functionFragment: "updateGToken", data: BytesLike): Result;
1369
1702
  decodeFunctionResult(functionFragment: "updateOpenOrderDetails", data: BytesLike): Result;
1370
1703
  decodeFunctionResult(functionFragment: "updateTradeCollateralAmount", data: BytesLike): Result;
1704
+ decodeFunctionResult(functionFragment: "updateTradeMaxClosingSlippageP", data: BytesLike): Result;
1705
+ decodeFunctionResult(functionFragment: "updateTradePosition", data: BytesLike): Result;
1371
1706
  decodeFunctionResult(functionFragment: "updateTradeSl", data: BytesLike): Result;
1372
1707
  decodeFunctionResult(functionFragment: "updateTradeTp", data: BytesLike): Result;
1373
1708
  decodeFunctionResult(functionFragment: "updateTradingActivated", data: BytesLike): Result;
@@ -1379,35 +1714,43 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1379
1714
  decodeFunctionResult(functionFragment: "initializeTriggerRewards", data: BytesLike): Result;
1380
1715
  decodeFunctionResult(functionFragment: "updateTriggerTimeoutBlocks", data: BytesLike): Result;
1381
1716
  decodeFunctionResult(functionFragment: "cancelOpenOrder", data: BytesLike): Result;
1717
+ decodeFunctionResult(functionFragment: "cancelOrderAfterTimeout", data: BytesLike): Result;
1382
1718
  decodeFunctionResult(functionFragment: "closeTradeMarket", data: BytesLike): Result;
1383
- decodeFunctionResult(functionFragment: "closeTradeMarketTimeout", data: BytesLike): Result;
1719
+ decodeFunctionResult(functionFragment: "decreasePositionSize", data: BytesLike): Result;
1384
1720
  decodeFunctionResult(functionFragment: "delegatedTradingAction", data: BytesLike): Result;
1385
1721
  decodeFunctionResult(functionFragment: "getByPassTriggerLink", data: BytesLike): Result;
1386
1722
  decodeFunctionResult(functionFragment: "getMarketOrdersTimeoutBlocks", data: BytesLike): Result;
1387
1723
  decodeFunctionResult(functionFragment: "getTradingDelegate", data: BytesLike): Result;
1388
1724
  decodeFunctionResult(functionFragment: "getWrappedNativeToken", data: BytesLike): Result;
1725
+ decodeFunctionResult(functionFragment: "increasePositionSize", data: BytesLike): Result;
1389
1726
  decodeFunctionResult(functionFragment: "initializeTrading", data: BytesLike): Result;
1390
1727
  decodeFunctionResult(functionFragment: "isWrappedNativeToken", data: BytesLike): Result;
1391
1728
  decodeFunctionResult(functionFragment: "openTrade", data: BytesLike): Result;
1392
- decodeFunctionResult(functionFragment: "openTradeMarketTimeout", data: BytesLike): Result;
1393
1729
  decodeFunctionResult(functionFragment: "openTradeNative", data: BytesLike): Result;
1394
1730
  decodeFunctionResult(functionFragment: "removeTradingDelegate", data: BytesLike): Result;
1395
1731
  decodeFunctionResult(functionFragment: "setTradingDelegate", data: BytesLike): Result;
1396
1732
  decodeFunctionResult(functionFragment: "triggerOrder", data: BytesLike): Result;
1397
1733
  decodeFunctionResult(functionFragment: "updateByPassTriggerLink", data: BytesLike): Result;
1734
+ decodeFunctionResult(functionFragment: "updateLeverage", data: BytesLike): Result;
1398
1735
  decodeFunctionResult(functionFragment: "updateMarketOrdersTimeoutBlocks", data: BytesLike): Result;
1736
+ decodeFunctionResult(functionFragment: "updateMaxClosingSlippageP", data: BytesLike): Result;
1399
1737
  decodeFunctionResult(functionFragment: "updateOpenOrder", data: BytesLike): Result;
1400
1738
  decodeFunctionResult(functionFragment: "updateSl", data: BytesLike): Result;
1401
1739
  decodeFunctionResult(functionFragment: "updateTp", data: BytesLike): Result;
1402
1740
  decodeFunctionResult(functionFragment: "claimPendingGovFees", data: BytesLike): Result;
1403
1741
  decodeFunctionResult(functionFragment: "closeTradeMarketCallback", data: BytesLike): Result;
1742
+ decodeFunctionResult(functionFragment: "decreasePositionSizeMarketCallback", data: BytesLike): Result;
1404
1743
  decodeFunctionResult(functionFragment: "executeTriggerCloseOrderCallback", data: BytesLike): Result;
1405
1744
  decodeFunctionResult(functionFragment: "executeTriggerOpenOrderCallback", data: BytesLike): Result;
1406
1745
  decodeFunctionResult(functionFragment: "getPendingGovFeesCollateral", data: BytesLike): Result;
1407
1746
  decodeFunctionResult(functionFragment: "getVaultClosingFeeP", data: BytesLike): Result;
1747
+ decodeFunctionResult(functionFragment: "increasePositionSizeMarketCallback", data: BytesLike): Result;
1408
1748
  decodeFunctionResult(functionFragment: "initializeCallbacks", data: BytesLike): Result;
1409
1749
  decodeFunctionResult(functionFragment: "openTradeMarketCallback", data: BytesLike): Result;
1750
+ decodeFunctionResult(functionFragment: "updateLeverageCallback", data: BytesLike): Result;
1410
1751
  decodeFunctionResult(functionFragment: "updateVaultClosingFeeP", data: BytesLike): Result;
1752
+ decodeFunctionResult(functionFragment: "validateTriggerCloseOrderCallback", data: BytesLike): Result;
1753
+ decodeFunctionResult(functionFragment: "validateTriggerOpenOrderCallback", data: BytesLike): Result;
1411
1754
  decodeFunctionResult(functionFragment: "getAllBorrowingPairs", data: BytesLike): Result;
1412
1755
  decodeFunctionResult(functionFragment: "getBorrowingGroup", data: BytesLike): Result;
1413
1756
  decodeFunctionResult(functionFragment: "getBorrowingGroupOi", data: BytesLike): Result;
@@ -1426,6 +1769,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1426
1769
  decodeFunctionResult(functionFragment: "getTradeBorrowingFee", data: BytesLike): Result;
1427
1770
  decodeFunctionResult(functionFragment: "getTradeLiquidationPrice", data: BytesLike): Result;
1428
1771
  decodeFunctionResult(functionFragment: "handleTradeBorrowingCallback", data: BytesLike): Result;
1772
+ decodeFunctionResult(functionFragment: "resetTradeBorrowingFees", data: BytesLike): Result;
1429
1773
  decodeFunctionResult(functionFragment: "setBorrowingGroupParams", data: BytesLike): Result;
1430
1774
  decodeFunctionResult(functionFragment: "setBorrowingGroupParamsArray", data: BytesLike): Result;
1431
1775
  decodeFunctionResult(functionFragment: "setBorrowingPairParams", data: BytesLike): Result;
@@ -1436,7 +1780,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1436
1780
  decodeFunctionResult(functionFragment: "fulfill", data: BytesLike): Result;
1437
1781
  decodeFunctionResult(functionFragment: "getChainlinkToken", data: BytesLike): Result;
1438
1782
  decodeFunctionResult(functionFragment: "getCollateralFromUsdNormalizedValue", data: BytesLike): Result;
1439
- decodeFunctionResult(functionFragment: "getCollateralGnsUniV3Pool", data: BytesLike): Result;
1783
+ decodeFunctionResult(functionFragment: "getCollateralGnsLiquidityPool", data: BytesLike): Result;
1440
1784
  decodeFunctionResult(functionFragment: "getCollateralPriceUsd", data: BytesLike): Result;
1441
1785
  decodeFunctionResult(functionFragment: "getCollateralUsdPriceFeed", data: BytesLike): Result;
1442
1786
  decodeFunctionResult(functionFragment: "getGnsPriceCollateralAddress", data: BytesLike): Result;
@@ -1461,22 +1805,18 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1461
1805
  decodeFunctionResult(functionFragment: "replaceOracle", data: BytesLike): Result;
1462
1806
  decodeFunctionResult(functionFragment: "setLimitJobId", data: BytesLike): Result;
1463
1807
  decodeFunctionResult(functionFragment: "setMarketJobId", data: BytesLike): Result;
1464
- decodeFunctionResult(functionFragment: "updateCollateralGnsUniV3Pool", data: BytesLike): Result;
1808
+ decodeFunctionResult(functionFragment: "updateCollateralGnsLiquidityPool", data: BytesLike): Result;
1465
1809
  decodeFunctionResult(functionFragment: "updateCollateralUsdPriceFeed", data: BytesLike): Result;
1466
1810
  decodeFunctionResult(functionFragment: "updateLinkUsdPriceFeed", data: BytesLike): Result;
1467
1811
  decodeFunctionResult(functionFragment: "updateMinAnswers", data: BytesLike): Result;
1468
1812
  decodeFunctionResult(functionFragment: "updateTwapInterval", data: BytesLike): Result;
1469
- decodeFunctionResult(functionFragment: "copyAllState", data: BytesLike): Result;
1470
- decodeFunctionResult(functionFragment: "copyBorrowingFeesGroups", data: BytesLike): Result;
1471
- decodeFunctionResult(functionFragment: "copyBorrowingFeesPairs", data: BytesLike): Result;
1472
- decodeFunctionResult(functionFragment: "copyLimits", data: BytesLike): Result;
1473
- decodeFunctionResult(functionFragment: "copyPairOis", data: BytesLike): Result;
1474
- decodeFunctionResult(functionFragment: "copyTraderDelegations", data: BytesLike): Result;
1475
- decodeFunctionResult(functionFragment: "copyTrades", data: BytesLike): Result;
1476
- decodeFunctionResult(functionFragment: "getCollateralStageState", data: BytesLike): Result;
1477
- decodeFunctionResult(functionFragment: "getCollateralState", data: BytesLike): Result;
1478
- decodeFunctionResult(functionFragment: "markAsDone", data: BytesLike): Result;
1479
- decodeFunctionResult(functionFragment: "transferBalance", data: BytesLike): Result;
1813
+ decodeFunctionResult(functionFragment: "addOtcCollateralBalance", data: BytesLike): Result;
1814
+ decodeFunctionResult(functionFragment: "getOtcBalance", data: BytesLike): Result;
1815
+ decodeFunctionResult(functionFragment: "getOtcConfig", data: BytesLike): Result;
1816
+ decodeFunctionResult(functionFragment: "getOtcRate", data: BytesLike): Result;
1817
+ decodeFunctionResult(functionFragment: "initializeOtc", data: BytesLike): Result;
1818
+ decodeFunctionResult(functionFragment: "sellGnsForCollateral", data: BytesLike): Result;
1819
+ decodeFunctionResult(functionFragment: "updateOtcConfig", data: BytesLike): Result;
1480
1820
  events: {
1481
1821
  "AccessControlUpdated(address,uint8,bool)": EventFragment;
1482
1822
  "AddressesUpdated(tuple)": EventFragment;
@@ -1485,6 +1825,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1485
1825
  "FeeAdded(uint256,string)": EventFragment;
1486
1826
  "FeeUpdated(uint256)": EventFragment;
1487
1827
  "GroupAdded(uint256,string)": EventFragment;
1828
+ "GroupLiquidationParamsUpdated(uint256,tuple)": EventFragment;
1488
1829
  "GroupUpdated(uint256)": EventFragment;
1489
1830
  "PairAdded(uint256,string,string)": EventFragment;
1490
1831
  "PairCustomMaxLeverageUpdated(uint256,uint256)": EventFragment;
@@ -1509,14 +1850,16 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1509
1850
  "TraderInfoFirstUpdate(address,uint32)": EventFragment;
1510
1851
  "TraderInfoUpdated(address,tuple)": EventFragment;
1511
1852
  "TraderTrailingPointsExpired(address,uint32,uint32,uint224)": EventFragment;
1853
+ "CumulativeFactorUpdated(uint256,uint40)": EventFragment;
1512
1854
  "OiWindowsSettingsInitialized(uint48,uint48)": EventFragment;
1513
1855
  "OnePercentDepthUpdated(uint256,uint128,uint128)": EventFragment;
1514
1856
  "PriceImpactOiTransferredPair(uint256,tuple)": EventFragment;
1515
1857
  "PriceImpactOiTransferredPairs(uint256,uint256,uint256,uint256)": EventFragment;
1516
1858
  "PriceImpactOpenInterestAdded(tuple)": EventFragment;
1517
- "PriceImpactOpenInterestRemoved(tuple,bool)": EventFragment;
1518
1859
  "PriceImpactWindowsCountUpdated(uint48)": EventFragment;
1519
1860
  "PriceImpactWindowsDurationUpdated(uint48)": EventFragment;
1861
+ "ProtectionCloseFactorBlocksUpdated(uint256,uint32)": EventFragment;
1862
+ "ProtectionCloseFactorUpdated(uint256,uint40)": EventFragment;
1520
1863
  "CollateralAdded(address,uint8,address)": EventFragment;
1521
1864
  "CollateralDisabled(uint8)": EventFragment;
1522
1865
  "CollateralUpdated(uint8,bool)": EventFragment;
@@ -1526,8 +1869,10 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1526
1869
  "PendingOrderStored(tuple)": EventFragment;
1527
1870
  "TradeClosed(tuple)": EventFragment;
1528
1871
  "TradeCollateralUpdated(tuple,uint120)": EventFragment;
1872
+ "TradeMaxClosingSlippagePUpdated(tuple,uint16)": EventFragment;
1873
+ "TradePositionUpdated(tuple,uint120,uint24,uint64,uint64,uint64,bool)": EventFragment;
1529
1874
  "TradeSlUpdated(tuple,uint64)": EventFragment;
1530
- "TradeStored(tuple,tuple)": EventFragment;
1875
+ "TradeStored(tuple,tuple,tuple)": EventFragment;
1531
1876
  "TradeTpUpdated(tuple,uint64)": EventFragment;
1532
1877
  "TradingActivatedUpdated(uint8)": EventFragment;
1533
1878
  "TriggerRewarded(uint256,uint256)": EventFragment;
@@ -1536,12 +1881,17 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1536
1881
  "ByPassTriggerLinkUpdated(address,bool)": EventFragment;
1537
1882
  "ChainlinkCallbackTimeout(tuple,uint256)": EventFragment;
1538
1883
  "CouldNotCloseTrade(address,uint16,uint32)": EventFragment;
1884
+ "LeverageUpdateExecuted(tuple,bool,uint8,uint8,address,uint256,uint256,uint256,uint256,tuple)": EventFragment;
1885
+ "LeverageUpdateInitiated(tuple,address,uint256,uint256,bool,uint256)": EventFragment;
1539
1886
  "MarketOrderInitiated(tuple,address,uint16,bool)": EventFragment;
1540
1887
  "MarketOrdersTimeoutBlocksUpdated(uint256)": EventFragment;
1541
1888
  "NativeTokenWrapped(address,uint256)": EventFragment;
1542
1889
  "OpenLimitCanceled(address,uint16,uint32)": EventFragment;
1543
1890
  "OpenLimitUpdated(address,uint16,uint32,uint64,uint64,uint64,uint64)": EventFragment;
1544
1891
  "OpenOrderPlaced(address,uint16,uint32)": EventFragment;
1892
+ "PositionSizeDecreaseExecuted(tuple,uint8,uint8,address,uint256,uint256,bool,uint256,uint256,uint256,uint256,tuple)": EventFragment;
1893
+ "PositionSizeIncreaseExecuted(tuple,uint8,uint8,address,uint256,uint256,bool,uint256,uint256,uint256,uint256,tuple)": EventFragment;
1894
+ "PositionSizeUpdateInitiated(tuple,address,uint256,uint256,bool,uint256,uint256)": EventFragment;
1545
1895
  "TriggerOrderInitiated(tuple,address,uint16,bool)": EventFragment;
1546
1896
  "BorrowingFeeCharged(address,uint8,uint256)": EventFragment;
1547
1897
  "GTokenFeeCharged(address,uint8,uint256)": EventFragment;
@@ -1559,15 +1909,13 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1559
1909
  "BorrowingGroupAccFeesUpdated(uint8,uint16,uint256,uint64,uint64)": EventFragment;
1560
1910
  "BorrowingGroupOiUpdated(uint8,uint16,bool,bool,uint72,uint72,uint72)": EventFragment;
1561
1911
  "BorrowingGroupUpdated(uint8,uint16,uint32,uint72,uint48)": EventFragment;
1562
- "BorrowingInitialAccFeesStored(uint8,address,uint16,uint32,uint64,uint64)": EventFragment;
1912
+ "BorrowingInitialAccFeesStored(uint8,address,uint16,uint32,bool,uint64,uint64)": EventFragment;
1563
1913
  "BorrowingPairAccFeesUpdated(uint8,uint16,uint256,uint64,uint64)": EventFragment;
1564
1914
  "BorrowingPairGroupUpdated(uint8,uint16,uint16,uint16)": EventFragment;
1565
1915
  "BorrowingPairOiUpdated(uint8,uint16,bool,bool,uint72,uint72,uint72)": EventFragment;
1566
1916
  "BorrowingPairParamsUpdated(uint8,uint16,uint16,uint32,uint48,uint72)": EventFragment;
1567
1917
  "TradeBorrowingCallbackHandled(uint8,address,uint16,uint32,bool,bool,uint256)": EventFragment;
1568
- "ChainlinkFulfilled(bytes32)": EventFragment;
1569
- "ChainlinkRequested(bytes32)": EventFragment;
1570
- "CollateralGnsUniV3PoolUpdated(uint8,tuple)": EventFragment;
1918
+ "CollateralGnsLiquidityPoolUpdated(uint8,tuple)": EventFragment;
1571
1919
  "CollateralUsdPriceFeedUpdated(uint8,address)": EventFragment;
1572
1920
  "JobIdUpdated(uint256,bytes32)": EventFragment;
1573
1921
  "LinkClaimedBack(uint256)": EventFragment;
@@ -1578,20 +1926,12 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1578
1926
  "OracleRemoved(uint256,address)": EventFragment;
1579
1927
  "OracleReplaced(uint256,address,address)": EventFragment;
1580
1928
  "PriceReceived(tuple,uint16,bytes32,uint256,bool,bool)": EventFragment;
1581
- "PriceRequested(uint8,tuple,uint8,uint256,bytes32,uint256,uint256,uint256,bool)": EventFragment;
1929
+ "PriceRequested(uint8,uint256,tuple,tuple,uint8,uint256,bool,bytes32,uint256,uint256)": EventFragment;
1582
1930
  "TradingCallbackExecuted(tuple,uint8)": EventFragment;
1583
1931
  "TwapIntervalUpdated(uint32)": EventFragment;
1584
- "BorrowingFeesGroupsCopied(uint8,uint16)": EventFragment;
1585
- "BorrowingFeesPairOisCopied(uint8,uint256)": EventFragment;
1586
- "BorrowingFeesPairsCopied(uint8,uint256)": EventFragment;
1587
- "CollateralTransferred(uint8,uint256,uint256)": EventFragment;
1588
- "LegacyLimitOrderSkipped(uint8,address,uint256,uint256)": EventFragment;
1589
- "LimitsCopied(uint8,uint256,uint256)": EventFragment;
1590
- "MarkedAsDone(uint8)": EventFragment;
1591
- "PairTradesCopied(uint8,uint256,uint256)": EventFragment;
1592
- "TradeCopied(uint8,address,uint256,uint256,uint256)": EventFragment;
1593
- "TraderDelegationsCopied(uint8,uint256)": EventFragment;
1594
- "TradesCopied(uint8,uint16,uint16)": EventFragment;
1932
+ "OtcBalanceUpdated(uint8,uint256)": EventFragment;
1933
+ "OtcConfigUpdated(tuple)": EventFragment;
1934
+ "OtcExecuted(uint8,uint256,uint256,uint256,uint256,uint256)": EventFragment;
1595
1935
  };
1596
1936
  getEvent(nameOrSignatureOrTopic: "AccessControlUpdated"): EventFragment;
1597
1937
  getEvent(nameOrSignatureOrTopic: "AddressesUpdated"): EventFragment;
@@ -1600,6 +1940,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1600
1940
  getEvent(nameOrSignatureOrTopic: "FeeAdded"): EventFragment;
1601
1941
  getEvent(nameOrSignatureOrTopic: "FeeUpdated"): EventFragment;
1602
1942
  getEvent(nameOrSignatureOrTopic: "GroupAdded"): EventFragment;
1943
+ getEvent(nameOrSignatureOrTopic: "GroupLiquidationParamsUpdated"): EventFragment;
1603
1944
  getEvent(nameOrSignatureOrTopic: "GroupUpdated"): EventFragment;
1604
1945
  getEvent(nameOrSignatureOrTopic: "PairAdded"): EventFragment;
1605
1946
  getEvent(nameOrSignatureOrTopic: "PairCustomMaxLeverageUpdated"): EventFragment;
@@ -1624,14 +1965,16 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1624
1965
  getEvent(nameOrSignatureOrTopic: "TraderInfoFirstUpdate"): EventFragment;
1625
1966
  getEvent(nameOrSignatureOrTopic: "TraderInfoUpdated"): EventFragment;
1626
1967
  getEvent(nameOrSignatureOrTopic: "TraderTrailingPointsExpired"): EventFragment;
1968
+ getEvent(nameOrSignatureOrTopic: "CumulativeFactorUpdated"): EventFragment;
1627
1969
  getEvent(nameOrSignatureOrTopic: "OiWindowsSettingsInitialized"): EventFragment;
1628
1970
  getEvent(nameOrSignatureOrTopic: "OnePercentDepthUpdated"): EventFragment;
1629
1971
  getEvent(nameOrSignatureOrTopic: "PriceImpactOiTransferredPair"): EventFragment;
1630
1972
  getEvent(nameOrSignatureOrTopic: "PriceImpactOiTransferredPairs"): EventFragment;
1631
1973
  getEvent(nameOrSignatureOrTopic: "PriceImpactOpenInterestAdded"): EventFragment;
1632
- getEvent(nameOrSignatureOrTopic: "PriceImpactOpenInterestRemoved"): EventFragment;
1633
1974
  getEvent(nameOrSignatureOrTopic: "PriceImpactWindowsCountUpdated"): EventFragment;
1634
1975
  getEvent(nameOrSignatureOrTopic: "PriceImpactWindowsDurationUpdated"): EventFragment;
1976
+ getEvent(nameOrSignatureOrTopic: "ProtectionCloseFactorBlocksUpdated"): EventFragment;
1977
+ getEvent(nameOrSignatureOrTopic: "ProtectionCloseFactorUpdated"): EventFragment;
1635
1978
  getEvent(nameOrSignatureOrTopic: "CollateralAdded"): EventFragment;
1636
1979
  getEvent(nameOrSignatureOrTopic: "CollateralDisabled"): EventFragment;
1637
1980
  getEvent(nameOrSignatureOrTopic: "CollateralUpdated"): EventFragment;
@@ -1641,6 +1984,8 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1641
1984
  getEvent(nameOrSignatureOrTopic: "PendingOrderStored"): EventFragment;
1642
1985
  getEvent(nameOrSignatureOrTopic: "TradeClosed"): EventFragment;
1643
1986
  getEvent(nameOrSignatureOrTopic: "TradeCollateralUpdated"): EventFragment;
1987
+ getEvent(nameOrSignatureOrTopic: "TradeMaxClosingSlippagePUpdated"): EventFragment;
1988
+ getEvent(nameOrSignatureOrTopic: "TradePositionUpdated"): EventFragment;
1644
1989
  getEvent(nameOrSignatureOrTopic: "TradeSlUpdated"): EventFragment;
1645
1990
  getEvent(nameOrSignatureOrTopic: "TradeStored"): EventFragment;
1646
1991
  getEvent(nameOrSignatureOrTopic: "TradeTpUpdated"): EventFragment;
@@ -1651,12 +1996,17 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1651
1996
  getEvent(nameOrSignatureOrTopic: "ByPassTriggerLinkUpdated"): EventFragment;
1652
1997
  getEvent(nameOrSignatureOrTopic: "ChainlinkCallbackTimeout"): EventFragment;
1653
1998
  getEvent(nameOrSignatureOrTopic: "CouldNotCloseTrade"): EventFragment;
1999
+ getEvent(nameOrSignatureOrTopic: "LeverageUpdateExecuted"): EventFragment;
2000
+ getEvent(nameOrSignatureOrTopic: "LeverageUpdateInitiated"): EventFragment;
1654
2001
  getEvent(nameOrSignatureOrTopic: "MarketOrderInitiated"): EventFragment;
1655
2002
  getEvent(nameOrSignatureOrTopic: "MarketOrdersTimeoutBlocksUpdated"): EventFragment;
1656
2003
  getEvent(nameOrSignatureOrTopic: "NativeTokenWrapped"): EventFragment;
1657
2004
  getEvent(nameOrSignatureOrTopic: "OpenLimitCanceled"): EventFragment;
1658
2005
  getEvent(nameOrSignatureOrTopic: "OpenLimitUpdated"): EventFragment;
1659
2006
  getEvent(nameOrSignatureOrTopic: "OpenOrderPlaced"): EventFragment;
2007
+ getEvent(nameOrSignatureOrTopic: "PositionSizeDecreaseExecuted"): EventFragment;
2008
+ getEvent(nameOrSignatureOrTopic: "PositionSizeIncreaseExecuted"): EventFragment;
2009
+ getEvent(nameOrSignatureOrTopic: "PositionSizeUpdateInitiated"): EventFragment;
1660
2010
  getEvent(nameOrSignatureOrTopic: "TriggerOrderInitiated"): EventFragment;
1661
2011
  getEvent(nameOrSignatureOrTopic: "BorrowingFeeCharged"): EventFragment;
1662
2012
  getEvent(nameOrSignatureOrTopic: "GTokenFeeCharged"): EventFragment;
@@ -1680,9 +2030,7 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1680
2030
  getEvent(nameOrSignatureOrTopic: "BorrowingPairOiUpdated"): EventFragment;
1681
2031
  getEvent(nameOrSignatureOrTopic: "BorrowingPairParamsUpdated"): EventFragment;
1682
2032
  getEvent(nameOrSignatureOrTopic: "TradeBorrowingCallbackHandled"): EventFragment;
1683
- getEvent(nameOrSignatureOrTopic: "ChainlinkFulfilled"): EventFragment;
1684
- getEvent(nameOrSignatureOrTopic: "ChainlinkRequested"): EventFragment;
1685
- getEvent(nameOrSignatureOrTopic: "CollateralGnsUniV3PoolUpdated"): EventFragment;
2033
+ getEvent(nameOrSignatureOrTopic: "CollateralGnsLiquidityPoolUpdated"): EventFragment;
1686
2034
  getEvent(nameOrSignatureOrTopic: "CollateralUsdPriceFeedUpdated"): EventFragment;
1687
2035
  getEvent(nameOrSignatureOrTopic: "JobIdUpdated"): EventFragment;
1688
2036
  getEvent(nameOrSignatureOrTopic: "LinkClaimedBack"): EventFragment;
@@ -1696,17 +2044,9 @@ export interface GNSMultiCollatDiamondInterface extends utils.Interface {
1696
2044
  getEvent(nameOrSignatureOrTopic: "PriceRequested"): EventFragment;
1697
2045
  getEvent(nameOrSignatureOrTopic: "TradingCallbackExecuted"): EventFragment;
1698
2046
  getEvent(nameOrSignatureOrTopic: "TwapIntervalUpdated"): EventFragment;
1699
- getEvent(nameOrSignatureOrTopic: "BorrowingFeesGroupsCopied"): EventFragment;
1700
- getEvent(nameOrSignatureOrTopic: "BorrowingFeesPairOisCopied"): EventFragment;
1701
- getEvent(nameOrSignatureOrTopic: "BorrowingFeesPairsCopied"): EventFragment;
1702
- getEvent(nameOrSignatureOrTopic: "CollateralTransferred"): EventFragment;
1703
- getEvent(nameOrSignatureOrTopic: "LegacyLimitOrderSkipped"): EventFragment;
1704
- getEvent(nameOrSignatureOrTopic: "LimitsCopied"): EventFragment;
1705
- getEvent(nameOrSignatureOrTopic: "MarkedAsDone"): EventFragment;
1706
- getEvent(nameOrSignatureOrTopic: "PairTradesCopied"): EventFragment;
1707
- getEvent(nameOrSignatureOrTopic: "TradeCopied"): EventFragment;
1708
- getEvent(nameOrSignatureOrTopic: "TraderDelegationsCopied"): EventFragment;
1709
- getEvent(nameOrSignatureOrTopic: "TradesCopied"): EventFragment;
2047
+ getEvent(nameOrSignatureOrTopic: "OtcBalanceUpdated"): EventFragment;
2048
+ getEvent(nameOrSignatureOrTopic: "OtcConfigUpdated"): EventFragment;
2049
+ getEvent(nameOrSignatureOrTopic: "OtcExecuted"): EventFragment;
1710
2050
  }
1711
2051
  export interface AccessControlUpdatedEventObject {
1712
2052
  target: string;
@@ -1765,6 +2105,15 @@ export type GroupAddedEvent = TypedEvent<[
1765
2105
  string
1766
2106
  ], GroupAddedEventObject>;
1767
2107
  export type GroupAddedEventFilter = TypedEventFilter<GroupAddedEvent>;
2108
+ export interface GroupLiquidationParamsUpdatedEventObject {
2109
+ index: BigNumber;
2110
+ params: IPairsStorage.GroupLiquidationParamsStructOutput;
2111
+ }
2112
+ export type GroupLiquidationParamsUpdatedEvent = TypedEvent<[
2113
+ BigNumber,
2114
+ IPairsStorage.GroupLiquidationParamsStructOutput
2115
+ ], GroupLiquidationParamsUpdatedEventObject>;
2116
+ export type GroupLiquidationParamsUpdatedEventFilter = TypedEventFilter<GroupLiquidationParamsUpdatedEvent>;
1768
2117
  export interface GroupUpdatedEventObject {
1769
2118
  index: BigNumber;
1770
2119
  }
@@ -1983,6 +2332,15 @@ export type TraderTrailingPointsExpiredEvent = TypedEvent<[
1983
2332
  BigNumber
1984
2333
  ], TraderTrailingPointsExpiredEventObject>;
1985
2334
  export type TraderTrailingPointsExpiredEventFilter = TypedEventFilter<TraderTrailingPointsExpiredEvent>;
2335
+ export interface CumulativeFactorUpdatedEventObject {
2336
+ pairIndex: BigNumber;
2337
+ cumulativeFactor: number;
2338
+ }
2339
+ export type CumulativeFactorUpdatedEvent = TypedEvent<[
2340
+ BigNumber,
2341
+ number
2342
+ ], CumulativeFactorUpdatedEventObject>;
2343
+ export type CumulativeFactorUpdatedEventFilter = TypedEventFilter<CumulativeFactorUpdatedEvent>;
1986
2344
  export interface OiWindowsSettingsInitializedEventObject {
1987
2345
  windowsDuration: number;
1988
2346
  windowsCount: number;
@@ -2032,15 +2390,6 @@ export type PriceImpactOpenInterestAddedEvent = TypedEvent<[
2032
2390
  IPriceImpact.OiWindowUpdateStructOutput
2033
2391
  ], PriceImpactOpenInterestAddedEventObject>;
2034
2392
  export type PriceImpactOpenInterestAddedEventFilter = TypedEventFilter<PriceImpactOpenInterestAddedEvent>;
2035
- export interface PriceImpactOpenInterestRemovedEventObject {
2036
- oiWindowUpdate: IPriceImpact.OiWindowUpdateStructOutput;
2037
- notOutdated: boolean;
2038
- }
2039
- export type PriceImpactOpenInterestRemovedEvent = TypedEvent<[
2040
- IPriceImpact.OiWindowUpdateStructOutput,
2041
- boolean
2042
- ], PriceImpactOpenInterestRemovedEventObject>;
2043
- export type PriceImpactOpenInterestRemovedEventFilter = TypedEventFilter<PriceImpactOpenInterestRemovedEvent>;
2044
2393
  export interface PriceImpactWindowsCountUpdatedEventObject {
2045
2394
  windowsCount: number;
2046
2395
  }
@@ -2055,6 +2404,24 @@ export type PriceImpactWindowsDurationUpdatedEvent = TypedEvent<[
2055
2404
  number
2056
2405
  ], PriceImpactWindowsDurationUpdatedEventObject>;
2057
2406
  export type PriceImpactWindowsDurationUpdatedEventFilter = TypedEventFilter<PriceImpactWindowsDurationUpdatedEvent>;
2407
+ export interface ProtectionCloseFactorBlocksUpdatedEventObject {
2408
+ pairIndex: BigNumber;
2409
+ protectionCloseFactorBlocks: number;
2410
+ }
2411
+ export type ProtectionCloseFactorBlocksUpdatedEvent = TypedEvent<[
2412
+ BigNumber,
2413
+ number
2414
+ ], ProtectionCloseFactorBlocksUpdatedEventObject>;
2415
+ export type ProtectionCloseFactorBlocksUpdatedEventFilter = TypedEventFilter<ProtectionCloseFactorBlocksUpdatedEvent>;
2416
+ export interface ProtectionCloseFactorUpdatedEventObject {
2417
+ pairIndex: BigNumber;
2418
+ protectionCloseFactor: number;
2419
+ }
2420
+ export type ProtectionCloseFactorUpdatedEvent = TypedEvent<[
2421
+ BigNumber,
2422
+ number
2423
+ ], ProtectionCloseFactorUpdatedEventObject>;
2424
+ export type ProtectionCloseFactorUpdatedEventFilter = TypedEventFilter<ProtectionCloseFactorUpdatedEvent>;
2058
2425
  export interface CollateralAddedEventObject {
2059
2426
  collateral: string;
2060
2427
  index: number;
@@ -2138,6 +2505,34 @@ export type TradeCollateralUpdatedEvent = TypedEvent<[
2138
2505
  BigNumber
2139
2506
  ], TradeCollateralUpdatedEventObject>;
2140
2507
  export type TradeCollateralUpdatedEventFilter = TypedEventFilter<TradeCollateralUpdatedEvent>;
2508
+ export interface TradeMaxClosingSlippagePUpdatedEventObject {
2509
+ tradeId: ITradingStorage.IdStructOutput;
2510
+ maxClosingSlippageP: number;
2511
+ }
2512
+ export type TradeMaxClosingSlippagePUpdatedEvent = TypedEvent<[
2513
+ ITradingStorage.IdStructOutput,
2514
+ number
2515
+ ], TradeMaxClosingSlippagePUpdatedEventObject>;
2516
+ export type TradeMaxClosingSlippagePUpdatedEventFilter = TypedEventFilter<TradeMaxClosingSlippagePUpdatedEvent>;
2517
+ export interface TradePositionUpdatedEventObject {
2518
+ tradeId: ITradingStorage.IdStructOutput;
2519
+ collateralAmount: BigNumber;
2520
+ leverage: number;
2521
+ openPrice: BigNumber;
2522
+ newTp: BigNumber;
2523
+ newSl: BigNumber;
2524
+ isPartialIncrease: boolean;
2525
+ }
2526
+ export type TradePositionUpdatedEvent = TypedEvent<[
2527
+ ITradingStorage.IdStructOutput,
2528
+ BigNumber,
2529
+ number,
2530
+ BigNumber,
2531
+ BigNumber,
2532
+ BigNumber,
2533
+ boolean
2534
+ ], TradePositionUpdatedEventObject>;
2535
+ export type TradePositionUpdatedEventFilter = TypedEventFilter<TradePositionUpdatedEvent>;
2141
2536
  export interface TradeSlUpdatedEventObject {
2142
2537
  tradeId: ITradingStorage.IdStructOutput;
2143
2538
  newSl: BigNumber;
@@ -2150,10 +2545,12 @@ export type TradeSlUpdatedEventFilter = TypedEventFilter<TradeSlUpdatedEvent>;
2150
2545
  export interface TradeStoredEventObject {
2151
2546
  trade: ITradingStorage.TradeStructOutput;
2152
2547
  tradeInfo: ITradingStorage.TradeInfoStructOutput;
2548
+ liquidationParams: IPairsStorage.GroupLiquidationParamsStructOutput;
2153
2549
  }
2154
2550
  export type TradeStoredEvent = TypedEvent<[
2155
2551
  ITradingStorage.TradeStructOutput,
2156
- ITradingStorage.TradeInfoStructOutput
2552
+ ITradingStorage.TradeInfoStructOutput,
2553
+ IPairsStorage.GroupLiquidationParamsStructOutput
2157
2554
  ], TradeStoredEventObject>;
2158
2555
  export type TradeStoredEventFilter = TypedEventFilter<TradeStoredEvent>;
2159
2556
  export interface TradeTpUpdatedEventObject {
@@ -2226,6 +2623,48 @@ export type CouldNotCloseTradeEvent = TypedEvent<[
2226
2623
  number
2227
2624
  ], CouldNotCloseTradeEventObject>;
2228
2625
  export type CouldNotCloseTradeEventFilter = TypedEventFilter<CouldNotCloseTradeEvent>;
2626
+ export interface LeverageUpdateExecutedEventObject {
2627
+ orderId: ITradingStorage.IdStructOutput;
2628
+ isIncrease: boolean;
2629
+ cancelReason: number;
2630
+ collateralIndex: number;
2631
+ trader: string;
2632
+ pairIndex: BigNumber;
2633
+ index: BigNumber;
2634
+ marketPrice: BigNumber;
2635
+ collateralDelta: BigNumber;
2636
+ values: IUpdateLeverage.UpdateLeverageValuesStructOutput;
2637
+ }
2638
+ export type LeverageUpdateExecutedEvent = TypedEvent<[
2639
+ ITradingStorage.IdStructOutput,
2640
+ boolean,
2641
+ number,
2642
+ number,
2643
+ string,
2644
+ BigNumber,
2645
+ BigNumber,
2646
+ BigNumber,
2647
+ BigNumber,
2648
+ IUpdateLeverage.UpdateLeverageValuesStructOutput
2649
+ ], LeverageUpdateExecutedEventObject>;
2650
+ export type LeverageUpdateExecutedEventFilter = TypedEventFilter<LeverageUpdateExecutedEvent>;
2651
+ export interface LeverageUpdateInitiatedEventObject {
2652
+ orderId: ITradingStorage.IdStructOutput;
2653
+ trader: string;
2654
+ pairIndex: BigNumber;
2655
+ index: BigNumber;
2656
+ isIncrease: boolean;
2657
+ newLeverage: BigNumber;
2658
+ }
2659
+ export type LeverageUpdateInitiatedEvent = TypedEvent<[
2660
+ ITradingStorage.IdStructOutput,
2661
+ string,
2662
+ BigNumber,
2663
+ BigNumber,
2664
+ boolean,
2665
+ BigNumber
2666
+ ], LeverageUpdateInitiatedEventObject>;
2667
+ export type LeverageUpdateInitiatedEventFilter = TypedEventFilter<LeverageUpdateInitiatedEvent>;
2229
2668
  export interface MarketOrderInitiatedEventObject {
2230
2669
  orderId: ITradingStorage.IdStructOutput;
2231
2670
  trader: string;
@@ -2296,36 +2735,113 @@ export type OpenOrderPlacedEvent = TypedEvent<[
2296
2735
  number
2297
2736
  ], OpenOrderPlacedEventObject>;
2298
2737
  export type OpenOrderPlacedEventFilter = TypedEventFilter<OpenOrderPlacedEvent>;
2299
- export interface TriggerOrderInitiatedEventObject {
2738
+ export interface PositionSizeDecreaseExecutedEventObject {
2300
2739
  orderId: ITradingStorage.IdStructOutput;
2740
+ cancelReason: number;
2741
+ collateralIndex: number;
2301
2742
  trader: string;
2302
- pairIndex: number;
2303
- byPassesLinkCost: boolean;
2743
+ pairIndex: BigNumber;
2744
+ index: BigNumber;
2745
+ long: boolean;
2746
+ marketPrice: BigNumber;
2747
+ collateralPriceUsd: BigNumber;
2748
+ collateralDelta: BigNumber;
2749
+ leverageDelta: BigNumber;
2750
+ values: IUpdatePositionSize.DecreasePositionSizeValuesStructOutput;
2304
2751
  }
2305
- export type TriggerOrderInitiatedEvent = TypedEvent<[
2752
+ export type PositionSizeDecreaseExecutedEvent = TypedEvent<[
2306
2753
  ITradingStorage.IdStructOutput,
2307
- string,
2308
2754
  number,
2309
- boolean
2310
- ], TriggerOrderInitiatedEventObject>;
2311
- export type TriggerOrderInitiatedEventFilter = TypedEventFilter<TriggerOrderInitiatedEvent>;
2312
- export interface BorrowingFeeChargedEventObject {
2313
- trader: string;
2314
- collateralIndex: number;
2315
- amountCollateral: BigNumber;
2316
- }
2317
- export type BorrowingFeeChargedEvent = TypedEvent<[
2318
- string,
2319
2755
  number,
2320
- BigNumber
2321
- ], BorrowingFeeChargedEventObject>;
2322
- export type BorrowingFeeChargedEventFilter = TypedEventFilter<BorrowingFeeChargedEvent>;
2323
- export interface GTokenFeeChargedEventObject {
2324
- trader: string;
2325
- collateralIndex: number;
2326
- amountCollateral: BigNumber;
2327
- }
2328
- export type GTokenFeeChargedEvent = TypedEvent<[
2756
+ string,
2757
+ BigNumber,
2758
+ BigNumber,
2759
+ boolean,
2760
+ BigNumber,
2761
+ BigNumber,
2762
+ BigNumber,
2763
+ BigNumber,
2764
+ IUpdatePositionSize.DecreasePositionSizeValuesStructOutput
2765
+ ], PositionSizeDecreaseExecutedEventObject>;
2766
+ export type PositionSizeDecreaseExecutedEventFilter = TypedEventFilter<PositionSizeDecreaseExecutedEvent>;
2767
+ export interface PositionSizeIncreaseExecutedEventObject {
2768
+ orderId: ITradingStorage.IdStructOutput;
2769
+ cancelReason: number;
2770
+ collateralIndex: number;
2771
+ trader: string;
2772
+ pairIndex: BigNumber;
2773
+ index: BigNumber;
2774
+ long: boolean;
2775
+ marketPrice: BigNumber;
2776
+ collateralPriceUsd: BigNumber;
2777
+ collateralDelta: BigNumber;
2778
+ leverageDelta: BigNumber;
2779
+ values: IUpdatePositionSize.IncreasePositionSizeValuesStructOutput;
2780
+ }
2781
+ export type PositionSizeIncreaseExecutedEvent = TypedEvent<[
2782
+ ITradingStorage.IdStructOutput,
2783
+ number,
2784
+ number,
2785
+ string,
2786
+ BigNumber,
2787
+ BigNumber,
2788
+ boolean,
2789
+ BigNumber,
2790
+ BigNumber,
2791
+ BigNumber,
2792
+ BigNumber,
2793
+ IUpdatePositionSize.IncreasePositionSizeValuesStructOutput
2794
+ ], PositionSizeIncreaseExecutedEventObject>;
2795
+ export type PositionSizeIncreaseExecutedEventFilter = TypedEventFilter<PositionSizeIncreaseExecutedEvent>;
2796
+ export interface PositionSizeUpdateInitiatedEventObject {
2797
+ orderId: ITradingStorage.IdStructOutput;
2798
+ trader: string;
2799
+ pairIndex: BigNumber;
2800
+ index: BigNumber;
2801
+ isIncrease: boolean;
2802
+ collateralDelta: BigNumber;
2803
+ leverageDelta: BigNumber;
2804
+ }
2805
+ export type PositionSizeUpdateInitiatedEvent = TypedEvent<[
2806
+ ITradingStorage.IdStructOutput,
2807
+ string,
2808
+ BigNumber,
2809
+ BigNumber,
2810
+ boolean,
2811
+ BigNumber,
2812
+ BigNumber
2813
+ ], PositionSizeUpdateInitiatedEventObject>;
2814
+ export type PositionSizeUpdateInitiatedEventFilter = TypedEventFilter<PositionSizeUpdateInitiatedEvent>;
2815
+ export interface TriggerOrderInitiatedEventObject {
2816
+ orderId: ITradingStorage.IdStructOutput;
2817
+ trader: string;
2818
+ pairIndex: number;
2819
+ byPassesLinkCost: boolean;
2820
+ }
2821
+ export type TriggerOrderInitiatedEvent = TypedEvent<[
2822
+ ITradingStorage.IdStructOutput,
2823
+ string,
2824
+ number,
2825
+ boolean
2826
+ ], TriggerOrderInitiatedEventObject>;
2827
+ export type TriggerOrderInitiatedEventFilter = TypedEventFilter<TriggerOrderInitiatedEvent>;
2828
+ export interface BorrowingFeeChargedEventObject {
2829
+ trader: string;
2830
+ collateralIndex: number;
2831
+ amountCollateral: BigNumber;
2832
+ }
2833
+ export type BorrowingFeeChargedEvent = TypedEvent<[
2834
+ string,
2835
+ number,
2836
+ BigNumber
2837
+ ], BorrowingFeeChargedEventObject>;
2838
+ export type BorrowingFeeChargedEventFilter = TypedEventFilter<BorrowingFeeChargedEvent>;
2839
+ export interface GTokenFeeChargedEventObject {
2840
+ trader: string;
2841
+ collateralIndex: number;
2842
+ amountCollateral: BigNumber;
2843
+ }
2844
+ export type GTokenFeeChargedEvent = TypedEvent<[
2329
2845
  string,
2330
2846
  number,
2331
2847
  BigNumber
@@ -2532,6 +3048,7 @@ export interface BorrowingInitialAccFeesStoredEventObject {
2532
3048
  trader: string;
2533
3049
  pairIndex: number;
2534
3050
  index: number;
3051
+ long: boolean;
2535
3052
  initialPairAccFee: BigNumber;
2536
3053
  initialGroupAccFee: BigNumber;
2537
3054
  }
@@ -2540,6 +3057,7 @@ export type BorrowingInitialAccFeesStoredEvent = TypedEvent<[
2540
3057
  string,
2541
3058
  number,
2542
3059
  number,
3060
+ boolean,
2543
3061
  BigNumber,
2544
3062
  BigNumber
2545
3063
  ], BorrowingInitialAccFeesStoredEventObject>;
@@ -2627,29 +3145,15 @@ export type TradeBorrowingCallbackHandledEvent = TypedEvent<[
2627
3145
  BigNumber
2628
3146
  ], TradeBorrowingCallbackHandledEventObject>;
2629
3147
  export type TradeBorrowingCallbackHandledEventFilter = TypedEventFilter<TradeBorrowingCallbackHandledEvent>;
2630
- export interface ChainlinkFulfilledEventObject {
2631
- id: string;
2632
- }
2633
- export type ChainlinkFulfilledEvent = TypedEvent<[
2634
- string
2635
- ], ChainlinkFulfilledEventObject>;
2636
- export type ChainlinkFulfilledEventFilter = TypedEventFilter<ChainlinkFulfilledEvent>;
2637
- export interface ChainlinkRequestedEventObject {
2638
- id: string;
2639
- }
2640
- export type ChainlinkRequestedEvent = TypedEvent<[
2641
- string
2642
- ], ChainlinkRequestedEventObject>;
2643
- export type ChainlinkRequestedEventFilter = TypedEventFilter<ChainlinkRequestedEvent>;
2644
- export interface CollateralGnsUniV3PoolUpdatedEventObject {
3148
+ export interface CollateralGnsLiquidityPoolUpdatedEventObject {
2645
3149
  collateralIndex: number;
2646
- newValue: IPriceAggregator.UniV3PoolInfoStructOutput;
3150
+ newValue: IPriceAggregator.LiquidityPoolInfoStructOutput;
2647
3151
  }
2648
- export type CollateralGnsUniV3PoolUpdatedEvent = TypedEvent<[
3152
+ export type CollateralGnsLiquidityPoolUpdatedEvent = TypedEvent<[
2649
3153
  number,
2650
- IPriceAggregator.UniV3PoolInfoStructOutput
2651
- ], CollateralGnsUniV3PoolUpdatedEventObject>;
2652
- export type CollateralGnsUniV3PoolUpdatedEventFilter = TypedEventFilter<CollateralGnsUniV3PoolUpdatedEvent>;
3154
+ IPriceAggregator.LiquidityPoolInfoStructOutput
3155
+ ], CollateralGnsLiquidityPoolUpdatedEventObject>;
3156
+ export type CollateralGnsLiquidityPoolUpdatedEventFilter = TypedEventFilter<CollateralGnsLiquidityPoolUpdatedEvent>;
2653
3157
  export interface CollateralUsdPriceFeedUpdatedEventObject {
2654
3158
  collateralIndex: number;
2655
3159
  value: string;
@@ -2744,25 +3248,27 @@ export type PriceReceivedEvent = TypedEvent<[
2744
3248
  export type PriceReceivedEventFilter = TypedEventFilter<PriceReceivedEvent>;
2745
3249
  export interface PriceRequestedEventObject {
2746
3250
  collateralIndex: number;
3251
+ pairIndex: BigNumber;
3252
+ tradeId: ITradingStorage.IdStructOutput;
2747
3253
  pendingOrderId: ITradingStorage.IdStructOutput;
2748
3254
  orderType: number;
2749
- pairIndex: BigNumber;
2750
- job: string;
2751
- nodesCount: BigNumber;
2752
- linkFeePerNode: BigNumber;
2753
3255
  fromBlock: BigNumber;
2754
3256
  isLookback: boolean;
3257
+ job: string;
3258
+ linkFeePerNode: BigNumber;
3259
+ nodesCount: BigNumber;
2755
3260
  }
2756
3261
  export type PriceRequestedEvent = TypedEvent<[
2757
3262
  number,
3263
+ BigNumber,
3264
+ ITradingStorage.IdStructOutput,
2758
3265
  ITradingStorage.IdStructOutput,
2759
3266
  number,
2760
3267
  BigNumber,
3268
+ boolean,
2761
3269
  string,
2762
3270
  BigNumber,
2763
- BigNumber,
2764
- BigNumber,
2765
- boolean
3271
+ BigNumber
2766
3272
  ], PriceRequestedEventObject>;
2767
3273
  export type PriceRequestedEventFilter = TypedEventFilter<PriceRequestedEvent>;
2768
3274
  export interface TradingCallbackExecutedEventObject {
@@ -2781,119 +3287,39 @@ export type TwapIntervalUpdatedEvent = TypedEvent<[
2781
3287
  number
2782
3288
  ], TwapIntervalUpdatedEventObject>;
2783
3289
  export type TwapIntervalUpdatedEventFilter = TypedEventFilter<TwapIntervalUpdatedEvent>;
2784
- export interface BorrowingFeesGroupsCopiedEventObject {
2785
- collateralIndex: number;
2786
- groupsCount: number;
2787
- }
2788
- export type BorrowingFeesGroupsCopiedEvent = TypedEvent<[
2789
- number,
2790
- number
2791
- ], BorrowingFeesGroupsCopiedEventObject>;
2792
- export type BorrowingFeesGroupsCopiedEventFilter = TypedEventFilter<BorrowingFeesGroupsCopiedEvent>;
2793
- export interface BorrowingFeesPairOisCopiedEventObject {
2794
- collateralIndex: number;
2795
- pairsCount: BigNumber;
2796
- }
2797
- export type BorrowingFeesPairOisCopiedEvent = TypedEvent<[
2798
- number,
2799
- BigNumber
2800
- ], BorrowingFeesPairOisCopiedEventObject>;
2801
- export type BorrowingFeesPairOisCopiedEventFilter = TypedEventFilter<BorrowingFeesPairOisCopiedEvent>;
2802
- export interface BorrowingFeesPairsCopiedEventObject {
3290
+ export interface OtcBalanceUpdatedEventObject {
2803
3291
  collateralIndex: number;
2804
- pairsCount: BigNumber;
3292
+ balanceCollateral: BigNumber;
2805
3293
  }
2806
- export type BorrowingFeesPairsCopiedEvent = TypedEvent<[
3294
+ export type OtcBalanceUpdatedEvent = TypedEvent<[
2807
3295
  number,
2808
3296
  BigNumber
2809
- ], BorrowingFeesPairsCopiedEventObject>;
2810
- export type BorrowingFeesPairsCopiedEventFilter = TypedEventFilter<BorrowingFeesPairsCopiedEvent>;
2811
- export interface CollateralTransferredEventObject {
3297
+ ], OtcBalanceUpdatedEventObject>;
3298
+ export type OtcBalanceUpdatedEventFilter = TypedEventFilter<OtcBalanceUpdatedEvent>;
3299
+ export interface OtcConfigUpdatedEventObject {
3300
+ config: IOtc.OtcConfigStructOutput;
3301
+ }
3302
+ export type OtcConfigUpdatedEvent = TypedEvent<[
3303
+ IOtc.OtcConfigStructOutput
3304
+ ], OtcConfigUpdatedEventObject>;
3305
+ export type OtcConfigUpdatedEventFilter = TypedEventFilter<OtcConfigUpdatedEvent>;
3306
+ export interface OtcExecutedEventObject {
2812
3307
  collateralIndex: number;
2813
- balance: BigNumber;
2814
- govFees: BigNumber;
2815
- }
2816
- export type CollateralTransferredEvent = TypedEvent<[
2817
- number,
2818
- BigNumber,
2819
- BigNumber
2820
- ], CollateralTransferredEventObject>;
2821
- export type CollateralTransferredEventFilter = TypedEventFilter<CollateralTransferredEvent>;
2822
- export interface LegacyLimitOrderSkippedEventObject {
2823
- collateralIndex: number;
2824
- trader: string;
2825
- pairIndex: BigNumber;
2826
- index: BigNumber;
3308
+ collateralAmount: BigNumber;
3309
+ gnsPriceCollateral: BigNumber;
3310
+ treasuryAmountGns: BigNumber;
3311
+ stakingAmountGns: BigNumber;
3312
+ burnAmountGns: BigNumber;
2827
3313
  }
2828
- export type LegacyLimitOrderSkippedEvent = TypedEvent<[
3314
+ export type OtcExecutedEvent = TypedEvent<[
2829
3315
  number,
2830
- string,
2831
3316
  BigNumber,
2832
- BigNumber
2833
- ], LegacyLimitOrderSkippedEventObject>;
2834
- export type LegacyLimitOrderSkippedEventFilter = TypedEventFilter<LegacyLimitOrderSkippedEvent>;
2835
- export interface LimitsCopiedEventObject {
2836
- collateralIndex: number;
2837
- fromIndex: BigNumber;
2838
- toIndex: BigNumber;
2839
- }
2840
- export type LimitsCopiedEvent = TypedEvent<[
2841
- number,
2842
3317
  BigNumber,
2843
- BigNumber
2844
- ], LimitsCopiedEventObject>;
2845
- export type LimitsCopiedEventFilter = TypedEventFilter<LimitsCopiedEvent>;
2846
- export interface MarkedAsDoneEventObject {
2847
- collateralIndex: number;
2848
- }
2849
- export type MarkedAsDoneEvent = TypedEvent<[number], MarkedAsDoneEventObject>;
2850
- export type MarkedAsDoneEventFilter = TypedEventFilter<MarkedAsDoneEvent>;
2851
- export interface PairTradesCopiedEventObject {
2852
- collateralIndex: number;
2853
- pairIndex: BigNumber;
2854
- tradersCount: BigNumber;
2855
- }
2856
- export type PairTradesCopiedEvent = TypedEvent<[
2857
- number,
2858
- BigNumber,
2859
- BigNumber
2860
- ], PairTradesCopiedEventObject>;
2861
- export type PairTradesCopiedEventFilter = TypedEventFilter<PairTradesCopiedEvent>;
2862
- export interface TradeCopiedEventObject {
2863
- collateralIndex: number;
2864
- trader: string;
2865
- pairIndex: BigNumber;
2866
- prevIndex: BigNumber;
2867
- newIndex: BigNumber;
2868
- }
2869
- export type TradeCopiedEvent = TypedEvent<[
2870
- number,
2871
- string,
2872
3318
  BigNumber,
2873
3319
  BigNumber,
2874
3320
  BigNumber
2875
- ], TradeCopiedEventObject>;
2876
- export type TradeCopiedEventFilter = TypedEventFilter<TradeCopiedEvent>;
2877
- export interface TraderDelegationsCopiedEventObject {
2878
- collateralIndex: number;
2879
- tradersCount: BigNumber;
2880
- }
2881
- export type TraderDelegationsCopiedEvent = TypedEvent<[
2882
- number,
2883
- BigNumber
2884
- ], TraderDelegationsCopiedEventObject>;
2885
- export type TraderDelegationsCopiedEventFilter = TypedEventFilter<TraderDelegationsCopiedEvent>;
2886
- export interface TradesCopiedEventObject {
2887
- collateralIndex: number;
2888
- fromPairIndex: number;
2889
- toPairIndex: number;
2890
- }
2891
- export type TradesCopiedEvent = TypedEvent<[
2892
- number,
2893
- number,
2894
- number
2895
- ], TradesCopiedEventObject>;
2896
- export type TradesCopiedEventFilter = TypedEventFilter<TradesCopiedEvent>;
3321
+ ], OtcExecutedEventObject>;
3322
+ export type OtcExecutedEventFilter = TypedEventFilter<OtcExecutedEvent>;
2897
3323
  export interface GNSMultiCollatDiamond extends BaseContract {
2898
3324
  connect(signerOrProvider: Signer | Provider | string): this;
2899
3325
  attach(addressOrName: string): this;
@@ -2946,14 +3372,20 @@ export interface GNSMultiCollatDiamond extends BaseContract {
2946
3372
  fees(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPairsStorage.FeeStructOutput]>;
2947
3373
  feesCount(overrides?: CallOverrides): Promise<[BigNumber]>;
2948
3374
  getAllPairsRestrictedMaxLeverage(overrides?: CallOverrides): Promise<[BigNumber[]]>;
3375
+ getGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPairsStorage.GroupLiquidationParamsStructOutput]>;
3376
+ getPairLiquidationParams(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPairsStorage.GroupLiquidationParamsStructOutput]>;
2949
3377
  groups(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPairsStorage.GroupStructOutput]>;
2950
3378
  groupsCount(overrides?: CallOverrides): Promise<[BigNumber]>;
3379
+ initializeGroupLiquidationParams(_groupLiquidationParams: IPairsStorage.GroupLiquidationParamsStruct[], overrides?: Overrides & {
3380
+ from?: PromiseOrValue<string>;
3381
+ }): Promise<ContractTransaction>;
2951
3382
  isPairIndexListed(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[boolean]>;
2952
3383
  isPairListed(_from: PromiseOrValue<string>, _to: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[boolean]>;
2953
3384
  pairCloseFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
2954
3385
  pairCustomMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
2955
3386
  pairJob(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[string, string]>;
2956
3387
  pairMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3388
+ pairMinFeeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
2957
3389
  pairMinLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
2958
3390
  pairMinPositionSizeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
2959
3391
  pairOpenFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
@@ -2967,6 +3399,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
2967
3399
  IPairsStorage.FeeStructOutput
2968
3400
  ]>;
2969
3401
  pairsCount(overrides?: CallOverrides): Promise<[BigNumber]>;
3402
+ setGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, _params: IPairsStorage.GroupLiquidationParamsStruct, overrides?: Overrides & {
3403
+ from?: PromiseOrValue<string>;
3404
+ }): Promise<ContractTransaction>;
2970
3405
  setPairCustomMaxLeverages(_indices: PromiseOrValue<BigNumberish>[], _values: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
2971
3406
  from?: PromiseOrValue<string>;
2972
3407
  }): Promise<ContractTransaction>;
@@ -3047,7 +3482,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3047
3482
  updateTraderPoints(_trader: PromiseOrValue<string>, _volumeUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3048
3483
  from?: PromiseOrValue<string>;
3049
3484
  }): Promise<ContractTransaction>;
3050
- addPriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
3485
+ addPriceImpactOpenInterest(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, _oiDeltaCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, overrides?: Overrides & {
3051
3486
  from?: PromiseOrValue<string>;
3052
3487
  }): Promise<ContractTransaction>;
3053
3488
  getOiWindow(_windowsDuration: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _windowId: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPriceImpact.PairOiStructOutput]>;
@@ -3055,20 +3490,24 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3055
3490
  getOiWindowsSettings(overrides?: CallOverrides): Promise<[IPriceImpact.OiWindowsSettingsStructOutput]>;
3056
3491
  getPairDepth(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPriceImpact.PairDepthStructOutput]>;
3057
3492
  getPairDepths(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<[IPriceImpact.PairDepthStructOutput[]]>;
3493
+ getPairFactors(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<[IPriceImpact.PairFactorsStructOutput[]]>;
3058
3494
  getPriceImpactOi(_pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<[BigNumber] & {
3059
3495
  activeOi: BigNumber;
3060
3496
  }>;
3061
- getTradePriceImpact(_openPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
3497
+ getTradePriceImpact(_marketPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, _isPnlPositive: PromiseOrValue<boolean>, _open: PromiseOrValue<boolean>, _lastPosIncreaseBlock: PromiseOrValue<BigNumberish>, _contractsVersion: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
3062
3498
  BigNumber,
3063
3499
  BigNumber
3064
3500
  ] & {
3065
3501
  priceImpactP: BigNumber;
3066
3502
  priceAfterImpact: BigNumber;
3067
3503
  }>;
3504
+ initializePairFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
3505
+ from?: PromiseOrValue<string>;
3506
+ }): Promise<ContractTransaction>;
3068
3507
  initializePriceImpact(_windowsDuration: PromiseOrValue<BigNumberish>, _windowsCount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3069
3508
  from?: PromiseOrValue<string>;
3070
3509
  }): Promise<ContractTransaction>;
3071
- removePriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _addTs: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3510
+ setCumulativeFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
3072
3511
  from?: PromiseOrValue<string>;
3073
3512
  }): Promise<ContractTransaction>;
3074
3513
  setPairDepths(_indices: PromiseOrValue<BigNumberish>[], _depthsAboveUsd: PromiseOrValue<BigNumberish>[], _depthsBelowUsd: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
@@ -3080,6 +3519,12 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3080
3519
  setPriceImpactWindowsDuration(_newWindowsDuration: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3081
3520
  from?: PromiseOrValue<string>;
3082
3521
  }): Promise<ContractTransaction>;
3522
+ setProtectionCloseFactorBlocks(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
3523
+ from?: PromiseOrValue<string>;
3524
+ }): Promise<ContractTransaction>;
3525
+ setProtectionCloseFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
3526
+ from?: PromiseOrValue<string>;
3527
+ }): Promise<ContractTransaction>;
3083
3528
  addCollateral(_collateral: PromiseOrValue<string>, _gToken: PromiseOrValue<string>, overrides?: Overrides & {
3084
3529
  from?: PromiseOrValue<string>;
3085
3530
  }): Promise<ContractTransaction>;
@@ -3092,23 +3537,25 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3092
3537
  getAllPendingOrders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[ITradingStorage.PendingOrderStructOutput[]]>;
3093
3538
  getAllTradeInfos(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[ITradingStorage.TradeInfoStructOutput[]]>;
3094
3539
  getAllTrades(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[ITradingStorage.TradeStructOutput[]]>;
3540
+ getAllTradesLiquidationParams(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPairsStorage.GroupLiquidationParamsStructOutput[]]>;
3095
3541
  getCollateral(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[ITradingStorage.CollateralStructOutput]>;
3096
3542
  getCollateralIndex(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[number]>;
3097
3543
  getCollaterals(overrides?: CallOverrides): Promise<[ITradingStorage.CollateralStructOutput[]]>;
3098
3544
  getCollateralsCount(overrides?: CallOverrides): Promise<[number]>;
3099
3545
  getCounters(_trader: PromiseOrValue<string>, _type: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[ITradingStorage.CounterStructOutput]>;
3546
+ getCurrentContractsVersion(overrides?: CallOverrides): Promise<[number]>;
3100
3547
  getGToken(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[string]>;
3101
- getPendingOpenOrderType(_tradeType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[number]>;
3102
3548
  getPendingOrder(_orderId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<[ITradingStorage.PendingOrderStructOutput]>;
3103
3549
  getPendingOrders(_user: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[ITradingStorage.PendingOrderStructOutput[]]>;
3104
- getPnlPercent(_openPrice: PromiseOrValue<BigNumberish>, _currentPrice: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _leverage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3105
3550
  getTrade(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[ITradingStorage.TradeStructOutput]>;
3106
3551
  getTradeInfo(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[ITradingStorage.TradeInfoStructOutput]>;
3107
3552
  getTradeInfos(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[ITradingStorage.TradeInfoStructOutput[]]>;
3553
+ getTradeLiquidationParams(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPairsStorage.GroupLiquidationParamsStructOutput]>;
3108
3554
  getTradePendingOrderBlock(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3109
3555
  getTraderStored(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[boolean]>;
3110
3556
  getTraders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[string[]]>;
3111
3557
  getTrades(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[ITradingStorage.TradeStructOutput[]]>;
3558
+ getTradesLiquidationParams(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[IPairsStorage.GroupLiquidationParamsStructOutput[]]>;
3112
3559
  getTradingActivated(overrides?: CallOverrides): Promise<[number]>;
3113
3560
  initializeTradingStorage(_gns: PromiseOrValue<string>, _gnsStaking: PromiseOrValue<string>, _collaterals: PromiseOrValue<string>[], _gTokens: PromiseOrValue<string>[], overrides?: Overrides & {
3114
3561
  from?: PromiseOrValue<string>;
@@ -3133,6 +3580,12 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3133
3580
  updateTradeCollateralAmount(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3134
3581
  from?: PromiseOrValue<string>;
3135
3582
  }): Promise<ContractTransaction>;
3583
+ updateTradeMaxClosingSlippageP(_tradeId: ITradingStorage.IdStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3584
+ from?: PromiseOrValue<string>;
3585
+ }): Promise<ContractTransaction>;
3586
+ updateTradePosition(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, _leverage: PromiseOrValue<BigNumberish>, _openPrice: PromiseOrValue<BigNumberish>, _isPartialIncrease: PromiseOrValue<boolean>, overrides?: Overrides & {
3587
+ from?: PromiseOrValue<string>;
3588
+ }): Promise<ContractTransaction>;
3136
3589
  updateTradeSl(_tradeId: ITradingStorage.IdStruct, _newSl: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3137
3590
  from?: PromiseOrValue<string>;
3138
3591
  }): Promise<ContractTransaction>;
@@ -3160,10 +3613,13 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3160
3613
  cancelOpenOrder(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3161
3614
  from?: PromiseOrValue<string>;
3162
3615
  }): Promise<ContractTransaction>;
3163
- closeTradeMarket(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3616
+ cancelOrderAfterTimeout(_orderIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3164
3617
  from?: PromiseOrValue<string>;
3165
3618
  }): Promise<ContractTransaction>;
3166
- closeTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: Overrides & {
3619
+ closeTradeMarket(_index: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3620
+ from?: PromiseOrValue<string>;
3621
+ }): Promise<ContractTransaction>;
3622
+ decreasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3167
3623
  from?: PromiseOrValue<string>;
3168
3624
  }): Promise<ContractTransaction>;
3169
3625
  delegatedTradingAction(_trader: PromiseOrValue<string>, _callData: PromiseOrValue<BytesLike>, overrides?: Overrides & {
@@ -3173,6 +3629,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3173
3629
  getMarketOrdersTimeoutBlocks(overrides?: CallOverrides): Promise<[number]>;
3174
3630
  getTradingDelegate(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[string]>;
3175
3631
  getWrappedNativeToken(overrides?: CallOverrides): Promise<[string]>;
3632
+ increasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3633
+ from?: PromiseOrValue<string>;
3634
+ }): Promise<ContractTransaction>;
3176
3635
  initializeTrading(_marketOrdersTimeoutBlocks: PromiseOrValue<BigNumberish>, _usersByPassTriggerLink: PromiseOrValue<string>[], overrides?: Overrides & {
3177
3636
  from?: PromiseOrValue<string>;
3178
3637
  }): Promise<ContractTransaction>;
@@ -3180,9 +3639,6 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3180
3639
  openTrade(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: Overrides & {
3181
3640
  from?: PromiseOrValue<string>;
3182
3641
  }): Promise<ContractTransaction>;
3183
- openTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: Overrides & {
3184
- from?: PromiseOrValue<string>;
3185
- }): Promise<ContractTransaction>;
3186
3642
  openTradeNative(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: PayableOverrides & {
3187
3643
  from?: PromiseOrValue<string>;
3188
3644
  }): Promise<ContractTransaction>;
@@ -3198,9 +3654,15 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3198
3654
  updateByPassTriggerLink(_users: PromiseOrValue<string>[], _shouldByPass: PromiseOrValue<boolean>[], overrides?: Overrides & {
3199
3655
  from?: PromiseOrValue<string>;
3200
3656
  }): Promise<ContractTransaction>;
3657
+ updateLeverage(_index: PromiseOrValue<BigNumberish>, _newLeverage: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3658
+ from?: PromiseOrValue<string>;
3659
+ }): Promise<ContractTransaction>;
3201
3660
  updateMarketOrdersTimeoutBlocks(_valueBlocks: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3202
3661
  from?: PromiseOrValue<string>;
3203
3662
  }): Promise<ContractTransaction>;
3663
+ updateMaxClosingSlippageP(_index: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3664
+ from?: PromiseOrValue<string>;
3665
+ }): Promise<ContractTransaction>;
3204
3666
  updateOpenOrder(_index: PromiseOrValue<BigNumberish>, _triggerPrice: PromiseOrValue<BigNumberish>, _tp: PromiseOrValue<BigNumberish>, _sl: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3205
3667
  from?: PromiseOrValue<string>;
3206
3668
  }): Promise<ContractTransaction>;
@@ -3216,6 +3678,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3216
3678
  closeTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
3217
3679
  from?: PromiseOrValue<string>;
3218
3680
  }): Promise<ContractTransaction>;
3681
+ decreasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
3682
+ from?: PromiseOrValue<string>;
3683
+ }): Promise<ContractTransaction>;
3219
3684
  executeTriggerCloseOrderCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
3220
3685
  from?: PromiseOrValue<string>;
3221
3686
  }): Promise<ContractTransaction>;
@@ -3224,15 +3689,45 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3224
3689
  }): Promise<ContractTransaction>;
3225
3690
  getPendingGovFeesCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3226
3691
  getVaultClosingFeeP(overrides?: CallOverrides): Promise<[number]>;
3692
+ increasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
3693
+ from?: PromiseOrValue<string>;
3694
+ }): Promise<ContractTransaction>;
3227
3695
  initializeCallbacks(_vaultClosingFeeP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3228
3696
  from?: PromiseOrValue<string>;
3229
3697
  }): Promise<ContractTransaction>;
3230
3698
  openTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
3231
3699
  from?: PromiseOrValue<string>;
3232
3700
  }): Promise<ContractTransaction>;
3701
+ updateLeverageCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
3702
+ from?: PromiseOrValue<string>;
3703
+ }): Promise<ContractTransaction>;
3233
3704
  updateVaultClosingFeeP(_valueP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3234
3705
  from?: PromiseOrValue<string>;
3235
3706
  }): Promise<ContractTransaction>;
3707
+ validateTriggerCloseOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
3708
+ ITradingStorage.TradeStructOutput,
3709
+ number,
3710
+ ITradingCallbacks.ValuesStructOutput,
3711
+ BigNumber
3712
+ ] & {
3713
+ t: ITradingStorage.TradeStructOutput;
3714
+ cancelReason: number;
3715
+ v: ITradingCallbacks.ValuesStructOutput;
3716
+ priceImpactP: BigNumber;
3717
+ }>;
3718
+ validateTriggerOpenOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
3719
+ ITradingStorage.TradeStructOutput,
3720
+ number,
3721
+ BigNumber,
3722
+ BigNumber,
3723
+ boolean
3724
+ ] & {
3725
+ t: ITradingStorage.TradeStructOutput;
3726
+ cancelReason: number;
3727
+ priceImpactP: BigNumber;
3728
+ priceAfterImpact: BigNumber;
3729
+ exactExecution: boolean;
3730
+ }>;
3236
3731
  getAllBorrowingPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
3237
3732
  IBorrowingFees.BorrowingDataStructOutput[],
3238
3733
  IBorrowingFees.OpenInterestStructOutput[],
@@ -3286,6 +3781,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3286
3781
  handleTradeBorrowingCallback(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
3287
3782
  from?: PromiseOrValue<string>;
3288
3783
  }): Promise<ContractTransaction>;
3784
+ resetTradeBorrowingFees(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
3785
+ from?: PromiseOrValue<string>;
3786
+ }): Promise<ContractTransaction>;
3289
3787
  setBorrowingGroupParams(_collateralIndex: PromiseOrValue<BigNumberish>, _groupIndex: PromiseOrValue<BigNumberish>, _value: IBorrowingFees.BorrowingGroupParamsStruct, overrides?: Overrides & {
3290
3788
  from?: PromiseOrValue<string>;
3291
3789
  }): Promise<ContractTransaction>;
@@ -3310,21 +3808,21 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3310
3808
  }): Promise<ContractTransaction>;
3311
3809
  getChainlinkToken(overrides?: CallOverrides): Promise<[string]>;
3312
3810
  getCollateralFromUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _normalizedValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3313
- getCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPriceAggregator.UniV3PoolInfoStructOutput]>;
3811
+ getCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[IPriceAggregator.LiquidityPoolInfoStructOutput]>;
3314
3812
  getCollateralPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3315
3813
  getCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[string]>;
3316
3814
  getGnsPriceCollateralAddress(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[BigNumber]>;
3317
3815
  getGnsPriceCollateralIndex(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3318
3816
  getGnsPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3319
3817
  getLimitJobId(overrides?: CallOverrides): Promise<[string]>;
3320
- getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3818
+ getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3321
3819
  getLinkUsdPriceFeed(overrides?: CallOverrides): Promise<[string]>;
3322
3820
  getMarketJobId(overrides?: CallOverrides): Promise<[string]>;
3323
3821
  getMinAnswers(overrides?: CallOverrides): Promise<[number]>;
3324
3822
  getOracle(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[string]>;
3325
3823
  getOracles(overrides?: CallOverrides): Promise<[string[]]>;
3326
3824
  getPendingRequest(_id: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<[string]>;
3327
- getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3825
+ getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _tradeId: ITradingStorage.IdStruct, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3328
3826
  from?: PromiseOrValue<string>;
3329
3827
  }): Promise<ContractTransaction>;
3330
3828
  getPriceAggregatorOrder(_requestId: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<[IPriceAggregator.OrderStructOutput]>;
@@ -3332,7 +3830,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3332
3830
  getRequestCount(overrides?: CallOverrides): Promise<[BigNumber]>;
3333
3831
  getTwapInterval(overrides?: CallOverrides): Promise<[number]>;
3334
3832
  getUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3335
- initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralUniV3Pools: PromiseOrValue<string>[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: Overrides & {
3833
+ initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralLiquidityPools: IPriceAggregator.LiquidityPoolInputStruct[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: Overrides & {
3336
3834
  from?: PromiseOrValue<string>;
3337
3835
  }): Promise<ContractTransaction>;
3338
3836
  removeOracle(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
@@ -3347,7 +3845,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3347
3845
  setMarketJobId(_jobId: PromiseOrValue<BytesLike>, overrides?: Overrides & {
3348
3846
  from?: PromiseOrValue<string>;
3349
3847
  }): Promise<ContractTransaction>;
3350
- updateCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, _uniV3Pool: PromiseOrValue<string>, overrides?: Overrides & {
3848
+ updateCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, _liquidityPoolInput: IPriceAggregator.LiquidityPoolInputStruct, overrides?: Overrides & {
3351
3849
  from?: PromiseOrValue<string>;
3352
3850
  }): Promise<ContractTransaction>;
3353
3851
  updateCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, _value: PromiseOrValue<string>, overrides?: Overrides & {
@@ -3362,33 +3860,19 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3362
3860
  updateTwapInterval(_twapInterval: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3363
3861
  from?: PromiseOrValue<string>;
3364
3862
  }): Promise<ContractTransaction>;
3365
- copyAllState(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: Overrides & {
3366
- from?: PromiseOrValue<string>;
3367
- }): Promise<ContractTransaction>;
3368
- copyBorrowingFeesGroups(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3369
- from?: PromiseOrValue<string>;
3370
- }): Promise<ContractTransaction>;
3371
- copyBorrowingFeesPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3863
+ addOtcCollateralBalance(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3372
3864
  from?: PromiseOrValue<string>;
3373
3865
  }): Promise<ContractTransaction>;
3374
- copyLimits(_collateralIndex: PromiseOrValue<BigNumberish>, _maxIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3866
+ getOtcBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3867
+ getOtcConfig(overrides?: CallOverrides): Promise<[IOtc.OtcConfigStructOutput]>;
3868
+ getOtcRate(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[BigNumber]>;
3869
+ initializeOtc(_config: IOtc.OtcConfigStruct, overrides?: Overrides & {
3375
3870
  from?: PromiseOrValue<string>;
3376
3871
  }): Promise<ContractTransaction>;
3377
- copyPairOis(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3872
+ sellGnsForCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3378
3873
  from?: PromiseOrValue<string>;
3379
3874
  }): Promise<ContractTransaction>;
3380
- copyTraderDelegations(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: Overrides & {
3381
- from?: PromiseOrValue<string>;
3382
- }): Promise<ContractTransaction>;
3383
- copyTrades(_collateralIndex: PromiseOrValue<BigNumberish>, _maxPairIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3384
- from?: PromiseOrValue<string>;
3385
- }): Promise<ContractTransaction>;
3386
- getCollateralStageState(_collateralIndex: PromiseOrValue<BigNumberish>, _stage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[boolean]>;
3387
- getCollateralState(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[number, BigNumber, number]>;
3388
- markAsDone(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3389
- from?: PromiseOrValue<string>;
3390
- }): Promise<ContractTransaction>;
3391
- transferBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3875
+ updateOtcConfig(_config: IOtc.OtcConfigStruct, overrides?: Overrides & {
3392
3876
  from?: PromiseOrValue<string>;
3393
3877
  }): Promise<ContractTransaction>;
3394
3878
  };
@@ -3419,14 +3903,20 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3419
3903
  fees(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.FeeStructOutput>;
3420
3904
  feesCount(overrides?: CallOverrides): Promise<BigNumber>;
3421
3905
  getAllPairsRestrictedMaxLeverage(overrides?: CallOverrides): Promise<BigNumber[]>;
3906
+ getGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput>;
3907
+ getPairLiquidationParams(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput>;
3422
3908
  groups(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupStructOutput>;
3423
3909
  groupsCount(overrides?: CallOverrides): Promise<BigNumber>;
3910
+ initializeGroupLiquidationParams(_groupLiquidationParams: IPairsStorage.GroupLiquidationParamsStruct[], overrides?: Overrides & {
3911
+ from?: PromiseOrValue<string>;
3912
+ }): Promise<ContractTransaction>;
3424
3913
  isPairIndexListed(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<boolean>;
3425
3914
  isPairListed(_from: PromiseOrValue<string>, _to: PromiseOrValue<string>, overrides?: CallOverrides): Promise<boolean>;
3426
3915
  pairCloseFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3427
3916
  pairCustomMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3428
3917
  pairJob(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[string, string]>;
3429
3918
  pairMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3919
+ pairMinFeeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3430
3920
  pairMinLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3431
3921
  pairMinPositionSizeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3432
3922
  pairOpenFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
@@ -3440,6 +3930,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3440
3930
  IPairsStorage.FeeStructOutput
3441
3931
  ]>;
3442
3932
  pairsCount(overrides?: CallOverrides): Promise<BigNumber>;
3933
+ setGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, _params: IPairsStorage.GroupLiquidationParamsStruct, overrides?: Overrides & {
3934
+ from?: PromiseOrValue<string>;
3935
+ }): Promise<ContractTransaction>;
3443
3936
  setPairCustomMaxLeverages(_indices: PromiseOrValue<BigNumberish>[], _values: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
3444
3937
  from?: PromiseOrValue<string>;
3445
3938
  }): Promise<ContractTransaction>;
@@ -3520,7 +4013,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3520
4013
  updateTraderPoints(_trader: PromiseOrValue<string>, _volumeUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3521
4014
  from?: PromiseOrValue<string>;
3522
4015
  }): Promise<ContractTransaction>;
3523
- addPriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
4016
+ addPriceImpactOpenInterest(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, _oiDeltaCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, overrides?: Overrides & {
3524
4017
  from?: PromiseOrValue<string>;
3525
4018
  }): Promise<ContractTransaction>;
3526
4019
  getOiWindow(_windowsDuration: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _windowId: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPriceImpact.PairOiStructOutput>;
@@ -3528,18 +4021,22 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3528
4021
  getOiWindowsSettings(overrides?: CallOverrides): Promise<IPriceImpact.OiWindowsSettingsStructOutput>;
3529
4022
  getPairDepth(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPriceImpact.PairDepthStructOutput>;
3530
4023
  getPairDepths(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<IPriceImpact.PairDepthStructOutput[]>;
4024
+ getPairFactors(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<IPriceImpact.PairFactorsStructOutput[]>;
3531
4025
  getPriceImpactOi(_pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<BigNumber>;
3532
- getTradePriceImpact(_openPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
4026
+ getTradePriceImpact(_marketPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, _isPnlPositive: PromiseOrValue<boolean>, _open: PromiseOrValue<boolean>, _lastPosIncreaseBlock: PromiseOrValue<BigNumberish>, _contractsVersion: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
3533
4027
  BigNumber,
3534
4028
  BigNumber
3535
4029
  ] & {
3536
4030
  priceImpactP: BigNumber;
3537
4031
  priceAfterImpact: BigNumber;
3538
4032
  }>;
4033
+ initializePairFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
4034
+ from?: PromiseOrValue<string>;
4035
+ }): Promise<ContractTransaction>;
3539
4036
  initializePriceImpact(_windowsDuration: PromiseOrValue<BigNumberish>, _windowsCount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3540
4037
  from?: PromiseOrValue<string>;
3541
4038
  }): Promise<ContractTransaction>;
3542
- removePriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _addTs: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4039
+ setCumulativeFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
3543
4040
  from?: PromiseOrValue<string>;
3544
4041
  }): Promise<ContractTransaction>;
3545
4042
  setPairDepths(_indices: PromiseOrValue<BigNumberish>[], _depthsAboveUsd: PromiseOrValue<BigNumberish>[], _depthsBelowUsd: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
@@ -3551,6 +4048,12 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3551
4048
  setPriceImpactWindowsDuration(_newWindowsDuration: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3552
4049
  from?: PromiseOrValue<string>;
3553
4050
  }): Promise<ContractTransaction>;
4051
+ setProtectionCloseFactorBlocks(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
4052
+ from?: PromiseOrValue<string>;
4053
+ }): Promise<ContractTransaction>;
4054
+ setProtectionCloseFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
4055
+ from?: PromiseOrValue<string>;
4056
+ }): Promise<ContractTransaction>;
3554
4057
  addCollateral(_collateral: PromiseOrValue<string>, _gToken: PromiseOrValue<string>, overrides?: Overrides & {
3555
4058
  from?: PromiseOrValue<string>;
3556
4059
  }): Promise<ContractTransaction>;
@@ -3563,23 +4066,25 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3563
4066
  getAllPendingOrders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.PendingOrderStructOutput[]>;
3564
4067
  getAllTradeInfos(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.TradeInfoStructOutput[]>;
3565
4068
  getAllTrades(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.TradeStructOutput[]>;
4069
+ getAllTradesLiquidationParams(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput[]>;
3566
4070
  getCollateral(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.CollateralStructOutput>;
3567
4071
  getCollateralIndex(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<number>;
3568
4072
  getCollaterals(overrides?: CallOverrides): Promise<ITradingStorage.CollateralStructOutput[]>;
3569
4073
  getCollateralsCount(overrides?: CallOverrides): Promise<number>;
3570
4074
  getCounters(_trader: PromiseOrValue<string>, _type: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.CounterStructOutput>;
4075
+ getCurrentContractsVersion(overrides?: CallOverrides): Promise<number>;
3571
4076
  getGToken(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<string>;
3572
- getPendingOpenOrderType(_tradeType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<number>;
3573
4077
  getPendingOrder(_orderId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<ITradingStorage.PendingOrderStructOutput>;
3574
4078
  getPendingOrders(_user: PromiseOrValue<string>, overrides?: CallOverrides): Promise<ITradingStorage.PendingOrderStructOutput[]>;
3575
- getPnlPercent(_openPrice: PromiseOrValue<BigNumberish>, _currentPrice: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _leverage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3576
4079
  getTrade(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.TradeStructOutput>;
3577
4080
  getTradeInfo(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.TradeInfoStructOutput>;
3578
4081
  getTradeInfos(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<ITradingStorage.TradeInfoStructOutput[]>;
4082
+ getTradeLiquidationParams(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput>;
3579
4083
  getTradePendingOrderBlock(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3580
4084
  getTraderStored(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<boolean>;
3581
4085
  getTraders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<string[]>;
3582
4086
  getTrades(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<ITradingStorage.TradeStructOutput[]>;
4087
+ getTradesLiquidationParams(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput[]>;
3583
4088
  getTradingActivated(overrides?: CallOverrides): Promise<number>;
3584
4089
  initializeTradingStorage(_gns: PromiseOrValue<string>, _gnsStaking: PromiseOrValue<string>, _collaterals: PromiseOrValue<string>[], _gTokens: PromiseOrValue<string>[], overrides?: Overrides & {
3585
4090
  from?: PromiseOrValue<string>;
@@ -3604,6 +4109,12 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3604
4109
  updateTradeCollateralAmount(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3605
4110
  from?: PromiseOrValue<string>;
3606
4111
  }): Promise<ContractTransaction>;
4112
+ updateTradeMaxClosingSlippageP(_tradeId: ITradingStorage.IdStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4113
+ from?: PromiseOrValue<string>;
4114
+ }): Promise<ContractTransaction>;
4115
+ updateTradePosition(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, _leverage: PromiseOrValue<BigNumberish>, _openPrice: PromiseOrValue<BigNumberish>, _isPartialIncrease: PromiseOrValue<boolean>, overrides?: Overrides & {
4116
+ from?: PromiseOrValue<string>;
4117
+ }): Promise<ContractTransaction>;
3607
4118
  updateTradeSl(_tradeId: ITradingStorage.IdStruct, _newSl: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3608
4119
  from?: PromiseOrValue<string>;
3609
4120
  }): Promise<ContractTransaction>;
@@ -3631,10 +4142,13 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3631
4142
  cancelOpenOrder(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3632
4143
  from?: PromiseOrValue<string>;
3633
4144
  }): Promise<ContractTransaction>;
3634
- closeTradeMarket(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4145
+ cancelOrderAfterTimeout(_orderIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4146
+ from?: PromiseOrValue<string>;
4147
+ }): Promise<ContractTransaction>;
4148
+ closeTradeMarket(_index: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3635
4149
  from?: PromiseOrValue<string>;
3636
4150
  }): Promise<ContractTransaction>;
3637
- closeTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: Overrides & {
4151
+ decreasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3638
4152
  from?: PromiseOrValue<string>;
3639
4153
  }): Promise<ContractTransaction>;
3640
4154
  delegatedTradingAction(_trader: PromiseOrValue<string>, _callData: PromiseOrValue<BytesLike>, overrides?: Overrides & {
@@ -3644,6 +4158,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3644
4158
  getMarketOrdersTimeoutBlocks(overrides?: CallOverrides): Promise<number>;
3645
4159
  getTradingDelegate(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<string>;
3646
4160
  getWrappedNativeToken(overrides?: CallOverrides): Promise<string>;
4161
+ increasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4162
+ from?: PromiseOrValue<string>;
4163
+ }): Promise<ContractTransaction>;
3647
4164
  initializeTrading(_marketOrdersTimeoutBlocks: PromiseOrValue<BigNumberish>, _usersByPassTriggerLink: PromiseOrValue<string>[], overrides?: Overrides & {
3648
4165
  from?: PromiseOrValue<string>;
3649
4166
  }): Promise<ContractTransaction>;
@@ -3651,9 +4168,6 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3651
4168
  openTrade(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: Overrides & {
3652
4169
  from?: PromiseOrValue<string>;
3653
4170
  }): Promise<ContractTransaction>;
3654
- openTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: Overrides & {
3655
- from?: PromiseOrValue<string>;
3656
- }): Promise<ContractTransaction>;
3657
4171
  openTradeNative(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: PayableOverrides & {
3658
4172
  from?: PromiseOrValue<string>;
3659
4173
  }): Promise<ContractTransaction>;
@@ -3669,9 +4183,15 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3669
4183
  updateByPassTriggerLink(_users: PromiseOrValue<string>[], _shouldByPass: PromiseOrValue<boolean>[], overrides?: Overrides & {
3670
4184
  from?: PromiseOrValue<string>;
3671
4185
  }): Promise<ContractTransaction>;
4186
+ updateLeverage(_index: PromiseOrValue<BigNumberish>, _newLeverage: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4187
+ from?: PromiseOrValue<string>;
4188
+ }): Promise<ContractTransaction>;
3672
4189
  updateMarketOrdersTimeoutBlocks(_valueBlocks: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3673
4190
  from?: PromiseOrValue<string>;
3674
4191
  }): Promise<ContractTransaction>;
4192
+ updateMaxClosingSlippageP(_index: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4193
+ from?: PromiseOrValue<string>;
4194
+ }): Promise<ContractTransaction>;
3675
4195
  updateOpenOrder(_index: PromiseOrValue<BigNumberish>, _triggerPrice: PromiseOrValue<BigNumberish>, _tp: PromiseOrValue<BigNumberish>, _sl: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3676
4196
  from?: PromiseOrValue<string>;
3677
4197
  }): Promise<ContractTransaction>;
@@ -3687,6 +4207,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3687
4207
  closeTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
3688
4208
  from?: PromiseOrValue<string>;
3689
4209
  }): Promise<ContractTransaction>;
4210
+ decreasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
4211
+ from?: PromiseOrValue<string>;
4212
+ }): Promise<ContractTransaction>;
3690
4213
  executeTriggerCloseOrderCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
3691
4214
  from?: PromiseOrValue<string>;
3692
4215
  }): Promise<ContractTransaction>;
@@ -3695,15 +4218,45 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3695
4218
  }): Promise<ContractTransaction>;
3696
4219
  getPendingGovFeesCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3697
4220
  getVaultClosingFeeP(overrides?: CallOverrides): Promise<number>;
4221
+ increasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
4222
+ from?: PromiseOrValue<string>;
4223
+ }): Promise<ContractTransaction>;
3698
4224
  initializeCallbacks(_vaultClosingFeeP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3699
4225
  from?: PromiseOrValue<string>;
3700
4226
  }): Promise<ContractTransaction>;
3701
4227
  openTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
3702
4228
  from?: PromiseOrValue<string>;
3703
4229
  }): Promise<ContractTransaction>;
4230
+ updateLeverageCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
4231
+ from?: PromiseOrValue<string>;
4232
+ }): Promise<ContractTransaction>;
3704
4233
  updateVaultClosingFeeP(_valueP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3705
4234
  from?: PromiseOrValue<string>;
3706
4235
  }): Promise<ContractTransaction>;
4236
+ validateTriggerCloseOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
4237
+ ITradingStorage.TradeStructOutput,
4238
+ number,
4239
+ ITradingCallbacks.ValuesStructOutput,
4240
+ BigNumber
4241
+ ] & {
4242
+ t: ITradingStorage.TradeStructOutput;
4243
+ cancelReason: number;
4244
+ v: ITradingCallbacks.ValuesStructOutput;
4245
+ priceImpactP: BigNumber;
4246
+ }>;
4247
+ validateTriggerOpenOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
4248
+ ITradingStorage.TradeStructOutput,
4249
+ number,
4250
+ BigNumber,
4251
+ BigNumber,
4252
+ boolean
4253
+ ] & {
4254
+ t: ITradingStorage.TradeStructOutput;
4255
+ cancelReason: number;
4256
+ priceImpactP: BigNumber;
4257
+ priceAfterImpact: BigNumber;
4258
+ exactExecution: boolean;
4259
+ }>;
3707
4260
  getAllBorrowingPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
3708
4261
  IBorrowingFees.BorrowingDataStructOutput[],
3709
4262
  IBorrowingFees.OpenInterestStructOutput[],
@@ -3753,6 +4306,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3753
4306
  handleTradeBorrowingCallback(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
3754
4307
  from?: PromiseOrValue<string>;
3755
4308
  }): Promise<ContractTransaction>;
4309
+ resetTradeBorrowingFees(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
4310
+ from?: PromiseOrValue<string>;
4311
+ }): Promise<ContractTransaction>;
3756
4312
  setBorrowingGroupParams(_collateralIndex: PromiseOrValue<BigNumberish>, _groupIndex: PromiseOrValue<BigNumberish>, _value: IBorrowingFees.BorrowingGroupParamsStruct, overrides?: Overrides & {
3757
4313
  from?: PromiseOrValue<string>;
3758
4314
  }): Promise<ContractTransaction>;
@@ -3777,21 +4333,21 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3777
4333
  }): Promise<ContractTransaction>;
3778
4334
  getChainlinkToken(overrides?: CallOverrides): Promise<string>;
3779
4335
  getCollateralFromUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _normalizedValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3780
- getCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPriceAggregator.UniV3PoolInfoStructOutput>;
4336
+ getCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPriceAggregator.LiquidityPoolInfoStructOutput>;
3781
4337
  getCollateralPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3782
4338
  getCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<string>;
3783
4339
  getGnsPriceCollateralAddress(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
3784
4340
  getGnsPriceCollateralIndex(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3785
4341
  getGnsPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3786
4342
  getLimitJobId(overrides?: CallOverrides): Promise<string>;
3787
- getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4343
+ getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3788
4344
  getLinkUsdPriceFeed(overrides?: CallOverrides): Promise<string>;
3789
4345
  getMarketJobId(overrides?: CallOverrides): Promise<string>;
3790
4346
  getMinAnswers(overrides?: CallOverrides): Promise<number>;
3791
4347
  getOracle(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<string>;
3792
4348
  getOracles(overrides?: CallOverrides): Promise<string[]>;
3793
4349
  getPendingRequest(_id: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<string>;
3794
- getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4350
+ getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _tradeId: ITradingStorage.IdStruct, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3795
4351
  from?: PromiseOrValue<string>;
3796
4352
  }): Promise<ContractTransaction>;
3797
4353
  getPriceAggregatorOrder(_requestId: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<IPriceAggregator.OrderStructOutput>;
@@ -3799,7 +4355,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3799
4355
  getRequestCount(overrides?: CallOverrides): Promise<BigNumber>;
3800
4356
  getTwapInterval(overrides?: CallOverrides): Promise<number>;
3801
4357
  getUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3802
- initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralUniV3Pools: PromiseOrValue<string>[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: Overrides & {
4358
+ initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralLiquidityPools: IPriceAggregator.LiquidityPoolInputStruct[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: Overrides & {
3803
4359
  from?: PromiseOrValue<string>;
3804
4360
  }): Promise<ContractTransaction>;
3805
4361
  removeOracle(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
@@ -3814,7 +4370,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3814
4370
  setMarketJobId(_jobId: PromiseOrValue<BytesLike>, overrides?: Overrides & {
3815
4371
  from?: PromiseOrValue<string>;
3816
4372
  }): Promise<ContractTransaction>;
3817
- updateCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, _uniV3Pool: PromiseOrValue<string>, overrides?: Overrides & {
4373
+ updateCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, _liquidityPoolInput: IPriceAggregator.LiquidityPoolInputStruct, overrides?: Overrides & {
3818
4374
  from?: PromiseOrValue<string>;
3819
4375
  }): Promise<ContractTransaction>;
3820
4376
  updateCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, _value: PromiseOrValue<string>, overrides?: Overrides & {
@@ -3829,33 +4385,19 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3829
4385
  updateTwapInterval(_twapInterval: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3830
4386
  from?: PromiseOrValue<string>;
3831
4387
  }): Promise<ContractTransaction>;
3832
- copyAllState(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: Overrides & {
3833
- from?: PromiseOrValue<string>;
3834
- }): Promise<ContractTransaction>;
3835
- copyBorrowingFeesGroups(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3836
- from?: PromiseOrValue<string>;
3837
- }): Promise<ContractTransaction>;
3838
- copyBorrowingFeesPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4388
+ addOtcCollateralBalance(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3839
4389
  from?: PromiseOrValue<string>;
3840
4390
  }): Promise<ContractTransaction>;
3841
- copyLimits(_collateralIndex: PromiseOrValue<BigNumberish>, _maxIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4391
+ getOtcBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4392
+ getOtcConfig(overrides?: CallOverrides): Promise<IOtc.OtcConfigStructOutput>;
4393
+ getOtcRate(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4394
+ initializeOtc(_config: IOtc.OtcConfigStruct, overrides?: Overrides & {
3842
4395
  from?: PromiseOrValue<string>;
3843
4396
  }): Promise<ContractTransaction>;
3844
- copyPairOis(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4397
+ sellGnsForCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3845
4398
  from?: PromiseOrValue<string>;
3846
4399
  }): Promise<ContractTransaction>;
3847
- copyTraderDelegations(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: Overrides & {
3848
- from?: PromiseOrValue<string>;
3849
- }): Promise<ContractTransaction>;
3850
- copyTrades(_collateralIndex: PromiseOrValue<BigNumberish>, _maxPairIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3851
- from?: PromiseOrValue<string>;
3852
- }): Promise<ContractTransaction>;
3853
- getCollateralStageState(_collateralIndex: PromiseOrValue<BigNumberish>, _stage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<boolean>;
3854
- getCollateralState(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[number, BigNumber, number]>;
3855
- markAsDone(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
3856
- from?: PromiseOrValue<string>;
3857
- }): Promise<ContractTransaction>;
3858
- transferBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4400
+ updateOtcConfig(_config: IOtc.OtcConfigStruct, overrides?: Overrides & {
3859
4401
  from?: PromiseOrValue<string>;
3860
4402
  }): Promise<ContractTransaction>;
3861
4403
  callStatic: {
@@ -3874,14 +4416,18 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3874
4416
  fees(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.FeeStructOutput>;
3875
4417
  feesCount(overrides?: CallOverrides): Promise<BigNumber>;
3876
4418
  getAllPairsRestrictedMaxLeverage(overrides?: CallOverrides): Promise<BigNumber[]>;
4419
+ getGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput>;
4420
+ getPairLiquidationParams(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput>;
3877
4421
  groups(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupStructOutput>;
3878
4422
  groupsCount(overrides?: CallOverrides): Promise<BigNumber>;
4423
+ initializeGroupLiquidationParams(_groupLiquidationParams: IPairsStorage.GroupLiquidationParamsStruct[], overrides?: CallOverrides): Promise<void>;
3879
4424
  isPairIndexListed(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<boolean>;
3880
4425
  isPairListed(_from: PromiseOrValue<string>, _to: PromiseOrValue<string>, overrides?: CallOverrides): Promise<boolean>;
3881
4426
  pairCloseFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3882
4427
  pairCustomMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3883
4428
  pairJob(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[string, string]>;
3884
4429
  pairMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4430
+ pairMinFeeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3885
4431
  pairMinLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3886
4432
  pairMinPositionSizeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3887
4433
  pairOpenFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
@@ -3895,6 +4441,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3895
4441
  IPairsStorage.FeeStructOutput
3896
4442
  ]>;
3897
4443
  pairsCount(overrides?: CallOverrides): Promise<BigNumber>;
4444
+ setGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, _params: IPairsStorage.GroupLiquidationParamsStruct, overrides?: CallOverrides): Promise<void>;
3898
4445
  setPairCustomMaxLeverages(_indices: PromiseOrValue<BigNumberish>[], _values: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<void>;
3899
4446
  updateFees(_ids: PromiseOrValue<BigNumberish>[], _fees: IPairsStorage.FeeStruct[], overrides?: CallOverrides): Promise<void>;
3900
4447
  updateGroups(_ids: PromiseOrValue<BigNumberish>[], _groups: IPairsStorage.GroupStruct[], overrides?: CallOverrides): Promise<void>;
@@ -3933,48 +4480,54 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3933
4480
  setFeeTiers(_feeTiersIndices: PromiseOrValue<BigNumberish>[], _feeTiers: IFeeTiers.FeeTierStruct[], overrides?: CallOverrides): Promise<void>;
3934
4481
  setGroupVolumeMultipliers(_groupIndices: PromiseOrValue<BigNumberish>[], _groupVolumeMultipliers: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<void>;
3935
4482
  updateTraderPoints(_trader: PromiseOrValue<string>, _volumeUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
3936
- addPriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<void>;
4483
+ addPriceImpactOpenInterest(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, _oiDeltaCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<void>;
3937
4484
  getOiWindow(_windowsDuration: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _windowId: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPriceImpact.PairOiStructOutput>;
3938
4485
  getOiWindows(_windowsDuration: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _windowIds: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<IPriceImpact.PairOiStructOutput[]>;
3939
4486
  getOiWindowsSettings(overrides?: CallOverrides): Promise<IPriceImpact.OiWindowsSettingsStructOutput>;
3940
4487
  getPairDepth(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPriceImpact.PairDepthStructOutput>;
3941
4488
  getPairDepths(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<IPriceImpact.PairDepthStructOutput[]>;
4489
+ getPairFactors(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<IPriceImpact.PairFactorsStructOutput[]>;
3942
4490
  getPriceImpactOi(_pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<BigNumber>;
3943
- getTradePriceImpact(_openPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
4491
+ getTradePriceImpact(_marketPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, _isPnlPositive: PromiseOrValue<boolean>, _open: PromiseOrValue<boolean>, _lastPosIncreaseBlock: PromiseOrValue<BigNumberish>, _contractsVersion: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
3944
4492
  BigNumber,
3945
4493
  BigNumber
3946
4494
  ] & {
3947
4495
  priceImpactP: BigNumber;
3948
4496
  priceAfterImpact: BigNumber;
3949
4497
  }>;
4498
+ initializePairFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<void>;
3950
4499
  initializePriceImpact(_windowsDuration: PromiseOrValue<BigNumberish>, _windowsCount: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
3951
- removePriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _addTs: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4500
+ setCumulativeFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<void>;
3952
4501
  setPairDepths(_indices: PromiseOrValue<BigNumberish>[], _depthsAboveUsd: PromiseOrValue<BigNumberish>[], _depthsBelowUsd: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<void>;
3953
4502
  setPriceImpactWindowsCount(_newWindowsCount: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
3954
4503
  setPriceImpactWindowsDuration(_newWindowsDuration: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4504
+ setProtectionCloseFactorBlocks(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<void>;
4505
+ setProtectionCloseFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<void>;
3955
4506
  addCollateral(_collateral: PromiseOrValue<string>, _gToken: PromiseOrValue<string>, overrides?: CallOverrides): Promise<void>;
3956
4507
  closePendingOrder(_orderId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<void>;
3957
4508
  closeTrade(_tradeId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<void>;
3958
4509
  getAllPendingOrders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.PendingOrderStructOutput[]>;
3959
4510
  getAllTradeInfos(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.TradeInfoStructOutput[]>;
3960
4511
  getAllTrades(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.TradeStructOutput[]>;
4512
+ getAllTradesLiquidationParams(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput[]>;
3961
4513
  getCollateral(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.CollateralStructOutput>;
3962
4514
  getCollateralIndex(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<number>;
3963
4515
  getCollaterals(overrides?: CallOverrides): Promise<ITradingStorage.CollateralStructOutput[]>;
3964
4516
  getCollateralsCount(overrides?: CallOverrides): Promise<number>;
3965
4517
  getCounters(_trader: PromiseOrValue<string>, _type: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.CounterStructOutput>;
4518
+ getCurrentContractsVersion(overrides?: CallOverrides): Promise<number>;
3966
4519
  getGToken(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<string>;
3967
- getPendingOpenOrderType(_tradeType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<number>;
3968
4520
  getPendingOrder(_orderId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<ITradingStorage.PendingOrderStructOutput>;
3969
4521
  getPendingOrders(_user: PromiseOrValue<string>, overrides?: CallOverrides): Promise<ITradingStorage.PendingOrderStructOutput[]>;
3970
- getPnlPercent(_openPrice: PromiseOrValue<BigNumberish>, _currentPrice: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _leverage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3971
4522
  getTrade(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.TradeStructOutput>;
3972
4523
  getTradeInfo(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<ITradingStorage.TradeInfoStructOutput>;
3973
4524
  getTradeInfos(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<ITradingStorage.TradeInfoStructOutput[]>;
4525
+ getTradeLiquidationParams(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput>;
3974
4526
  getTradePendingOrderBlock(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
3975
4527
  getTraderStored(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<boolean>;
3976
4528
  getTraders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<string[]>;
3977
4529
  getTrades(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<ITradingStorage.TradeStructOutput[]>;
4530
+ getTradesLiquidationParams(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<IPairsStorage.GroupLiquidationParamsStructOutput[]>;
3978
4531
  getTradingActivated(overrides?: CallOverrides): Promise<number>;
3979
4532
  initializeTradingStorage(_gns: PromiseOrValue<string>, _gnsStaking: PromiseOrValue<string>, _collaterals: PromiseOrValue<string>[], _gTokens: PromiseOrValue<string>[], overrides?: CallOverrides): Promise<void>;
3980
4533
  isCollateralActive(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<boolean>;
@@ -3985,6 +4538,8 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3985
4538
  updateGToken(_collateral: PromiseOrValue<string>, _gToken: PromiseOrValue<string>, overrides?: CallOverrides): Promise<void>;
3986
4539
  updateOpenOrderDetails(_tradeId: ITradingStorage.IdStruct, _openPrice: PromiseOrValue<BigNumberish>, _tp: PromiseOrValue<BigNumberish>, _sl: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
3987
4540
  updateTradeCollateralAmount(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4541
+ updateTradeMaxClosingSlippageP(_tradeId: ITradingStorage.IdStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4542
+ updateTradePosition(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, _leverage: PromiseOrValue<BigNumberish>, _openPrice: PromiseOrValue<BigNumberish>, _isPartialIncrease: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<void>;
3988
4543
  updateTradeSl(_tradeId: ITradingStorage.IdStruct, _newSl: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
3989
4544
  updateTradeTp(_tradeId: ITradingStorage.IdStruct, _newTp: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
3990
4545
  updateTradingActivated(_activated: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
@@ -3996,35 +4551,65 @@ export interface GNSMultiCollatDiamond extends BaseContract {
3996
4551
  initializeTriggerRewards(_timeoutBlocks: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
3997
4552
  updateTriggerTimeoutBlocks(_timeoutBlocks: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
3998
4553
  cancelOpenOrder(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
3999
- closeTradeMarket(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4000
- closeTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<void>;
4554
+ cancelOrderAfterTimeout(_orderIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4555
+ closeTradeMarket(_index: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4556
+ decreasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4001
4557
  delegatedTradingAction(_trader: PromiseOrValue<string>, _callData: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<string>;
4002
4558
  getByPassTriggerLink(_user: PromiseOrValue<string>, overrides?: CallOverrides): Promise<boolean>;
4003
4559
  getMarketOrdersTimeoutBlocks(overrides?: CallOverrides): Promise<number>;
4004
4560
  getTradingDelegate(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<string>;
4005
4561
  getWrappedNativeToken(overrides?: CallOverrides): Promise<string>;
4562
+ increasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4006
4563
  initializeTrading(_marketOrdersTimeoutBlocks: PromiseOrValue<BigNumberish>, _usersByPassTriggerLink: PromiseOrValue<string>[], overrides?: CallOverrides): Promise<void>;
4007
4564
  isWrappedNativeToken(_token: PromiseOrValue<string>, overrides?: CallOverrides): Promise<boolean>;
4008
4565
  openTrade(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: CallOverrides): Promise<void>;
4009
- openTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<void>;
4010
4566
  openTradeNative(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: CallOverrides): Promise<void>;
4011
4567
  removeTradingDelegate(overrides?: CallOverrides): Promise<void>;
4012
4568
  setTradingDelegate(_delegate: PromiseOrValue<string>, overrides?: CallOverrides): Promise<void>;
4013
4569
  triggerOrder(_packed: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4014
4570
  updateByPassTriggerLink(_users: PromiseOrValue<string>[], _shouldByPass: PromiseOrValue<boolean>[], overrides?: CallOverrides): Promise<void>;
4571
+ updateLeverage(_index: PromiseOrValue<BigNumberish>, _newLeverage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4015
4572
  updateMarketOrdersTimeoutBlocks(_valueBlocks: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4573
+ updateMaxClosingSlippageP(_index: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4016
4574
  updateOpenOrder(_index: PromiseOrValue<BigNumberish>, _triggerPrice: PromiseOrValue<BigNumberish>, _tp: PromiseOrValue<BigNumberish>, _sl: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4017
4575
  updateSl(_index: PromiseOrValue<BigNumberish>, _newSl: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4018
4576
  updateTp(_index: PromiseOrValue<BigNumberish>, _newTp: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4019
4577
  claimPendingGovFees(overrides?: CallOverrides): Promise<void>;
4020
4578
  closeTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: CallOverrides): Promise<void>;
4579
+ decreasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: CallOverrides): Promise<void>;
4021
4580
  executeTriggerCloseOrderCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: CallOverrides): Promise<void>;
4022
4581
  executeTriggerOpenOrderCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: CallOverrides): Promise<void>;
4023
4582
  getPendingGovFeesCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4024
4583
  getVaultClosingFeeP(overrides?: CallOverrides): Promise<number>;
4584
+ increasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: CallOverrides): Promise<void>;
4025
4585
  initializeCallbacks(_vaultClosingFeeP: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4026
4586
  openTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: CallOverrides): Promise<void>;
4587
+ updateLeverageCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: CallOverrides): Promise<void>;
4027
4588
  updateVaultClosingFeeP(_valueP: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4589
+ validateTriggerCloseOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
4590
+ ITradingStorage.TradeStructOutput,
4591
+ number,
4592
+ ITradingCallbacks.ValuesStructOutput,
4593
+ BigNumber
4594
+ ] & {
4595
+ t: ITradingStorage.TradeStructOutput;
4596
+ cancelReason: number;
4597
+ v: ITradingCallbacks.ValuesStructOutput;
4598
+ priceImpactP: BigNumber;
4599
+ }>;
4600
+ validateTriggerOpenOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
4601
+ ITradingStorage.TradeStructOutput,
4602
+ number,
4603
+ BigNumber,
4604
+ BigNumber,
4605
+ boolean
4606
+ ] & {
4607
+ t: ITradingStorage.TradeStructOutput;
4608
+ cancelReason: number;
4609
+ priceImpactP: BigNumber;
4610
+ priceAfterImpact: BigNumber;
4611
+ exactExecution: boolean;
4612
+ }>;
4028
4613
  getAllBorrowingPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[
4029
4614
  IBorrowingFees.BorrowingDataStructOutput[],
4030
4615
  IBorrowingFees.OpenInterestStructOutput[],
@@ -4072,6 +4657,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4072
4657
  getTradeBorrowingFee(_input: IBorrowingFees.BorrowingFeeInputStruct, overrides?: CallOverrides): Promise<BigNumber>;
4073
4658
  getTradeLiquidationPrice(_input: IBorrowingFees.LiqPriceInputStruct, overrides?: CallOverrides): Promise<BigNumber>;
4074
4659
  handleTradeBorrowingCallback(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, _long: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<void>;
4660
+ resetTradeBorrowingFees(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<void>;
4075
4661
  setBorrowingGroupParams(_collateralIndex: PromiseOrValue<BigNumberish>, _groupIndex: PromiseOrValue<BigNumberish>, _value: IBorrowingFees.BorrowingGroupParamsStruct, overrides?: CallOverrides): Promise<void>;
4076
4662
  setBorrowingGroupParamsArray(_collateralIndex: PromiseOrValue<BigNumberish>, _indices: PromiseOrValue<BigNumberish>[], _values: IBorrowingFees.BorrowingGroupParamsStruct[], overrides?: CallOverrides): Promise<void>;
4077
4663
  setBorrowingPairParams(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _value: IBorrowingFees.BorrowingPairParamsStruct, overrides?: CallOverrides): Promise<void>;
@@ -4082,47 +4668,43 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4082
4668
  fulfill(_requestId: PromiseOrValue<BytesLike>, _priceData: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4083
4669
  getChainlinkToken(overrides?: CallOverrides): Promise<string>;
4084
4670
  getCollateralFromUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _normalizedValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4085
- getCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPriceAggregator.UniV3PoolInfoStructOutput>;
4671
+ getCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<IPriceAggregator.LiquidityPoolInfoStructOutput>;
4086
4672
  getCollateralPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4087
4673
  getCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<string>;
4088
4674
  getGnsPriceCollateralAddress(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
4089
4675
  getGnsPriceCollateralIndex(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4090
4676
  getGnsPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4091
4677
  getLimitJobId(overrides?: CallOverrides): Promise<string>;
4092
- getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4678
+ getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4093
4679
  getLinkUsdPriceFeed(overrides?: CallOverrides): Promise<string>;
4094
4680
  getMarketJobId(overrides?: CallOverrides): Promise<string>;
4095
4681
  getMinAnswers(overrides?: CallOverrides): Promise<number>;
4096
4682
  getOracle(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<string>;
4097
4683
  getOracles(overrides?: CallOverrides): Promise<string[]>;
4098
4684
  getPendingRequest(_id: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<string>;
4099
- getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4685
+ getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _tradeId: ITradingStorage.IdStruct, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4100
4686
  getPriceAggregatorOrder(_requestId: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<IPriceAggregator.OrderStructOutput>;
4101
4687
  getPriceAggregatorOrderAnswers(_orderId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<IPriceAggregator.OrderAnswerStructOutput[]>;
4102
4688
  getRequestCount(overrides?: CallOverrides): Promise<BigNumber>;
4103
4689
  getTwapInterval(overrides?: CallOverrides): Promise<number>;
4104
4690
  getUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4105
- initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralUniV3Pools: PromiseOrValue<string>[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: CallOverrides): Promise<void>;
4691
+ initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralLiquidityPools: IPriceAggregator.LiquidityPoolInputStruct[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: CallOverrides): Promise<void>;
4106
4692
  removeOracle(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4107
4693
  replaceOracle(_index: PromiseOrValue<BigNumberish>, _a: PromiseOrValue<string>, overrides?: CallOverrides): Promise<void>;
4108
4694
  setLimitJobId(_jobId: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<void>;
4109
4695
  setMarketJobId(_jobId: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<void>;
4110
- updateCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, _uniV3Pool: PromiseOrValue<string>, overrides?: CallOverrides): Promise<void>;
4696
+ updateCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, _liquidityPoolInput: IPriceAggregator.LiquidityPoolInputStruct, overrides?: CallOverrides): Promise<void>;
4111
4697
  updateCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, _value: PromiseOrValue<string>, overrides?: CallOverrides): Promise<void>;
4112
4698
  updateLinkUsdPriceFeed(_value: PromiseOrValue<string>, overrides?: CallOverrides): Promise<void>;
4113
4699
  updateMinAnswers(_value: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4114
4700
  updateTwapInterval(_twapInterval: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4115
- copyAllState(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: CallOverrides): Promise<void>;
4116
- copyBorrowingFeesGroups(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4117
- copyBorrowingFeesPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4118
- copyLimits(_collateralIndex: PromiseOrValue<BigNumberish>, _maxIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4119
- copyPairOis(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4120
- copyTraderDelegations(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: CallOverrides): Promise<void>;
4121
- copyTrades(_collateralIndex: PromiseOrValue<BigNumberish>, _maxPairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4122
- getCollateralStageState(_collateralIndex: PromiseOrValue<BigNumberish>, _stage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<boolean>;
4123
- getCollateralState(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<[number, BigNumber, number]>;
4124
- markAsDone(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4125
- transferBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4701
+ addOtcCollateralBalance(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4702
+ getOtcBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4703
+ getOtcConfig(overrides?: CallOverrides): Promise<IOtc.OtcConfigStructOutput>;
4704
+ getOtcRate(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4705
+ initializeOtc(_config: IOtc.OtcConfigStruct, overrides?: CallOverrides): Promise<void>;
4706
+ sellGnsForCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<void>;
4707
+ updateOtcConfig(_config: IOtc.OtcConfigStruct, overrides?: CallOverrides): Promise<void>;
4126
4708
  };
4127
4709
  filters: {
4128
4710
  "AccessControlUpdated(address,uint8,bool)"(target?: null, role?: null, access?: null): AccessControlUpdatedEventFilter;
@@ -4139,6 +4721,8 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4139
4721
  FeeUpdated(index?: null): FeeUpdatedEventFilter;
4140
4722
  "GroupAdded(uint256,string)"(index?: null, name?: null): GroupAddedEventFilter;
4141
4723
  GroupAdded(index?: null, name?: null): GroupAddedEventFilter;
4724
+ "GroupLiquidationParamsUpdated(uint256,tuple)"(index?: null, params?: null): GroupLiquidationParamsUpdatedEventFilter;
4725
+ GroupLiquidationParamsUpdated(index?: null, params?: null): GroupLiquidationParamsUpdatedEventFilter;
4142
4726
  "GroupUpdated(uint256)"(index?: null): GroupUpdatedEventFilter;
4143
4727
  GroupUpdated(index?: null): GroupUpdatedEventFilter;
4144
4728
  "PairAdded(uint256,string,string)"(index?: null, from?: null, to?: null): PairAddedEventFilter;
@@ -4187,6 +4771,8 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4187
4771
  TraderInfoUpdated(trader?: PromiseOrValue<string> | null, traderInfo?: null): TraderInfoUpdatedEventFilter;
4188
4772
  "TraderTrailingPointsExpired(address,uint32,uint32,uint224)"(trader?: PromiseOrValue<string> | null, fromDay?: null, toDay?: null, expiredPoints?: null): TraderTrailingPointsExpiredEventFilter;
4189
4773
  TraderTrailingPointsExpired(trader?: PromiseOrValue<string> | null, fromDay?: null, toDay?: null, expiredPoints?: null): TraderTrailingPointsExpiredEventFilter;
4774
+ "CumulativeFactorUpdated(uint256,uint40)"(pairIndex?: PromiseOrValue<BigNumberish> | null, cumulativeFactor?: null): CumulativeFactorUpdatedEventFilter;
4775
+ CumulativeFactorUpdated(pairIndex?: PromiseOrValue<BigNumberish> | null, cumulativeFactor?: null): CumulativeFactorUpdatedEventFilter;
4190
4776
  "OiWindowsSettingsInitialized(uint48,uint48)"(windowsDuration?: PromiseOrValue<BigNumberish> | null, windowsCount?: PromiseOrValue<BigNumberish> | null): OiWindowsSettingsInitializedEventFilter;
4191
4777
  OiWindowsSettingsInitialized(windowsDuration?: PromiseOrValue<BigNumberish> | null, windowsCount?: PromiseOrValue<BigNumberish> | null): OiWindowsSettingsInitializedEventFilter;
4192
4778
  "OnePercentDepthUpdated(uint256,uint128,uint128)"(pairIndex?: PromiseOrValue<BigNumberish> | null, valueAboveUsd?: null, valueBelowUsd?: null): OnePercentDepthUpdatedEventFilter;
@@ -4197,12 +4783,14 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4197
4783
  PriceImpactOiTransferredPairs(pairsCount?: null, prevCurrentWindowId?: null, prevEarliestWindowId?: null, newCurrentWindowId?: null): PriceImpactOiTransferredPairsEventFilter;
4198
4784
  "PriceImpactOpenInterestAdded(tuple)"(oiWindowUpdate?: null): PriceImpactOpenInterestAddedEventFilter;
4199
4785
  PriceImpactOpenInterestAdded(oiWindowUpdate?: null): PriceImpactOpenInterestAddedEventFilter;
4200
- "PriceImpactOpenInterestRemoved(tuple,bool)"(oiWindowUpdate?: null, notOutdated?: null): PriceImpactOpenInterestRemovedEventFilter;
4201
- PriceImpactOpenInterestRemoved(oiWindowUpdate?: null, notOutdated?: null): PriceImpactOpenInterestRemovedEventFilter;
4202
4786
  "PriceImpactWindowsCountUpdated(uint48)"(windowsCount?: PromiseOrValue<BigNumberish> | null): PriceImpactWindowsCountUpdatedEventFilter;
4203
4787
  PriceImpactWindowsCountUpdated(windowsCount?: PromiseOrValue<BigNumberish> | null): PriceImpactWindowsCountUpdatedEventFilter;
4204
4788
  "PriceImpactWindowsDurationUpdated(uint48)"(windowsDuration?: PromiseOrValue<BigNumberish> | null): PriceImpactWindowsDurationUpdatedEventFilter;
4205
4789
  PriceImpactWindowsDurationUpdated(windowsDuration?: PromiseOrValue<BigNumberish> | null): PriceImpactWindowsDurationUpdatedEventFilter;
4790
+ "ProtectionCloseFactorBlocksUpdated(uint256,uint32)"(pairIndex?: PromiseOrValue<BigNumberish> | null, protectionCloseFactorBlocks?: null): ProtectionCloseFactorBlocksUpdatedEventFilter;
4791
+ ProtectionCloseFactorBlocksUpdated(pairIndex?: PromiseOrValue<BigNumberish> | null, protectionCloseFactorBlocks?: null): ProtectionCloseFactorBlocksUpdatedEventFilter;
4792
+ "ProtectionCloseFactorUpdated(uint256,uint40)"(pairIndex?: PromiseOrValue<BigNumberish> | null, protectionCloseFactor?: null): ProtectionCloseFactorUpdatedEventFilter;
4793
+ ProtectionCloseFactorUpdated(pairIndex?: PromiseOrValue<BigNumberish> | null, protectionCloseFactor?: null): ProtectionCloseFactorUpdatedEventFilter;
4206
4794
  "CollateralAdded(address,uint8,address)"(collateral?: null, index?: null, gToken?: null): CollateralAddedEventFilter;
4207
4795
  CollateralAdded(collateral?: null, index?: null, gToken?: null): CollateralAddedEventFilter;
4208
4796
  "CollateralDisabled(uint8)"(index?: null): CollateralDisabledEventFilter;
@@ -4221,10 +4809,14 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4221
4809
  TradeClosed(tradeId?: null): TradeClosedEventFilter;
4222
4810
  "TradeCollateralUpdated(tuple,uint120)"(tradeId?: null, collateralAmount?: null): TradeCollateralUpdatedEventFilter;
4223
4811
  TradeCollateralUpdated(tradeId?: null, collateralAmount?: null): TradeCollateralUpdatedEventFilter;
4812
+ "TradeMaxClosingSlippagePUpdated(tuple,uint16)"(tradeId?: null, maxClosingSlippageP?: null): TradeMaxClosingSlippagePUpdatedEventFilter;
4813
+ TradeMaxClosingSlippagePUpdated(tradeId?: null, maxClosingSlippageP?: null): TradeMaxClosingSlippagePUpdatedEventFilter;
4814
+ "TradePositionUpdated(tuple,uint120,uint24,uint64,uint64,uint64,bool)"(tradeId?: null, collateralAmount?: null, leverage?: null, openPrice?: null, newTp?: null, newSl?: null, isPartialIncrease?: null): TradePositionUpdatedEventFilter;
4815
+ TradePositionUpdated(tradeId?: null, collateralAmount?: null, leverage?: null, openPrice?: null, newTp?: null, newSl?: null, isPartialIncrease?: null): TradePositionUpdatedEventFilter;
4224
4816
  "TradeSlUpdated(tuple,uint64)"(tradeId?: null, newSl?: null): TradeSlUpdatedEventFilter;
4225
4817
  TradeSlUpdated(tradeId?: null, newSl?: null): TradeSlUpdatedEventFilter;
4226
- "TradeStored(tuple,tuple)"(trade?: null, tradeInfo?: null): TradeStoredEventFilter;
4227
- TradeStored(trade?: null, tradeInfo?: null): TradeStoredEventFilter;
4818
+ "TradeStored(tuple,tuple,tuple)"(trade?: null, tradeInfo?: null, liquidationParams?: null): TradeStoredEventFilter;
4819
+ TradeStored(trade?: null, tradeInfo?: null, liquidationParams?: null): TradeStoredEventFilter;
4228
4820
  "TradeTpUpdated(tuple,uint64)"(tradeId?: null, newTp?: null): TradeTpUpdatedEventFilter;
4229
4821
  TradeTpUpdated(tradeId?: null, newTp?: null): TradeTpUpdatedEventFilter;
4230
4822
  "TradingActivatedUpdated(uint8)"(activated?: null): TradingActivatedUpdatedEventFilter;
@@ -4241,6 +4833,10 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4241
4833
  ChainlinkCallbackTimeout(pendingOrderId?: null, pairIndex?: PromiseOrValue<BigNumberish> | null): ChainlinkCallbackTimeoutEventFilter;
4242
4834
  "CouldNotCloseTrade(address,uint16,uint32)"(trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null): CouldNotCloseTradeEventFilter;
4243
4835
  CouldNotCloseTrade(trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null): CouldNotCloseTradeEventFilter;
4836
+ "LeverageUpdateExecuted(tuple,bool,uint8,uint8,address,uint256,uint256,uint256,uint256,tuple)"(orderId?: null, isIncrease?: null, cancelReason?: null, collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, marketPrice?: null, collateralDelta?: null, values?: null): LeverageUpdateExecutedEventFilter;
4837
+ LeverageUpdateExecuted(orderId?: null, isIncrease?: null, cancelReason?: null, collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, marketPrice?: null, collateralDelta?: null, values?: null): LeverageUpdateExecutedEventFilter;
4838
+ "LeverageUpdateInitiated(tuple,address,uint256,uint256,bool,uint256)"(orderId?: null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, isIncrease?: null, newLeverage?: null): LeverageUpdateInitiatedEventFilter;
4839
+ LeverageUpdateInitiated(orderId?: null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, isIncrease?: null, newLeverage?: null): LeverageUpdateInitiatedEventFilter;
4244
4840
  "MarketOrderInitiated(tuple,address,uint16,bool)"(orderId?: null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, open?: null): MarketOrderInitiatedEventFilter;
4245
4841
  MarketOrderInitiated(orderId?: null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, open?: null): MarketOrderInitiatedEventFilter;
4246
4842
  "MarketOrdersTimeoutBlocksUpdated(uint256)"(newValueBlocks?: null): MarketOrdersTimeoutBlocksUpdatedEventFilter;
@@ -4253,6 +4849,12 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4253
4849
  OpenLimitUpdated(trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, newPrice?: null, newTp?: null, newSl?: null, maxSlippageP?: null): OpenLimitUpdatedEventFilter;
4254
4850
  "OpenOrderPlaced(address,uint16,uint32)"(trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null): OpenOrderPlacedEventFilter;
4255
4851
  OpenOrderPlaced(trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null): OpenOrderPlacedEventFilter;
4852
+ "PositionSizeDecreaseExecuted(tuple,uint8,uint8,address,uint256,uint256,bool,uint256,uint256,uint256,uint256,tuple)"(orderId?: null, cancelReason?: null, collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, long?: null, marketPrice?: null, collateralPriceUsd?: null, collateralDelta?: null, leverageDelta?: null, values?: null): PositionSizeDecreaseExecutedEventFilter;
4853
+ PositionSizeDecreaseExecuted(orderId?: null, cancelReason?: null, collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, long?: null, marketPrice?: null, collateralPriceUsd?: null, collateralDelta?: null, leverageDelta?: null, values?: null): PositionSizeDecreaseExecutedEventFilter;
4854
+ "PositionSizeIncreaseExecuted(tuple,uint8,uint8,address,uint256,uint256,bool,uint256,uint256,uint256,uint256,tuple)"(orderId?: null, cancelReason?: null, collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, long?: null, marketPrice?: null, collateralPriceUsd?: null, collateralDelta?: null, leverageDelta?: null, values?: null): PositionSizeIncreaseExecutedEventFilter;
4855
+ PositionSizeIncreaseExecuted(orderId?: null, cancelReason?: null, collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, long?: null, marketPrice?: null, collateralPriceUsd?: null, collateralDelta?: null, leverageDelta?: null, values?: null): PositionSizeIncreaseExecutedEventFilter;
4856
+ "PositionSizeUpdateInitiated(tuple,address,uint256,uint256,bool,uint256,uint256)"(orderId?: null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, isIncrease?: null, collateralDelta?: null, leverageDelta?: null): PositionSizeUpdateInitiatedEventFilter;
4857
+ PositionSizeUpdateInitiated(orderId?: null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, isIncrease?: null, collateralDelta?: null, leverageDelta?: null): PositionSizeUpdateInitiatedEventFilter;
4256
4858
  "TriggerOrderInitiated(tuple,address,uint16,bool)"(orderId?: null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, byPassesLinkCost?: null): TriggerOrderInitiatedEventFilter;
4257
4859
  TriggerOrderInitiated(orderId?: null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, byPassesLinkCost?: null): TriggerOrderInitiatedEventFilter;
4258
4860
  "BorrowingFeeCharged(address,uint8,uint256)"(trader?: PromiseOrValue<string> | null, collateralIndex?: PromiseOrValue<BigNumberish> | null, amountCollateral?: null): BorrowingFeeChargedEventFilter;
@@ -4287,8 +4889,8 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4287
4889
  BorrowingGroupOiUpdated(collateralIndex?: PromiseOrValue<BigNumberish> | null, groupIndex?: PromiseOrValue<BigNumberish> | null, long?: null, increase?: null, delta?: null, newOiLong?: null, newOiShort?: null): BorrowingGroupOiUpdatedEventFilter;
4288
4890
  "BorrowingGroupUpdated(uint8,uint16,uint32,uint72,uint48)"(collateralIndex?: PromiseOrValue<BigNumberish> | null, groupIndex?: PromiseOrValue<BigNumberish> | null, feePerBlock?: null, maxOi?: null, feeExponent?: null): BorrowingGroupUpdatedEventFilter;
4289
4891
  BorrowingGroupUpdated(collateralIndex?: PromiseOrValue<BigNumberish> | null, groupIndex?: PromiseOrValue<BigNumberish> | null, feePerBlock?: null, maxOi?: null, feeExponent?: null): BorrowingGroupUpdatedEventFilter;
4290
- "BorrowingInitialAccFeesStored(uint8,address,uint16,uint32,uint64,uint64)"(collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, initialPairAccFee?: null, initialGroupAccFee?: null): BorrowingInitialAccFeesStoredEventFilter;
4291
- BorrowingInitialAccFeesStored(collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, initialPairAccFee?: null, initialGroupAccFee?: null): BorrowingInitialAccFeesStoredEventFilter;
4892
+ "BorrowingInitialAccFeesStored(uint8,address,uint16,uint32,bool,uint64,uint64)"(collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, long?: null, initialPairAccFee?: null, initialGroupAccFee?: null): BorrowingInitialAccFeesStoredEventFilter;
4893
+ BorrowingInitialAccFeesStored(collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, long?: null, initialPairAccFee?: null, initialGroupAccFee?: null): BorrowingInitialAccFeesStoredEventFilter;
4292
4894
  "BorrowingPairAccFeesUpdated(uint8,uint16,uint256,uint64,uint64)"(collateralIndex?: PromiseOrValue<BigNumberish> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, currentBlock?: null, accFeeLong?: null, accFeeShort?: null): BorrowingPairAccFeesUpdatedEventFilter;
4293
4895
  BorrowingPairAccFeesUpdated(collateralIndex?: PromiseOrValue<BigNumberish> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, currentBlock?: null, accFeeLong?: null, accFeeShort?: null): BorrowingPairAccFeesUpdatedEventFilter;
4294
4896
  "BorrowingPairGroupUpdated(uint8,uint16,uint16,uint16)"(collateralIndex?: PromiseOrValue<BigNumberish> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, prevGroupIndex?: null, newGroupIndex?: null): BorrowingPairGroupUpdatedEventFilter;
@@ -4299,12 +4901,8 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4299
4901
  BorrowingPairParamsUpdated(collateralIndex?: PromiseOrValue<BigNumberish> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, groupIndex?: PromiseOrValue<BigNumberish> | null, feePerBlock?: null, feeExponent?: null, maxOi?: null): BorrowingPairParamsUpdatedEventFilter;
4300
4902
  "TradeBorrowingCallbackHandled(uint8,address,uint16,uint32,bool,bool,uint256)"(collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, open?: null, long?: null, positionSizeCollateral?: null): TradeBorrowingCallbackHandledEventFilter;
4301
4903
  TradeBorrowingCallbackHandled(collateralIndex?: PromiseOrValue<BigNumberish> | null, trader?: PromiseOrValue<string> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, index?: null, open?: null, long?: null, positionSizeCollateral?: null): TradeBorrowingCallbackHandledEventFilter;
4302
- "ChainlinkFulfilled(bytes32)"(id?: PromiseOrValue<BytesLike> | null): ChainlinkFulfilledEventFilter;
4303
- ChainlinkFulfilled(id?: PromiseOrValue<BytesLike> | null): ChainlinkFulfilledEventFilter;
4304
- "ChainlinkRequested(bytes32)"(id?: PromiseOrValue<BytesLike> | null): ChainlinkRequestedEventFilter;
4305
- ChainlinkRequested(id?: PromiseOrValue<BytesLike> | null): ChainlinkRequestedEventFilter;
4306
- "CollateralGnsUniV3PoolUpdated(uint8,tuple)"(collateralIndex?: null, newValue?: null): CollateralGnsUniV3PoolUpdatedEventFilter;
4307
- CollateralGnsUniV3PoolUpdated(collateralIndex?: null, newValue?: null): CollateralGnsUniV3PoolUpdatedEventFilter;
4904
+ "CollateralGnsLiquidityPoolUpdated(uint8,tuple)"(collateralIndex?: null, newValue?: null): CollateralGnsLiquidityPoolUpdatedEventFilter;
4905
+ CollateralGnsLiquidityPoolUpdated(collateralIndex?: null, newValue?: null): CollateralGnsLiquidityPoolUpdatedEventFilter;
4308
4906
  "CollateralUsdPriceFeedUpdated(uint8,address)"(collateralIndex?: null, value?: null): CollateralUsdPriceFeedUpdatedEventFilter;
4309
4907
  CollateralUsdPriceFeedUpdated(collateralIndex?: null, value?: null): CollateralUsdPriceFeedUpdatedEventFilter;
4310
4908
  "JobIdUpdated(uint256,bytes32)"(index?: null, jobId?: null): JobIdUpdatedEventFilter;
@@ -4325,34 +4923,18 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4325
4923
  OracleReplaced(index?: null, oldOracle?: null, newOracle?: null): OracleReplacedEventFilter;
4326
4924
  "PriceReceived(tuple,uint16,bytes32,uint256,bool,bool)"(orderId?: null, pairIndex?: PromiseOrValue<BigNumberish> | null, request?: null, priceData?: null, isLookback?: null, usedInMedian?: null): PriceReceivedEventFilter;
4327
4925
  PriceReceived(orderId?: null, pairIndex?: PromiseOrValue<BigNumberish> | null, request?: null, priceData?: null, isLookback?: null, usedInMedian?: null): PriceReceivedEventFilter;
4328
- "PriceRequested(uint8,tuple,uint8,uint256,bytes32,uint256,uint256,uint256,bool)"(collateralIndex?: null, pendingOrderId?: null, orderType?: PromiseOrValue<BigNumberish> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, job?: PromiseOrValue<BytesLike> | null, nodesCount?: null, linkFeePerNode?: null, fromBlock?: null, isLookback?: null): PriceRequestedEventFilter;
4329
- PriceRequested(collateralIndex?: null, pendingOrderId?: null, orderType?: PromiseOrValue<BigNumberish> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, job?: PromiseOrValue<BytesLike> | null, nodesCount?: null, linkFeePerNode?: null, fromBlock?: null, isLookback?: null): PriceRequestedEventFilter;
4926
+ "PriceRequested(uint8,uint256,tuple,tuple,uint8,uint256,bool,bytes32,uint256,uint256)"(collateralIndex?: PromiseOrValue<BigNumberish> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, tradeId?: null, pendingOrderId?: null, orderType?: null, fromBlock?: null, isLookback?: null, job?: null, linkFeePerNode?: null, nodesCount?: null): PriceRequestedEventFilter;
4927
+ PriceRequested(collateralIndex?: PromiseOrValue<BigNumberish> | null, pairIndex?: PromiseOrValue<BigNumberish> | null, tradeId?: null, pendingOrderId?: null, orderType?: null, fromBlock?: null, isLookback?: null, job?: null, linkFeePerNode?: null, nodesCount?: null): PriceRequestedEventFilter;
4330
4928
  "TradingCallbackExecuted(tuple,uint8)"(a?: null, orderType?: null): TradingCallbackExecutedEventFilter;
4331
4929
  TradingCallbackExecuted(a?: null, orderType?: null): TradingCallbackExecutedEventFilter;
4332
4930
  "TwapIntervalUpdated(uint32)"(newValue?: null): TwapIntervalUpdatedEventFilter;
4333
4931
  TwapIntervalUpdated(newValue?: null): TwapIntervalUpdatedEventFilter;
4334
- "BorrowingFeesGroupsCopied(uint8,uint16)"(collateralIndex?: null, groupsCount?: null): BorrowingFeesGroupsCopiedEventFilter;
4335
- BorrowingFeesGroupsCopied(collateralIndex?: null, groupsCount?: null): BorrowingFeesGroupsCopiedEventFilter;
4336
- "BorrowingFeesPairOisCopied(uint8,uint256)"(collateralIndex?: null, pairsCount?: null): BorrowingFeesPairOisCopiedEventFilter;
4337
- BorrowingFeesPairOisCopied(collateralIndex?: null, pairsCount?: null): BorrowingFeesPairOisCopiedEventFilter;
4338
- "BorrowingFeesPairsCopied(uint8,uint256)"(collateralIndex?: null, pairsCount?: null): BorrowingFeesPairsCopiedEventFilter;
4339
- BorrowingFeesPairsCopied(collateralIndex?: null, pairsCount?: null): BorrowingFeesPairsCopiedEventFilter;
4340
- "CollateralTransferred(uint8,uint256,uint256)"(collateralIndex?: null, balance?: null, govFees?: null): CollateralTransferredEventFilter;
4341
- CollateralTransferred(collateralIndex?: null, balance?: null, govFees?: null): CollateralTransferredEventFilter;
4342
- "LegacyLimitOrderSkipped(uint8,address,uint256,uint256)"(collateralIndex?: null, trader?: null, pairIndex?: null, index?: null): LegacyLimitOrderSkippedEventFilter;
4343
- LegacyLimitOrderSkipped(collateralIndex?: null, trader?: null, pairIndex?: null, index?: null): LegacyLimitOrderSkippedEventFilter;
4344
- "LimitsCopied(uint8,uint256,uint256)"(collateralIndex?: null, fromIndex?: null, toIndex?: null): LimitsCopiedEventFilter;
4345
- LimitsCopied(collateralIndex?: null, fromIndex?: null, toIndex?: null): LimitsCopiedEventFilter;
4346
- "MarkedAsDone(uint8)"(collateralIndex?: null): MarkedAsDoneEventFilter;
4347
- MarkedAsDone(collateralIndex?: null): MarkedAsDoneEventFilter;
4348
- "PairTradesCopied(uint8,uint256,uint256)"(collateralIndex?: null, pairIndex?: null, tradersCount?: null): PairTradesCopiedEventFilter;
4349
- PairTradesCopied(collateralIndex?: null, pairIndex?: null, tradersCount?: null): PairTradesCopiedEventFilter;
4350
- "TradeCopied(uint8,address,uint256,uint256,uint256)"(collateralIndex?: null, trader?: null, pairIndex?: null, prevIndex?: null, newIndex?: null): TradeCopiedEventFilter;
4351
- TradeCopied(collateralIndex?: null, trader?: null, pairIndex?: null, prevIndex?: null, newIndex?: null): TradeCopiedEventFilter;
4352
- "TraderDelegationsCopied(uint8,uint256)"(collateralIndex?: null, tradersCount?: null): TraderDelegationsCopiedEventFilter;
4353
- TraderDelegationsCopied(collateralIndex?: null, tradersCount?: null): TraderDelegationsCopiedEventFilter;
4354
- "TradesCopied(uint8,uint16,uint16)"(collateralIndex?: null, fromPairIndex?: null, toPairIndex?: null): TradesCopiedEventFilter;
4355
- TradesCopied(collateralIndex?: null, fromPairIndex?: null, toPairIndex?: null): TradesCopiedEventFilter;
4932
+ "OtcBalanceUpdated(uint8,uint256)"(collateralIndex?: PromiseOrValue<BigNumberish> | null, balanceCollateral?: null): OtcBalanceUpdatedEventFilter;
4933
+ OtcBalanceUpdated(collateralIndex?: PromiseOrValue<BigNumberish> | null, balanceCollateral?: null): OtcBalanceUpdatedEventFilter;
4934
+ "OtcConfigUpdated(tuple)"(config?: null): OtcConfigUpdatedEventFilter;
4935
+ OtcConfigUpdated(config?: null): OtcConfigUpdatedEventFilter;
4936
+ "OtcExecuted(uint8,uint256,uint256,uint256,uint256,uint256)"(collateralIndex?: PromiseOrValue<BigNumberish> | null, collateralAmount?: null, gnsPriceCollateral?: null, treasuryAmountGns?: null, stakingAmountGns?: null, burnAmountGns?: null): OtcExecutedEventFilter;
4937
+ OtcExecuted(collateralIndex?: PromiseOrValue<BigNumberish> | null, collateralAmount?: null, gnsPriceCollateral?: null, treasuryAmountGns?: null, stakingAmountGns?: null, burnAmountGns?: null): OtcExecutedEventFilter;
4356
4938
  };
4357
4939
  estimateGas: {
4358
4940
  diamondCut(_faceCut: IDiamondStorage.FacetCutStruct[], _init: PromiseOrValue<string>, _calldata: PromiseOrValue<BytesLike>, overrides?: Overrides & {
@@ -4382,14 +4964,20 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4382
4964
  fees(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4383
4965
  feesCount(overrides?: CallOverrides): Promise<BigNumber>;
4384
4966
  getAllPairsRestrictedMaxLeverage(overrides?: CallOverrides): Promise<BigNumber>;
4967
+ getGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4968
+ getPairLiquidationParams(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4385
4969
  groups(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4386
4970
  groupsCount(overrides?: CallOverrides): Promise<BigNumber>;
4971
+ initializeGroupLiquidationParams(_groupLiquidationParams: IPairsStorage.GroupLiquidationParamsStruct[], overrides?: Overrides & {
4972
+ from?: PromiseOrValue<string>;
4973
+ }): Promise<BigNumber>;
4387
4974
  isPairIndexListed(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4388
4975
  isPairListed(_from: PromiseOrValue<string>, _to: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
4389
4976
  pairCloseFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4390
4977
  pairCustomMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4391
4978
  pairJob(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4392
4979
  pairMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4980
+ pairMinFeeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4393
4981
  pairMinLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4394
4982
  pairMinPositionSizeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4395
4983
  pairOpenFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
@@ -4399,6 +4987,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4399
4987
  pairs(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4400
4988
  pairsBackend(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4401
4989
  pairsCount(overrides?: CallOverrides): Promise<BigNumber>;
4990
+ setGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, _params: IPairsStorage.GroupLiquidationParamsStruct, overrides?: Overrides & {
4991
+ from?: PromiseOrValue<string>;
4992
+ }): Promise<BigNumber>;
4402
4993
  setPairCustomMaxLeverages(_indices: PromiseOrValue<BigNumberish>[], _values: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
4403
4994
  from?: PromiseOrValue<string>;
4404
4995
  }): Promise<BigNumber>;
@@ -4479,7 +5070,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4479
5070
  updateTraderPoints(_trader: PromiseOrValue<string>, _volumeUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4480
5071
  from?: PromiseOrValue<string>;
4481
5072
  }): Promise<BigNumber>;
4482
- addPriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
5073
+ addPriceImpactOpenInterest(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, _oiDeltaCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, overrides?: Overrides & {
4483
5074
  from?: PromiseOrValue<string>;
4484
5075
  }): Promise<BigNumber>;
4485
5076
  getOiWindow(_windowsDuration: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _windowId: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
@@ -4487,12 +5078,16 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4487
5078
  getOiWindowsSettings(overrides?: CallOverrides): Promise<BigNumber>;
4488
5079
  getPairDepth(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4489
5080
  getPairDepths(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<BigNumber>;
5081
+ getPairFactors(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<BigNumber>;
4490
5082
  getPriceImpactOi(_pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<BigNumber>;
4491
- getTradePriceImpact(_openPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
5083
+ getTradePriceImpact(_marketPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, _isPnlPositive: PromiseOrValue<boolean>, _open: PromiseOrValue<boolean>, _lastPosIncreaseBlock: PromiseOrValue<BigNumberish>, _contractsVersion: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
5084
+ initializePairFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
5085
+ from?: PromiseOrValue<string>;
5086
+ }): Promise<BigNumber>;
4492
5087
  initializePriceImpact(_windowsDuration: PromiseOrValue<BigNumberish>, _windowsCount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4493
5088
  from?: PromiseOrValue<string>;
4494
5089
  }): Promise<BigNumber>;
4495
- removePriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _addTs: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5090
+ setCumulativeFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
4496
5091
  from?: PromiseOrValue<string>;
4497
5092
  }): Promise<BigNumber>;
4498
5093
  setPairDepths(_indices: PromiseOrValue<BigNumberish>[], _depthsAboveUsd: PromiseOrValue<BigNumberish>[], _depthsBelowUsd: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
@@ -4504,6 +5099,12 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4504
5099
  setPriceImpactWindowsDuration(_newWindowsDuration: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4505
5100
  from?: PromiseOrValue<string>;
4506
5101
  }): Promise<BigNumber>;
5102
+ setProtectionCloseFactorBlocks(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
5103
+ from?: PromiseOrValue<string>;
5104
+ }): Promise<BigNumber>;
5105
+ setProtectionCloseFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
5106
+ from?: PromiseOrValue<string>;
5107
+ }): Promise<BigNumber>;
4507
5108
  addCollateral(_collateral: PromiseOrValue<string>, _gToken: PromiseOrValue<string>, overrides?: Overrides & {
4508
5109
  from?: PromiseOrValue<string>;
4509
5110
  }): Promise<BigNumber>;
@@ -4516,23 +5117,25 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4516
5117
  getAllPendingOrders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4517
5118
  getAllTradeInfos(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4518
5119
  getAllTrades(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
5120
+ getAllTradesLiquidationParams(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4519
5121
  getCollateral(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4520
5122
  getCollateralIndex(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
4521
5123
  getCollaterals(overrides?: CallOverrides): Promise<BigNumber>;
4522
5124
  getCollateralsCount(overrides?: CallOverrides): Promise<BigNumber>;
4523
5125
  getCounters(_trader: PromiseOrValue<string>, _type: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
5126
+ getCurrentContractsVersion(overrides?: CallOverrides): Promise<BigNumber>;
4524
5127
  getGToken(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4525
- getPendingOpenOrderType(_tradeType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4526
5128
  getPendingOrder(_orderId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<BigNumber>;
4527
5129
  getPendingOrders(_user: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
4528
- getPnlPercent(_openPrice: PromiseOrValue<BigNumberish>, _currentPrice: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _leverage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4529
5130
  getTrade(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4530
5131
  getTradeInfo(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4531
5132
  getTradeInfos(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
5133
+ getTradeLiquidationParams(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4532
5134
  getTradePendingOrderBlock(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4533
5135
  getTraderStored(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
4534
5136
  getTraders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4535
5137
  getTrades(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
5138
+ getTradesLiquidationParams(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
4536
5139
  getTradingActivated(overrides?: CallOverrides): Promise<BigNumber>;
4537
5140
  initializeTradingStorage(_gns: PromiseOrValue<string>, _gnsStaking: PromiseOrValue<string>, _collaterals: PromiseOrValue<string>[], _gTokens: PromiseOrValue<string>[], overrides?: Overrides & {
4538
5141
  from?: PromiseOrValue<string>;
@@ -4557,6 +5160,12 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4557
5160
  updateTradeCollateralAmount(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4558
5161
  from?: PromiseOrValue<string>;
4559
5162
  }): Promise<BigNumber>;
5163
+ updateTradeMaxClosingSlippageP(_tradeId: ITradingStorage.IdStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5164
+ from?: PromiseOrValue<string>;
5165
+ }): Promise<BigNumber>;
5166
+ updateTradePosition(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, _leverage: PromiseOrValue<BigNumberish>, _openPrice: PromiseOrValue<BigNumberish>, _isPartialIncrease: PromiseOrValue<boolean>, overrides?: Overrides & {
5167
+ from?: PromiseOrValue<string>;
5168
+ }): Promise<BigNumber>;
4560
5169
  updateTradeSl(_tradeId: ITradingStorage.IdStruct, _newSl: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4561
5170
  from?: PromiseOrValue<string>;
4562
5171
  }): Promise<BigNumber>;
@@ -4584,10 +5193,13 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4584
5193
  cancelOpenOrder(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4585
5194
  from?: PromiseOrValue<string>;
4586
5195
  }): Promise<BigNumber>;
4587
- closeTradeMarket(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5196
+ cancelOrderAfterTimeout(_orderIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5197
+ from?: PromiseOrValue<string>;
5198
+ }): Promise<BigNumber>;
5199
+ closeTradeMarket(_index: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4588
5200
  from?: PromiseOrValue<string>;
4589
5201
  }): Promise<BigNumber>;
4590
- closeTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: Overrides & {
5202
+ decreasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4591
5203
  from?: PromiseOrValue<string>;
4592
5204
  }): Promise<BigNumber>;
4593
5205
  delegatedTradingAction(_trader: PromiseOrValue<string>, _callData: PromiseOrValue<BytesLike>, overrides?: Overrides & {
@@ -4597,6 +5209,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4597
5209
  getMarketOrdersTimeoutBlocks(overrides?: CallOverrides): Promise<BigNumber>;
4598
5210
  getTradingDelegate(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
4599
5211
  getWrappedNativeToken(overrides?: CallOverrides): Promise<BigNumber>;
5212
+ increasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5213
+ from?: PromiseOrValue<string>;
5214
+ }): Promise<BigNumber>;
4600
5215
  initializeTrading(_marketOrdersTimeoutBlocks: PromiseOrValue<BigNumberish>, _usersByPassTriggerLink: PromiseOrValue<string>[], overrides?: Overrides & {
4601
5216
  from?: PromiseOrValue<string>;
4602
5217
  }): Promise<BigNumber>;
@@ -4604,9 +5219,6 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4604
5219
  openTrade(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: Overrides & {
4605
5220
  from?: PromiseOrValue<string>;
4606
5221
  }): Promise<BigNumber>;
4607
- openTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: Overrides & {
4608
- from?: PromiseOrValue<string>;
4609
- }): Promise<BigNumber>;
4610
5222
  openTradeNative(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: PayableOverrides & {
4611
5223
  from?: PromiseOrValue<string>;
4612
5224
  }): Promise<BigNumber>;
@@ -4622,9 +5234,15 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4622
5234
  updateByPassTriggerLink(_users: PromiseOrValue<string>[], _shouldByPass: PromiseOrValue<boolean>[], overrides?: Overrides & {
4623
5235
  from?: PromiseOrValue<string>;
4624
5236
  }): Promise<BigNumber>;
5237
+ updateLeverage(_index: PromiseOrValue<BigNumberish>, _newLeverage: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5238
+ from?: PromiseOrValue<string>;
5239
+ }): Promise<BigNumber>;
4625
5240
  updateMarketOrdersTimeoutBlocks(_valueBlocks: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4626
5241
  from?: PromiseOrValue<string>;
4627
5242
  }): Promise<BigNumber>;
5243
+ updateMaxClosingSlippageP(_index: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5244
+ from?: PromiseOrValue<string>;
5245
+ }): Promise<BigNumber>;
4628
5246
  updateOpenOrder(_index: PromiseOrValue<BigNumberish>, _triggerPrice: PromiseOrValue<BigNumberish>, _tp: PromiseOrValue<BigNumberish>, _sl: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4629
5247
  from?: PromiseOrValue<string>;
4630
5248
  }): Promise<BigNumber>;
@@ -4640,6 +5258,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4640
5258
  closeTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
4641
5259
  from?: PromiseOrValue<string>;
4642
5260
  }): Promise<BigNumber>;
5261
+ decreasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
5262
+ from?: PromiseOrValue<string>;
5263
+ }): Promise<BigNumber>;
4643
5264
  executeTriggerCloseOrderCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
4644
5265
  from?: PromiseOrValue<string>;
4645
5266
  }): Promise<BigNumber>;
@@ -4648,15 +5269,23 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4648
5269
  }): Promise<BigNumber>;
4649
5270
  getPendingGovFeesCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4650
5271
  getVaultClosingFeeP(overrides?: CallOverrides): Promise<BigNumber>;
5272
+ increasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
5273
+ from?: PromiseOrValue<string>;
5274
+ }): Promise<BigNumber>;
4651
5275
  initializeCallbacks(_vaultClosingFeeP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4652
5276
  from?: PromiseOrValue<string>;
4653
5277
  }): Promise<BigNumber>;
4654
5278
  openTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
4655
5279
  from?: PromiseOrValue<string>;
4656
5280
  }): Promise<BigNumber>;
5281
+ updateLeverageCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
5282
+ from?: PromiseOrValue<string>;
5283
+ }): Promise<BigNumber>;
4657
5284
  updateVaultClosingFeeP(_valueP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4658
5285
  from?: PromiseOrValue<string>;
4659
5286
  }): Promise<BigNumber>;
5287
+ validateTriggerCloseOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
5288
+ validateTriggerOpenOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4660
5289
  getAllBorrowingPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4661
5290
  getBorrowingGroup(_collateralIndex: PromiseOrValue<BigNumberish>, _groupIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4662
5291
  getBorrowingGroupOi(_collateralIndex: PromiseOrValue<BigNumberish>, _groupIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
@@ -4677,6 +5306,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4677
5306
  handleTradeBorrowingCallback(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
4678
5307
  from?: PromiseOrValue<string>;
4679
5308
  }): Promise<BigNumber>;
5309
+ resetTradeBorrowingFees(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
5310
+ from?: PromiseOrValue<string>;
5311
+ }): Promise<BigNumber>;
4680
5312
  setBorrowingGroupParams(_collateralIndex: PromiseOrValue<BigNumberish>, _groupIndex: PromiseOrValue<BigNumberish>, _value: IBorrowingFees.BorrowingGroupParamsStruct, overrides?: Overrides & {
4681
5313
  from?: PromiseOrValue<string>;
4682
5314
  }): Promise<BigNumber>;
@@ -4701,21 +5333,21 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4701
5333
  }): Promise<BigNumber>;
4702
5334
  getChainlinkToken(overrides?: CallOverrides): Promise<BigNumber>;
4703
5335
  getCollateralFromUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _normalizedValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4704
- getCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
5336
+ getCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4705
5337
  getCollateralPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4706
5338
  getCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4707
5339
  getGnsPriceCollateralAddress(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
4708
5340
  getGnsPriceCollateralIndex(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4709
5341
  getGnsPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4710
5342
  getLimitJobId(overrides?: CallOverrides): Promise<BigNumber>;
4711
- getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
5343
+ getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4712
5344
  getLinkUsdPriceFeed(overrides?: CallOverrides): Promise<BigNumber>;
4713
5345
  getMarketJobId(overrides?: CallOverrides): Promise<BigNumber>;
4714
5346
  getMinAnswers(overrides?: CallOverrides): Promise<BigNumber>;
4715
5347
  getOracle(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4716
5348
  getOracles(overrides?: CallOverrides): Promise<BigNumber>;
4717
5349
  getPendingRequest(_id: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<BigNumber>;
4718
- getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5350
+ getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _tradeId: ITradingStorage.IdStruct, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4719
5351
  from?: PromiseOrValue<string>;
4720
5352
  }): Promise<BigNumber>;
4721
5353
  getPriceAggregatorOrder(_requestId: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<BigNumber>;
@@ -4723,7 +5355,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4723
5355
  getRequestCount(overrides?: CallOverrides): Promise<BigNumber>;
4724
5356
  getTwapInterval(overrides?: CallOverrides): Promise<BigNumber>;
4725
5357
  getUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4726
- initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralUniV3Pools: PromiseOrValue<string>[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: Overrides & {
5358
+ initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralLiquidityPools: IPriceAggregator.LiquidityPoolInputStruct[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: Overrides & {
4727
5359
  from?: PromiseOrValue<string>;
4728
5360
  }): Promise<BigNumber>;
4729
5361
  removeOracle(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
@@ -4738,7 +5370,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4738
5370
  setMarketJobId(_jobId: PromiseOrValue<BytesLike>, overrides?: Overrides & {
4739
5371
  from?: PromiseOrValue<string>;
4740
5372
  }): Promise<BigNumber>;
4741
- updateCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, _uniV3Pool: PromiseOrValue<string>, overrides?: Overrides & {
5373
+ updateCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, _liquidityPoolInput: IPriceAggregator.LiquidityPoolInputStruct, overrides?: Overrides & {
4742
5374
  from?: PromiseOrValue<string>;
4743
5375
  }): Promise<BigNumber>;
4744
5376
  updateCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, _value: PromiseOrValue<string>, overrides?: Overrides & {
@@ -4753,33 +5385,19 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4753
5385
  updateTwapInterval(_twapInterval: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4754
5386
  from?: PromiseOrValue<string>;
4755
5387
  }): Promise<BigNumber>;
4756
- copyAllState(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: Overrides & {
4757
- from?: PromiseOrValue<string>;
4758
- }): Promise<BigNumber>;
4759
- copyBorrowingFeesGroups(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4760
- from?: PromiseOrValue<string>;
4761
- }): Promise<BigNumber>;
4762
- copyBorrowingFeesPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4763
- from?: PromiseOrValue<string>;
4764
- }): Promise<BigNumber>;
4765
- copyLimits(_collateralIndex: PromiseOrValue<BigNumberish>, _maxIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4766
- from?: PromiseOrValue<string>;
4767
- }): Promise<BigNumber>;
4768
- copyPairOis(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4769
- from?: PromiseOrValue<string>;
4770
- }): Promise<BigNumber>;
4771
- copyTraderDelegations(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: Overrides & {
5388
+ addOtcCollateralBalance(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4772
5389
  from?: PromiseOrValue<string>;
4773
5390
  }): Promise<BigNumber>;
4774
- copyTrades(_collateralIndex: PromiseOrValue<BigNumberish>, _maxPairIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5391
+ getOtcBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
5392
+ getOtcConfig(overrides?: CallOverrides): Promise<BigNumber>;
5393
+ getOtcRate(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
5394
+ initializeOtc(_config: IOtc.OtcConfigStruct, overrides?: Overrides & {
4775
5395
  from?: PromiseOrValue<string>;
4776
5396
  }): Promise<BigNumber>;
4777
- getCollateralStageState(_collateralIndex: PromiseOrValue<BigNumberish>, _stage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4778
- getCollateralState(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<BigNumber>;
4779
- markAsDone(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5397
+ sellGnsForCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4780
5398
  from?: PromiseOrValue<string>;
4781
5399
  }): Promise<BigNumber>;
4782
- transferBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5400
+ updateOtcConfig(_config: IOtc.OtcConfigStruct, overrides?: Overrides & {
4783
5401
  from?: PromiseOrValue<string>;
4784
5402
  }): Promise<BigNumber>;
4785
5403
  };
@@ -4811,14 +5429,20 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4811
5429
  fees(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4812
5430
  feesCount(overrides?: CallOverrides): Promise<PopulatedTransaction>;
4813
5431
  getAllPairsRestrictedMaxLeverage(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5432
+ getGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5433
+ getPairLiquidationParams(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4814
5434
  groups(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4815
5435
  groupsCount(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5436
+ initializeGroupLiquidationParams(_groupLiquidationParams: IPairsStorage.GroupLiquidationParamsStruct[], overrides?: Overrides & {
5437
+ from?: PromiseOrValue<string>;
5438
+ }): Promise<PopulatedTransaction>;
4816
5439
  isPairIndexListed(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4817
5440
  isPairListed(_from: PromiseOrValue<string>, _to: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4818
5441
  pairCloseFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4819
5442
  pairCustomMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4820
5443
  pairJob(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4821
5444
  pairMaxLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5445
+ pairMinFeeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4822
5446
  pairMinLeverage(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4823
5447
  pairMinPositionSizeUsd(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4824
5448
  pairOpenFeeP(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
@@ -4828,6 +5452,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4828
5452
  pairs(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4829
5453
  pairsBackend(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4830
5454
  pairsCount(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5455
+ setGroupLiquidationParams(_groupIndex: PromiseOrValue<BigNumberish>, _params: IPairsStorage.GroupLiquidationParamsStruct, overrides?: Overrides & {
5456
+ from?: PromiseOrValue<string>;
5457
+ }): Promise<PopulatedTransaction>;
4831
5458
  setPairCustomMaxLeverages(_indices: PromiseOrValue<BigNumberish>[], _values: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
4832
5459
  from?: PromiseOrValue<string>;
4833
5460
  }): Promise<PopulatedTransaction>;
@@ -4908,7 +5535,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4908
5535
  updateTraderPoints(_trader: PromiseOrValue<string>, _volumeUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4909
5536
  from?: PromiseOrValue<string>;
4910
5537
  }): Promise<PopulatedTransaction>;
4911
- addPriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
5538
+ addPriceImpactOpenInterest(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, _oiDeltaCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, overrides?: Overrides & {
4912
5539
  from?: PromiseOrValue<string>;
4913
5540
  }): Promise<PopulatedTransaction>;
4914
5541
  getOiWindow(_windowsDuration: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _windowId: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
@@ -4916,12 +5543,16 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4916
5543
  getOiWindowsSettings(overrides?: CallOverrides): Promise<PopulatedTransaction>;
4917
5544
  getPairDepth(_pairIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4918
5545
  getPairDepths(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<PopulatedTransaction>;
5546
+ getPairFactors(_indices: PromiseOrValue<BigNumberish>[], overrides?: CallOverrides): Promise<PopulatedTransaction>;
4919
5547
  getPriceImpactOi(_pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4920
- getTradePriceImpact(_openPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5548
+ getTradePriceImpact(_marketPrice: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _tradeOpenInterestUsd: PromiseOrValue<BigNumberish>, _isPnlPositive: PromiseOrValue<boolean>, _open: PromiseOrValue<boolean>, _lastPosIncreaseBlock: PromiseOrValue<BigNumberish>, _contractsVersion: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5549
+ initializePairFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
5550
+ from?: PromiseOrValue<string>;
5551
+ }): Promise<PopulatedTransaction>;
4921
5552
  initializePriceImpact(_windowsDuration: PromiseOrValue<BigNumberish>, _windowsCount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4922
5553
  from?: PromiseOrValue<string>;
4923
5554
  }): Promise<PopulatedTransaction>;
4924
- removePriceImpactOpenInterest(_openInterestUsd: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _addTs: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5555
+ setCumulativeFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _cumulativeFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
4925
5556
  from?: PromiseOrValue<string>;
4926
5557
  }): Promise<PopulatedTransaction>;
4927
5558
  setPairDepths(_indices: PromiseOrValue<BigNumberish>[], _depthsAboveUsd: PromiseOrValue<BigNumberish>[], _depthsBelowUsd: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
@@ -4933,6 +5564,12 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4933
5564
  setPriceImpactWindowsDuration(_newWindowsDuration: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4934
5565
  from?: PromiseOrValue<string>;
4935
5566
  }): Promise<PopulatedTransaction>;
5567
+ setProtectionCloseFactorBlocks(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactorBlocks: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
5568
+ from?: PromiseOrValue<string>;
5569
+ }): Promise<PopulatedTransaction>;
5570
+ setProtectionCloseFactors(_pairIndices: PromiseOrValue<BigNumberish>[], _protectionCloseFactors: PromiseOrValue<BigNumberish>[], overrides?: Overrides & {
5571
+ from?: PromiseOrValue<string>;
5572
+ }): Promise<PopulatedTransaction>;
4936
5573
  addCollateral(_collateral: PromiseOrValue<string>, _gToken: PromiseOrValue<string>, overrides?: Overrides & {
4937
5574
  from?: PromiseOrValue<string>;
4938
5575
  }): Promise<PopulatedTransaction>;
@@ -4945,23 +5582,25 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4945
5582
  getAllPendingOrders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4946
5583
  getAllTradeInfos(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4947
5584
  getAllTrades(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5585
+ getAllTradesLiquidationParams(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4948
5586
  getCollateral(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4949
5587
  getCollateralIndex(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4950
5588
  getCollaterals(overrides?: CallOverrides): Promise<PopulatedTransaction>;
4951
5589
  getCollateralsCount(overrides?: CallOverrides): Promise<PopulatedTransaction>;
4952
5590
  getCounters(_trader: PromiseOrValue<string>, _type: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5591
+ getCurrentContractsVersion(overrides?: CallOverrides): Promise<PopulatedTransaction>;
4953
5592
  getGToken(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4954
- getPendingOpenOrderType(_tradeType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4955
5593
  getPendingOrder(_orderId: ITradingStorage.IdStruct, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4956
5594
  getPendingOrders(_user: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4957
- getPnlPercent(_openPrice: PromiseOrValue<BigNumberish>, _currentPrice: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, _leverage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4958
5595
  getTrade(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4959
5596
  getTradeInfo(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4960
5597
  getTradeInfos(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5598
+ getTradeLiquidationParams(_trader: PromiseOrValue<string>, _index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4961
5599
  getTradePendingOrderBlock(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4962
5600
  getTraderStored(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4963
5601
  getTraders(_offset: PromiseOrValue<BigNumberish>, _limit: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4964
5602
  getTrades(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5603
+ getTradesLiquidationParams(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
4965
5604
  getTradingActivated(overrides?: CallOverrides): Promise<PopulatedTransaction>;
4966
5605
  initializeTradingStorage(_gns: PromiseOrValue<string>, _gnsStaking: PromiseOrValue<string>, _collaterals: PromiseOrValue<string>[], _gTokens: PromiseOrValue<string>[], overrides?: Overrides & {
4967
5606
  from?: PromiseOrValue<string>;
@@ -4986,6 +5625,12 @@ export interface GNSMultiCollatDiamond extends BaseContract {
4986
5625
  updateTradeCollateralAmount(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4987
5626
  from?: PromiseOrValue<string>;
4988
5627
  }): Promise<PopulatedTransaction>;
5628
+ updateTradeMaxClosingSlippageP(_tradeId: ITradingStorage.IdStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5629
+ from?: PromiseOrValue<string>;
5630
+ }): Promise<PopulatedTransaction>;
5631
+ updateTradePosition(_tradeId: ITradingStorage.IdStruct, _collateralAmount: PromiseOrValue<BigNumberish>, _leverage: PromiseOrValue<BigNumberish>, _openPrice: PromiseOrValue<BigNumberish>, _isPartialIncrease: PromiseOrValue<boolean>, overrides?: Overrides & {
5632
+ from?: PromiseOrValue<string>;
5633
+ }): Promise<PopulatedTransaction>;
4989
5634
  updateTradeSl(_tradeId: ITradingStorage.IdStruct, _newSl: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
4990
5635
  from?: PromiseOrValue<string>;
4991
5636
  }): Promise<PopulatedTransaction>;
@@ -5013,10 +5658,13 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5013
5658
  cancelOpenOrder(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5014
5659
  from?: PromiseOrValue<string>;
5015
5660
  }): Promise<PopulatedTransaction>;
5016
- closeTradeMarket(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5661
+ cancelOrderAfterTimeout(_orderIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5662
+ from?: PromiseOrValue<string>;
5663
+ }): Promise<PopulatedTransaction>;
5664
+ closeTradeMarket(_index: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5017
5665
  from?: PromiseOrValue<string>;
5018
5666
  }): Promise<PopulatedTransaction>;
5019
- closeTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: Overrides & {
5667
+ decreasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5020
5668
  from?: PromiseOrValue<string>;
5021
5669
  }): Promise<PopulatedTransaction>;
5022
5670
  delegatedTradingAction(_trader: PromiseOrValue<string>, _callData: PromiseOrValue<BytesLike>, overrides?: Overrides & {
@@ -5026,6 +5674,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5026
5674
  getMarketOrdersTimeoutBlocks(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5027
5675
  getTradingDelegate(_trader: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5028
5676
  getWrappedNativeToken(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5677
+ increasePositionSize(_index: PromiseOrValue<BigNumberish>, _collateralDelta: PromiseOrValue<BigNumberish>, _leverageDelta: PromiseOrValue<BigNumberish>, _expectedPrice: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5678
+ from?: PromiseOrValue<string>;
5679
+ }): Promise<PopulatedTransaction>;
5029
5680
  initializeTrading(_marketOrdersTimeoutBlocks: PromiseOrValue<BigNumberish>, _usersByPassTriggerLink: PromiseOrValue<string>[], overrides?: Overrides & {
5030
5681
  from?: PromiseOrValue<string>;
5031
5682
  }): Promise<PopulatedTransaction>;
@@ -5033,9 +5684,6 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5033
5684
  openTrade(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: Overrides & {
5034
5685
  from?: PromiseOrValue<string>;
5035
5686
  }): Promise<PopulatedTransaction>;
5036
- openTradeMarketTimeout(_orderId: ITradingStorage.IdStruct, overrides?: Overrides & {
5037
- from?: PromiseOrValue<string>;
5038
- }): Promise<PopulatedTransaction>;
5039
5687
  openTradeNative(_trade: ITradingStorage.TradeStruct, _maxSlippageP: PromiseOrValue<BigNumberish>, _referrer: PromiseOrValue<string>, overrides?: PayableOverrides & {
5040
5688
  from?: PromiseOrValue<string>;
5041
5689
  }): Promise<PopulatedTransaction>;
@@ -5051,9 +5699,15 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5051
5699
  updateByPassTriggerLink(_users: PromiseOrValue<string>[], _shouldByPass: PromiseOrValue<boolean>[], overrides?: Overrides & {
5052
5700
  from?: PromiseOrValue<string>;
5053
5701
  }): Promise<PopulatedTransaction>;
5702
+ updateLeverage(_index: PromiseOrValue<BigNumberish>, _newLeverage: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5703
+ from?: PromiseOrValue<string>;
5704
+ }): Promise<PopulatedTransaction>;
5054
5705
  updateMarketOrdersTimeoutBlocks(_valueBlocks: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5055
5706
  from?: PromiseOrValue<string>;
5056
5707
  }): Promise<PopulatedTransaction>;
5708
+ updateMaxClosingSlippageP(_index: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5709
+ from?: PromiseOrValue<string>;
5710
+ }): Promise<PopulatedTransaction>;
5057
5711
  updateOpenOrder(_index: PromiseOrValue<BigNumberish>, _triggerPrice: PromiseOrValue<BigNumberish>, _tp: PromiseOrValue<BigNumberish>, _sl: PromiseOrValue<BigNumberish>, _maxSlippageP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5058
5712
  from?: PromiseOrValue<string>;
5059
5713
  }): Promise<PopulatedTransaction>;
@@ -5069,6 +5723,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5069
5723
  closeTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
5070
5724
  from?: PromiseOrValue<string>;
5071
5725
  }): Promise<PopulatedTransaction>;
5726
+ decreasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
5727
+ from?: PromiseOrValue<string>;
5728
+ }): Promise<PopulatedTransaction>;
5072
5729
  executeTriggerCloseOrderCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
5073
5730
  from?: PromiseOrValue<string>;
5074
5731
  }): Promise<PopulatedTransaction>;
@@ -5077,15 +5734,23 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5077
5734
  }): Promise<PopulatedTransaction>;
5078
5735
  getPendingGovFeesCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5079
5736
  getVaultClosingFeeP(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5737
+ increasePositionSizeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
5738
+ from?: PromiseOrValue<string>;
5739
+ }): Promise<PopulatedTransaction>;
5080
5740
  initializeCallbacks(_vaultClosingFeeP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5081
5741
  from?: PromiseOrValue<string>;
5082
5742
  }): Promise<PopulatedTransaction>;
5083
5743
  openTradeMarketCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
5084
5744
  from?: PromiseOrValue<string>;
5085
5745
  }): Promise<PopulatedTransaction>;
5746
+ updateLeverageCallback(_a: ITradingCallbacks.AggregatorAnswerStruct, overrides?: Overrides & {
5747
+ from?: PromiseOrValue<string>;
5748
+ }): Promise<PopulatedTransaction>;
5086
5749
  updateVaultClosingFeeP(_valueP: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5087
5750
  from?: PromiseOrValue<string>;
5088
5751
  }): Promise<PopulatedTransaction>;
5752
+ validateTriggerCloseOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5753
+ validateTriggerOpenOrderCallback(_tradeId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<BigNumberish>, _high: PromiseOrValue<BigNumberish>, _low: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5089
5754
  getAllBorrowingPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5090
5755
  getBorrowingGroup(_collateralIndex: PromiseOrValue<BigNumberish>, _groupIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5091
5756
  getBorrowingGroupOi(_collateralIndex: PromiseOrValue<BigNumberish>, _groupIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
@@ -5106,6 +5771,9 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5106
5771
  handleTradeBorrowingCallback(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _open: PromiseOrValue<boolean>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
5107
5772
  from?: PromiseOrValue<string>;
5108
5773
  }): Promise<PopulatedTransaction>;
5774
+ resetTradeBorrowingFees(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _index: PromiseOrValue<BigNumberish>, _long: PromiseOrValue<boolean>, overrides?: Overrides & {
5775
+ from?: PromiseOrValue<string>;
5776
+ }): Promise<PopulatedTransaction>;
5109
5777
  setBorrowingGroupParams(_collateralIndex: PromiseOrValue<BigNumberish>, _groupIndex: PromiseOrValue<BigNumberish>, _value: IBorrowingFees.BorrowingGroupParamsStruct, overrides?: Overrides & {
5110
5778
  from?: PromiseOrValue<string>;
5111
5779
  }): Promise<PopulatedTransaction>;
@@ -5130,21 +5798,21 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5130
5798
  }): Promise<PopulatedTransaction>;
5131
5799
  getChainlinkToken(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5132
5800
  getCollateralFromUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _normalizedValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5133
- getCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5801
+ getCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5134
5802
  getCollateralPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5135
5803
  getCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5136
5804
  getGnsPriceCollateralAddress(_collateral: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5137
5805
  getGnsPriceCollateralIndex(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5138
5806
  getGnsPriceUsd(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5139
5807
  getLimitJobId(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5140
- getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5808
+ getLinkFee(_collateralIndex: PromiseOrValue<BigNumberish>, _trader: PromiseOrValue<string>, _pairIndex: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5141
5809
  getLinkUsdPriceFeed(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5142
5810
  getMarketJobId(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5143
5811
  getMinAnswers(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5144
5812
  getOracle(_index: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5145
5813
  getOracles(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5146
5814
  getPendingRequest(_id: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5147
- getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5815
+ getPrice(_collateralIndex: PromiseOrValue<BigNumberish>, _pairIndex: PromiseOrValue<BigNumberish>, _tradeId: ITradingStorage.IdStruct, _orderId: ITradingStorage.IdStruct, _orderType: PromiseOrValue<BigNumberish>, _positionSizeCollateral: PromiseOrValue<BigNumberish>, _fromBlock: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5148
5816
  from?: PromiseOrValue<string>;
5149
5817
  }): Promise<PopulatedTransaction>;
5150
5818
  getPriceAggregatorOrder(_requestId: PromiseOrValue<BytesLike>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
@@ -5152,7 +5820,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5152
5820
  getRequestCount(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5153
5821
  getTwapInterval(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5154
5822
  getUsdNormalizedValue(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralValue: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5155
- initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralUniV3Pools: PromiseOrValue<string>[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: Overrides & {
5823
+ initializePriceAggregator(_linkToken: PromiseOrValue<string>, _linkUsdPriceFeed: PromiseOrValue<string>, _twapInterval: PromiseOrValue<BigNumberish>, _minAnswers: PromiseOrValue<BigNumberish>, _nodes: PromiseOrValue<string>[], _jobIds: [PromiseOrValue<BytesLike>, PromiseOrValue<BytesLike>], _collateralIndices: PromiseOrValue<BigNumberish>[], _gnsCollateralLiquidityPools: IPriceAggregator.LiquidityPoolInputStruct[], _collateralUsdPriceFeeds: PromiseOrValue<string>[], overrides?: Overrides & {
5156
5824
  from?: PromiseOrValue<string>;
5157
5825
  }): Promise<PopulatedTransaction>;
5158
5826
  removeOracle(_index: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
@@ -5167,7 +5835,7 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5167
5835
  setMarketJobId(_jobId: PromiseOrValue<BytesLike>, overrides?: Overrides & {
5168
5836
  from?: PromiseOrValue<string>;
5169
5837
  }): Promise<PopulatedTransaction>;
5170
- updateCollateralGnsUniV3Pool(_collateralIndex: PromiseOrValue<BigNumberish>, _uniV3Pool: PromiseOrValue<string>, overrides?: Overrides & {
5838
+ updateCollateralGnsLiquidityPool(_collateralIndex: PromiseOrValue<BigNumberish>, _liquidityPoolInput: IPriceAggregator.LiquidityPoolInputStruct, overrides?: Overrides & {
5171
5839
  from?: PromiseOrValue<string>;
5172
5840
  }): Promise<PopulatedTransaction>;
5173
5841
  updateCollateralUsdPriceFeed(_collateralIndex: PromiseOrValue<BigNumberish>, _value: PromiseOrValue<string>, overrides?: Overrides & {
@@ -5182,33 +5850,19 @@ export interface GNSMultiCollatDiamond extends BaseContract {
5182
5850
  updateTwapInterval(_twapInterval: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5183
5851
  from?: PromiseOrValue<string>;
5184
5852
  }): Promise<PopulatedTransaction>;
5185
- copyAllState(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: Overrides & {
5186
- from?: PromiseOrValue<string>;
5187
- }): Promise<PopulatedTransaction>;
5188
- copyBorrowingFeesGroups(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5189
- from?: PromiseOrValue<string>;
5190
- }): Promise<PopulatedTransaction>;
5191
- copyBorrowingFeesPairs(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5192
- from?: PromiseOrValue<string>;
5193
- }): Promise<PopulatedTransaction>;
5194
- copyLimits(_collateralIndex: PromiseOrValue<BigNumberish>, _maxIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5195
- from?: PromiseOrValue<string>;
5196
- }): Promise<PopulatedTransaction>;
5197
- copyPairOis(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5198
- from?: PromiseOrValue<string>;
5199
- }): Promise<PopulatedTransaction>;
5200
- copyTraderDelegations(_collateralIndex: PromiseOrValue<BigNumberish>, _traders: PromiseOrValue<string>[], overrides?: Overrides & {
5853
+ addOtcCollateralBalance(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5201
5854
  from?: PromiseOrValue<string>;
5202
5855
  }): Promise<PopulatedTransaction>;
5203
- copyTrades(_collateralIndex: PromiseOrValue<BigNumberish>, _maxPairIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5856
+ getOtcBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5857
+ getOtcConfig(overrides?: CallOverrides): Promise<PopulatedTransaction>;
5858
+ getOtcRate(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5859
+ initializeOtc(_config: IOtc.OtcConfigStruct, overrides?: Overrides & {
5204
5860
  from?: PromiseOrValue<string>;
5205
5861
  }): Promise<PopulatedTransaction>;
5206
- getCollateralStageState(_collateralIndex: PromiseOrValue<BigNumberish>, _stage: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5207
- getCollateralState(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
5208
- markAsDone(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5862
+ sellGnsForCollateral(_collateralIndex: PromiseOrValue<BigNumberish>, _collateralAmount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5209
5863
  from?: PromiseOrValue<string>;
5210
5864
  }): Promise<PopulatedTransaction>;
5211
- transferBalance(_collateralIndex: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
5865
+ updateOtcConfig(_config: IOtc.OtcConfigStruct, overrides?: Overrides & {
5212
5866
  from?: PromiseOrValue<string>;
5213
5867
  }): Promise<PopulatedTransaction>;
5214
5868
  };