@dhedge/backend-flatcoin-core 0.3.40 → 0.3.41

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.
@@ -30,8 +30,12 @@ export declare class GraphQueryService {
30
30
  getLiquidatedPositionsByCloseBlockFrom(closeBlockFrom: number): Promise<Position[]>;
31
31
  getAllUnitHolders(): Promise<UnitHolder[]>;
32
32
  getUnitHoldersPaginated(skip: number, first: number): Promise<UnitHolder[]>;
33
- getOutgoingUnitTransfersPaginated(accountFrom: string, skip: number, first: number): Promise<UnitTransfer[]>;
34
- getIncomingUnitTransfersPaginated(accountTo: string, skip: number, first: number): Promise<UnitTransfer[]>;
33
+ private getOutgoingUnitTransfersByBlockNumberFrom;
34
+ private getIncomingUnitTransfersByBlockNumberFrom;
35
+ getAllOutgoingUnitTransfersForAccount(account: string): Promise<UnitTransfer[]>;
36
+ getAllIncomingUnitTransfersForAccount(account: string): Promise<UnitTransfer[]>;
37
+ private getOutgoingUnitTransfersPaginated;
38
+ private getIncomingUnitTransfersPaginated;
35
39
  }
36
40
  export declare const getAnnouncedOrdersQuery: string;
37
41
  export declare const getLeverageOpensQuery: string;
@@ -55,5 +59,7 @@ export declare const getClosedPositionsQuery: string;
55
59
  export declare const getClosedPositionsQueryByCloseBlockFrom: string;
56
60
  export declare const getLiquidatedPositionsQueryByCloseBlockFrom: string;
57
61
  export declare const getUnitHoldersQueryPaginated: string;
58
- export declare const getUnitTransfersFromQueryPaginated: string;
59
- export declare const getUnitTransfersToQueryPaginated: string;
62
+ export declare const getOutgoingUnitTransfersByBlockNumberFromQuery: string;
63
+ export declare const getIncomingUnitTransfersByBlockNumberFromQuery: string;
64
+ export declare const getOutgoingUnitTransfersQueryPaginated: string;
65
+ export declare const getIncomingUnitTransfersQueryPaginated: string;
@@ -9,7 +9,7 @@ var __metadata = (this && this.__metadata) || function (k, v) {
9
9
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.getUnitTransfersToQueryPaginated = exports.getUnitTransfersFromQueryPaginated = exports.getUnitHoldersQueryPaginated = exports.getLiquidatedPositionsQueryByCloseBlockFrom = exports.getClosedPositionsQueryByCloseBlockFrom = exports.getClosedPositionsQuery = exports.getClosedPositionsQueryPaginated = exports.getOpenPositionsQueryPaginated = exports.getLimitOrderExecutedsByTimestampFromQuery = exports.getLimitOrderAnnouncedsQuery = exports.getWithdrawsByWithdrawerAddressQuery = exports.getWithdrawsByTimestampFromQuery = exports.getWithdrawsQuery = exports.getDepositsByDepositorAddressQuery = exports.getDepositsByTimestampFromQuery = exports.getDepositsQuery = exports.getPositionLiquidatedsQuery = exports.getLeverageAdjustsByBlockFromQuery = exports.getLeverageAdjustsByTimestampFromQuery = exports.getLeverageClosesByTimestampFromQuery = exports.getLeverageClosesQuery = exports.getLeverageOpensByTimestampFromQuery = exports.getLeverageOpensQuery = exports.getAnnouncedOrdersQuery = exports.GraphQueryService = void 0;
12
+ exports.getIncomingUnitTransfersQueryPaginated = exports.getOutgoingUnitTransfersQueryPaginated = exports.getIncomingUnitTransfersByBlockNumberFromQuery = exports.getOutgoingUnitTransfersByBlockNumberFromQuery = exports.getUnitHoldersQueryPaginated = exports.getLiquidatedPositionsQueryByCloseBlockFrom = exports.getClosedPositionsQueryByCloseBlockFrom = exports.getClosedPositionsQuery = exports.getClosedPositionsQueryPaginated = exports.getOpenPositionsQueryPaginated = exports.getLimitOrderExecutedsByTimestampFromQuery = exports.getLimitOrderAnnouncedsQuery = exports.getWithdrawsByWithdrawerAddressQuery = exports.getWithdrawsByTimestampFromQuery = exports.getWithdrawsQuery = exports.getDepositsByDepositorAddressQuery = exports.getDepositsByTimestampFromQuery = exports.getDepositsQuery = exports.getPositionLiquidatedsQuery = exports.getLeverageAdjustsByBlockFromQuery = exports.getLeverageAdjustsByTimestampFromQuery = exports.getLeverageClosesByTimestampFromQuery = exports.getLeverageClosesQuery = exports.getLeverageOpensByTimestampFromQuery = exports.getLeverageOpensQuery = exports.getAnnouncedOrdersQuery = exports.GraphQueryService = void 0;
13
13
  const common_1 = require("@nestjs/common");
14
14
  const graphql_request_1 = require("graphql-request");
15
15
  let GraphQueryService = class GraphQueryService {
@@ -326,10 +326,64 @@ let GraphQueryService = class GraphQueryService {
326
326
  throw error;
327
327
  }
328
328
  }
329
- async getOutgoingUnitTransfersPaginated(accountFrom, skip, first) {
330
- const variables = { accountFrom, skip, first };
329
+ async getOutgoingUnitTransfersByBlockNumberFrom(account, blockNumberFrom) {
330
+ const variables = { account, blockNumberFrom };
331
331
  try {
332
- const response = await this.graphQLClient.request(exports.getUnitTransfersFromQueryPaginated, variables);
332
+ const response = await this.graphQLClient.request(exports.getOutgoingUnitTransfersByBlockNumberFromQuery, variables);
333
+ this.logger.log(`Fetched ${response.unitTransfers.length} outgoing unit transfers by block number from the graph`);
334
+ return response.unitTransfers;
335
+ }
336
+ catch (error) {
337
+ this.logger.error('Error fetching outgoing unit transfers by bock number from the graph:', error);
338
+ throw error;
339
+ }
340
+ }
341
+ async getIncomingUnitTransfersByBlockNumberFrom(account, blockNumberFrom) {
342
+ const variables = { account, blockNumberFrom };
343
+ try {
344
+ const response = await this.graphQLClient.request(exports.getIncomingUnitTransfersByBlockNumberFromQuery, variables);
345
+ this.logger.log(`Fetched ${response.unitTransfers.length} incoming unit transfers by block number from the graph`);
346
+ return response.unitTransfers;
347
+ }
348
+ catch (error) {
349
+ this.logger.error('Error fetching incoming unit transfers by bock number from the graph:', error);
350
+ throw error;
351
+ }
352
+ }
353
+ async getAllOutgoingUnitTransfersForAccount(account) {
354
+ const allTransfers = [];
355
+ const first = 999;
356
+ let skip = 0;
357
+ // currently thegraph allows to get only 10_000 entities
358
+ while (skip < 10000) {
359
+ const fetchedTransfers = await this.getOutgoingUnitTransfersPaginated(account.toLowerCase(), skip, first);
360
+ if (fetchedTransfers.length === 0) {
361
+ break;
362
+ }
363
+ allTransfers.push(...fetchedTransfers);
364
+ skip += first;
365
+ }
366
+ return allTransfers;
367
+ }
368
+ async getAllIncomingUnitTransfersForAccount(account) {
369
+ const allTransfers = [];
370
+ const first = 999;
371
+ let skip = 0;
372
+ // currently thegraph allows to get only 10_000 entities
373
+ while (skip < 10000) {
374
+ const fetchedTransfers = await this.getIncomingUnitTransfersPaginated(account.toLowerCase(), skip, first);
375
+ if (fetchedTransfers.length === 0) {
376
+ break;
377
+ }
378
+ allTransfers.push(...fetchedTransfers);
379
+ skip += first;
380
+ }
381
+ return allTransfers;
382
+ }
383
+ async getOutgoingUnitTransfersPaginated(account, skip, first) {
384
+ const variables = { account, skip, first };
385
+ try {
386
+ const response = await this.graphQLClient.request(exports.getOutgoingUnitTransfersQueryPaginated, variables);
333
387
  this.logger.log(`Fetched ${response.unitTransfers.length} outgoing unit transfers from the graph`);
334
388
  return response.unitTransfers;
335
389
  }
@@ -338,10 +392,10 @@ let GraphQueryService = class GraphQueryService {
338
392
  throw error;
339
393
  }
340
394
  }
341
- async getIncomingUnitTransfersPaginated(accountTo, skip, first) {
342
- const variables = { accountTo, skip, first };
395
+ async getIncomingUnitTransfersPaginated(account, skip, first) {
396
+ const variables = { account, skip, first };
343
397
  try {
344
- const response = await this.graphQLClient.request(exports.getUnitTransfersToQueryPaginated, variables);
398
+ const response = await this.graphQLClient.request(exports.getIncomingUnitTransfersQueryPaginated, variables);
345
399
  this.logger.log(`Fetched ${response.unitTransfers.length} incoming unit transfers from the graph`);
346
400
  return response.unitTransfers;
347
401
  }
@@ -659,17 +713,33 @@ exports.getUnitHoldersQueryPaginated = (0, graphql_request_1.gql) `
659
713
  }
660
714
  }
661
715
  `;
662
- exports.getUnitTransfersFromQueryPaginated = (0, graphql_request_1.gql) `
663
- query GetUnitTransfers($from: String, $skip: Int, $first: Int) {
664
- unitTransfers(from: $from, skip: $skip, first: $first) {
716
+ exports.getOutgoingUnitTransfersByBlockNumberFromQuery = (0, graphql_request_1.gql) `
717
+ query GetUnitTransfers($account: String, $blockNumberFrom: String) {
718
+ unitTransfers(where: { from: $account, blockNumber_gt: $blockNumberFrom }, first: 1000) {
719
+ value
720
+ blockNumber
721
+ }
722
+ }
723
+ `;
724
+ exports.getIncomingUnitTransfersByBlockNumberFromQuery = (0, graphql_request_1.gql) `
725
+ query GetUnitTransfers($account: String, $blockNumberFrom: String) {
726
+ unitTransfers(where: { to: $account, blockNumber_gt: $blockNumberFrom }, first: 1000) {
727
+ value
728
+ blockNumber
729
+ }
730
+ }
731
+ `;
732
+ exports.getOutgoingUnitTransfersQueryPaginated = (0, graphql_request_1.gql) `
733
+ query GetUnitTransfers($account: String, $skip: Int, $first: Int) {
734
+ unitTransfers(where: { from: $account }, skip: $skip, first: $first) {
665
735
  value
666
736
  blockNumber
667
737
  }
668
738
  }
669
739
  `;
670
- exports.getUnitTransfersToQueryPaginated = (0, graphql_request_1.gql) `
671
- query GetUnitTransfers($to: String, $skip: Int, $first: Int) {
672
- unitTransfers(to: $to, skip: $skip, first: $first) {
740
+ exports.getIncomingUnitTransfersQueryPaginated = (0, graphql_request_1.gql) `
741
+ query GetUnitTransfers($account: String, $skip: Int, $first: Int) {
742
+ unitTransfers(where: { to: $account }, skip: $skip, first: $first) {
673
743
  value
674
744
  blockNumber
675
745
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dhedge/backend-flatcoin-core",
3
- "version": "0.3.40",
3
+ "version": "0.3.41",
4
4
  "description": "Backend Flatcoin Core",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",