@lido-nestjs/execution 1.1.0 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -16,13 +16,13 @@ yarn add @lido-nestjs/execution
16
16
  ```ts
17
17
  // Import
18
18
  import { Injectable, Module } from '@nestjs/common';
19
- import { ExecutionModule } from '@lido-nestjs/execution';
19
+ import { FallbackProviderModule } from '@lido-nestjs/execution';
20
20
  import { MyService } from './my.service';
21
21
 
22
22
  @Module({
23
23
  imports: [
24
24
  LoggerModule.forRoot({}),
25
- ExecutionModule.forRoot({
25
+ FallbackProviderModule.forRoot({
26
26
  imports: [],
27
27
  urls: ['http://localhost:8545', 'http://fallback:8545'],
28
28
  network: 1,
@@ -48,4 +48,25 @@ export class MyService {
48
48
 
49
49
  ### Async usage
50
50
 
51
- // TODO
51
+ ```ts
52
+ import { Module } from '@nestjs/common';
53
+ import { FallbackProviderModule } from '@lido-nestjs/execution';
54
+ import { ConfigModule, ConfigService } from './my.service';
55
+
56
+ @Module({
57
+ imports: [
58
+ ConfigModule.forRoot(),
59
+ FetchModule.forRoot(),
60
+ FallbackProviderModule.forRootAsync({
61
+ async useFactory(configService: ConfigService) {
62
+ return {
63
+ urls: configService.urls,
64
+ network: configService.network,
65
+ };
66
+ },
67
+ inject: [ConfigService],
68
+ }),
69
+ ],
70
+ })
71
+ export class MyModule {}
72
+ ```
@@ -0,0 +1,8 @@
1
+ import { DynamicModule } from '@nestjs/common';
2
+ import { BatchProviderModuleAsyncOptions, BatchProviderModuleSyncOptions } from './interfaces/module.options';
3
+ export declare class BatchProviderModule {
4
+ static forRoot(options: BatchProviderModuleSyncOptions): DynamicModule;
5
+ static forFeature(options: BatchProviderModuleSyncOptions): DynamicModule;
6
+ static forRootAsync(options: BatchProviderModuleAsyncOptions): DynamicModule;
7
+ static forFeatureAsync(options: BatchProviderModuleAsyncOptions): DynamicModule;
8
+ }
@@ -0,0 +1,61 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var tslib = require('tslib');
6
+ var common = require('@nestjs/common');
7
+ var extendedJsonRpcBatchProvider = require('./provider/extended-json-rpc-batch-provider.js');
8
+ var constants = require('./constants/constants.js');
9
+
10
+ var BatchProviderModule_1;
11
+ const getModuleProviders = (options) => {
12
+ return [
13
+ {
14
+ provide: extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider,
15
+ useFactory: () => {
16
+ return new extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider(options.url, options.network, options.requestPolicy, options.fetchMiddlewares);
17
+ },
18
+ },
19
+ ];
20
+ };
21
+ exports.BatchProviderModule = BatchProviderModule_1 = class BatchProviderModule {
22
+ static forRoot(options) {
23
+ return Object.assign({ global: true }, this.forFeature(options));
24
+ }
25
+ static forFeature(options) {
26
+ return {
27
+ module: BatchProviderModule_1,
28
+ imports: options.imports,
29
+ providers: getModuleProviders(options),
30
+ exports: [extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider],
31
+ };
32
+ }
33
+ static forRootAsync(options) {
34
+ return Object.assign({ global: true }, this.forFeatureAsync(options));
35
+ }
36
+ static forFeatureAsync(options) {
37
+ return {
38
+ module: BatchProviderModule_1,
39
+ imports: options.imports,
40
+ providers: [
41
+ {
42
+ provide: constants.BATCH_PROVIDER_MODULE_OPTIONS,
43
+ useFactory: options.useFactory,
44
+ inject: options.inject,
45
+ },
46
+ {
47
+ provide: extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider,
48
+ useFactory: (options) => {
49
+ return new extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider(options.url, options.network, options.requestPolicy, options.fetchMiddlewares);
50
+ },
51
+ inject: [constants.BATCH_PROVIDER_MODULE_OPTIONS],
52
+ },
53
+ ...(options.providers || []),
54
+ ],
55
+ exports: [extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider],
56
+ };
57
+ }
58
+ };
59
+ exports.BatchProviderModule = BatchProviderModule_1 = tslib.__decorate([
60
+ common.Module({})
61
+ ], exports.BatchProviderModule);
@@ -1,5 +1,2 @@
1
- export declare const EXECUTION_MODULE_OPTIONS: unique symbol;
2
- export declare enum Provider {
3
- ExtendedJsonRpcBatchProvider = 0,
4
- SimpleFallbackJsonRpcBatchProvider = 1
5
- }
1
+ export declare const FALLBACK_PROVIDER_MODULE_OPTIONS: unique symbol;
2
+ export declare const BATCH_PROVIDER_MODULE_OPTIONS: unique symbol;
@@ -2,16 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const EXECUTION_MODULE_OPTIONS = Symbol('execution-module-options');
6
- exports.Provider = void 0;
7
- (function (Provider) {
8
- Provider[Provider["ExtendedJsonRpcBatchProvider"] = 0] = "ExtendedJsonRpcBatchProvider";
9
- Provider[Provider["SimpleFallbackJsonRpcBatchProvider"] = 1] = "SimpleFallbackJsonRpcBatchProvider";
10
- })(exports.Provider || (exports.Provider = {}));
11
- // export type Providers =
12
- // [Provider.ExtendedJsonRpcBatchProvider, Provider.SimpleFallbackJsonRpcBatchProvider] |
13
- // [Provider.SimpleFallbackJsonRpcBatchProvider, Provider.ExtendedJsonRpcBatchProvider] |
14
- // [Provider.SimpleFallbackJsonRpcBatchProvider] |
15
- // [Provider.ExtendedJsonRpcBatchProvider];
5
+ const FALLBACK_PROVIDER_MODULE_OPTIONS = Symbol('fallback-provider-module-options');
6
+ const BATCH_PROVIDER_MODULE_OPTIONS = Symbol('batch-provider-module-options');
16
7
 
17
- exports.EXECUTION_MODULE_OPTIONS = EXECUTION_MODULE_OPTIONS;
8
+ exports.BATCH_PROVIDER_MODULE_OPTIONS = BATCH_PROVIDER_MODULE_OPTIONS;
9
+ exports.FALLBACK_PROVIDER_MODULE_OPTIONS = FALLBACK_PROVIDER_MODULE_OPTIONS;
@@ -0,0 +1,6 @@
1
+ export declare class NoNewBlocksWhilePollingError extends Error {
2
+ name: string;
3
+ message: string;
4
+ latestObservedBlockNumber: number;
5
+ constructor(message: string, latestObservedBlockNumber: number);
6
+ }
@@ -0,0 +1,14 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ class NoNewBlocksWhilePollingError extends Error {
6
+ constructor(message, latestObservedBlockNumber) {
7
+ super('');
8
+ this.name = 'NoNewBlocksWhilePollingError';
9
+ this.message = message;
10
+ this.latestObservedBlockNumber = latestObservedBlockNumber;
11
+ }
12
+ }
13
+
14
+ exports.NoNewBlocksWhilePollingError = NoNewBlocksWhilePollingError;
@@ -0,0 +1,8 @@
1
+ import { DynamicModule } from '@nestjs/common';
2
+ import { FallbackProviderModuleAsyncOptions, FallbackProviderModuleSyncOptions } from './interfaces/module.options';
3
+ export declare class FallbackProviderModule {
4
+ static forRoot(options: FallbackProviderModuleSyncOptions): DynamicModule;
5
+ static forFeature(options: FallbackProviderModuleSyncOptions): DynamicModule;
6
+ static forRootAsync(options: FallbackProviderModuleAsyncOptions): DynamicModule;
7
+ static forFeatureAsync(options: FallbackProviderModuleAsyncOptions): DynamicModule;
8
+ }
@@ -9,7 +9,7 @@ var constants = require('./constants/constants.js');
9
9
  var simpleFallbackJsonRpcBatchProvider = require('./provider/simple-fallback-json-rpc-batch-provider.js');
10
10
  var logger = require('@lido-nestjs/logger');
11
11
 
12
- var ExecutionModule_1;
12
+ var FallbackProviderModule_1;
13
13
  const getModuleProviders = (options) => {
14
14
  return [
15
15
  {
@@ -28,19 +28,16 @@ const getModuleProviders = (options) => {
28
28
  },
29
29
  ];
30
30
  };
31
- exports.ExecutionModule = ExecutionModule_1 = class ExecutionModule {
31
+ exports.FallbackProviderModule = FallbackProviderModule_1 = class FallbackProviderModule {
32
32
  static forRoot(options) {
33
33
  return Object.assign({ global: true }, this.forFeature(options));
34
34
  }
35
35
  static forFeature(options) {
36
36
  return {
37
- module: ExecutionModule_1,
37
+ module: FallbackProviderModule_1,
38
38
  imports: options.imports,
39
39
  providers: getModuleProviders(options),
40
- exports: [
41
- simpleFallbackJsonRpcBatchProvider.SimpleFallbackJsonRpcBatchProvider,
42
- extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider,
43
- ],
40
+ exports: [simpleFallbackJsonRpcBatchProvider.SimpleFallbackJsonRpcBatchProvider],
44
41
  };
45
42
  }
46
43
  static forRootAsync(options) {
@@ -48,11 +45,11 @@ exports.ExecutionModule = ExecutionModule_1 = class ExecutionModule {
48
45
  }
49
46
  static forFeatureAsync(options) {
50
47
  return {
51
- module: ExecutionModule_1,
48
+ module: FallbackProviderModule_1,
52
49
  imports: options.imports,
53
50
  providers: [
54
51
  {
55
- provide: constants.EXECUTION_MODULE_OPTIONS,
52
+ provide: constants.FALLBACK_PROVIDER_MODULE_OPTIONS,
56
53
  useFactory: options.useFactory,
57
54
  inject: options.inject,
58
55
  },
@@ -61,25 +58,14 @@ exports.ExecutionModule = ExecutionModule_1 = class ExecutionModule {
61
58
  useFactory: (logger, options) => {
62
59
  return new simpleFallbackJsonRpcBatchProvider.SimpleFallbackJsonRpcBatchProvider(options, logger);
63
60
  },
64
- inject: [logger.LOGGER_PROVIDER, constants.EXECUTION_MODULE_OPTIONS],
65
- },
66
- {
67
- provide: extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider,
68
- useFactory: (options) => {
69
- return new extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider(options.urls[0], undefined, // options.network,
70
- options.requestPolicy);
71
- },
72
- inject: [constants.EXECUTION_MODULE_OPTIONS],
61
+ inject: [logger.LOGGER_PROVIDER, constants.FALLBACK_PROVIDER_MODULE_OPTIONS],
73
62
  },
74
63
  ...(options.providers || []),
75
64
  ],
76
- exports: [
77
- simpleFallbackJsonRpcBatchProvider.SimpleFallbackJsonRpcBatchProvider,
78
- extendedJsonRpcBatchProvider.ExtendedJsonRpcBatchProvider,
79
- ],
65
+ exports: [simpleFallbackJsonRpcBatchProvider.SimpleFallbackJsonRpcBatchProvider],
80
66
  };
81
67
  }
82
68
  };
83
- exports.ExecutionModule = ExecutionModule_1 = tslib.__decorate([
69
+ exports.FallbackProviderModule = FallbackProviderModule_1 = tslib.__decorate([
84
70
  common.Module({})
85
- ], exports.ExecutionModule);
71
+ ], exports.FallbackProviderModule);
package/dist/index.d.ts CHANGED
@@ -1,8 +1,8 @@
1
1
  export * from './provider/extended-json-rpc-batch-provider';
2
2
  export * from './provider/simple-fallback-json-rpc-batch-provider';
3
3
  export * from './common/queue';
4
- export * from './execution.module';
4
+ export * from './fallback-provider.module';
5
+ export * from './batch-provider.module';
5
6
  export * from './interfaces/fallback-provider';
6
7
  export * from './interfaces/simple-fallback-provider-config';
7
- export { ExecutionModuleAsyncOptions } from './interfaces/module.options';
8
- export { ExecutionModuleSyncOptions } from './interfaces/module.options';
8
+ export * from './interfaces/module.options';
package/dist/index.js CHANGED
@@ -5,7 +5,8 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  var extendedJsonRpcBatchProvider = require('./provider/extended-json-rpc-batch-provider.js');
6
6
  var simpleFallbackJsonRpcBatchProvider = require('./provider/simple-fallback-json-rpc-batch-provider.js');
7
7
  var queue = require('./common/queue.js');
8
- var execution_module = require('./execution.module.js');
8
+ var fallbackProvider_module = require('./fallback-provider.module.js');
9
+ var batchProvider_module = require('./batch-provider.module.js');
9
10
 
10
11
 
11
12
 
@@ -18,7 +19,11 @@ Object.defineProperty(exports, 'SimpleFallbackJsonRpcBatchProvider', {
18
19
  get: function () { return simpleFallbackJsonRpcBatchProvider.SimpleFallbackJsonRpcBatchProvider; }
19
20
  });
20
21
  exports.Queue = queue.Queue;
21
- Object.defineProperty(exports, 'ExecutionModule', {
22
+ Object.defineProperty(exports, 'FallbackProviderModule', {
22
23
  enumerable: true,
23
- get: function () { return execution_module.ExecutionModule; }
24
+ get: function () { return fallbackProvider_module.FallbackProviderModule; }
25
+ });
26
+ Object.defineProperty(exports, 'BatchProviderModule', {
27
+ enumerable: true,
28
+ get: function () { return batchProvider_module.BatchProviderModule; }
24
29
  });
@@ -4,4 +4,5 @@ export interface FallbackProvider {
4
4
  provider: ExtendedJsonRpcBatchProvider;
5
5
  network: Network | null;
6
6
  index: number;
7
+ unreachable: boolean;
7
8
  }
@@ -1,8 +1,22 @@
1
1
  import { ModuleMetadata } from '@nestjs/common';
2
2
  import { SimpleFallbackProviderConfig } from './simple-fallback-provider-config';
3
- export interface ExecutionModuleSyncOptions extends Pick<ModuleMetadata, 'imports'>, SimpleFallbackProviderConfig {
3
+ import { ConnectionInfo } from '@ethersproject/web';
4
+ import { Networkish } from './networkish';
5
+ import { RequestPolicy } from '../provider/extended-json-rpc-batch-provider';
6
+ import { MiddlewareCallback } from '@lido-nestjs/middleware';
7
+ export interface FallbackProviderModuleSyncOptions extends Pick<ModuleMetadata, 'imports'>, SimpleFallbackProviderConfig {
4
8
  }
5
- export interface ExecutionModuleAsyncOptions extends Pick<ModuleMetadata, 'imports' | 'providers'> {
6
- useFactory: (...args: any[]) => Promise<ExecutionModuleSyncOptions> | ExecutionModuleSyncOptions;
9
+ export interface BatchProviderModuleSyncOptions extends Pick<ModuleMetadata, 'imports'> {
10
+ url: ConnectionInfo | string;
11
+ network?: Networkish;
12
+ requestPolicy?: RequestPolicy;
13
+ fetchMiddlewares?: MiddlewareCallback<Promise<any>>[];
14
+ }
15
+ export interface FallbackProviderModuleAsyncOptions extends Pick<ModuleMetadata, 'imports' | 'providers'> {
16
+ useFactory: (...args: any[]) => Promise<FallbackProviderModuleSyncOptions> | FallbackProviderModuleSyncOptions;
17
+ inject: any[];
18
+ }
19
+ export interface BatchProviderModuleAsyncOptions extends Pick<ModuleMetadata, 'imports' | 'providers'> {
20
+ useFactory: (...args: any[]) => Promise<BatchProviderModuleSyncOptions> | BatchProviderModuleSyncOptions;
7
21
  inject: any[];
8
22
  }
@@ -11,5 +11,7 @@ export interface SimpleFallbackProviderConfig {
11
11
  minBackoffMs?: number;
12
12
  maxBackoffMs?: number;
13
13
  logRetries?: boolean;
14
+ resetIntervalMs?: number;
14
15
  fetchMiddlewares?: MiddlewareCallback<Promise<any>>[];
16
+ maxTimeWithoutNewBlocksMs?: number;
15
17
  }
@@ -7,6 +7,7 @@ import { BlockTag } from '../ethers/block-tag';
7
7
  import { BigNumber, BigNumberish } from '@ethersproject/bignumber';
8
8
  import { Deferrable } from '@ethersproject/properties';
9
9
  import { TransactionRequest } from '@ethersproject/abstract-provider/src.ts/index';
10
+ import { EventType, Listener } from '@ethersproject/abstract-provider';
10
11
  /**
11
12
  * EIP-1898 support
12
13
  * https://eips.ethereum.org/EIPS/eip-1898
@@ -26,14 +27,17 @@ export declare class SimpleFallbackJsonRpcBatchProvider extends BaseProvider {
26
27
  protected fallbackProviders: [FallbackProvider];
27
28
  protected activeFallbackProviderIndex: number;
28
29
  protected detectNetworkFirstRun: boolean;
30
+ protected resetTimer: ReturnType<typeof setTimeout> | null;
29
31
  constructor(config: SimpleFallbackProviderConfig, logger: LoggerService);
30
32
  static _formatter: Formatter | null;
31
33
  static getFormatter(): Formatter;
34
+ on(eventName: EventType, listener: Listener): this;
32
35
  protected get provider(): FallbackProvider;
33
36
  protected switchToNextProvider(): void;
34
37
  perform(method: string, params: {
35
38
  [name: string]: unknown;
36
39
  }): Promise<unknown>;
37
40
  detectNetwork(): Promise<Network>;
41
+ protected resetFallbacks(): void;
38
42
  protected networksEqual(networkA: Network, networkB: Network): boolean;
39
43
  }
@@ -9,12 +9,14 @@ var common = require('@nestjs/common');
9
9
  var retrier = require('../common/retrier.js');
10
10
  var formatterWithEip1898 = require('../ethers/formatter-with-eip1898.js');
11
11
  var networks = require('../common/networks.js');
12
+ var noNewBlocksWhilePolling_error = require('../error/no-new-blocks-while-polling.error.js');
12
13
 
13
14
  exports.SimpleFallbackJsonRpcBatchProvider = class SimpleFallbackJsonRpcBatchProvider extends providers.BaseProvider {
14
15
  constructor(config, logger) {
15
16
  super(config.network);
16
17
  this.detectNetworkFirstRun = true;
17
- this.config = Object.assign({ maxRetries: 3, minBackoffMs: 500, maxBackoffMs: 5000, logRetries: true }, config);
18
+ this.resetTimer = null;
19
+ this.config = Object.assign({ maxRetries: 3, minBackoffMs: 500, maxBackoffMs: 5000, logRetries: true, resetIntervalMs: 10000, maxTimeWithoutNewBlocksMs: 60000 }, config);
18
20
  this.logger = logger;
19
21
  const conns = config.urls.filter((url) => {
20
22
  if (!url) {
@@ -35,6 +37,7 @@ exports.SimpleFallbackJsonRpcBatchProvider = class SimpleFallbackJsonRpcBatchPro
35
37
  network: null,
36
38
  provider,
37
39
  index,
40
+ unreachable: false,
38
41
  };
39
42
  });
40
43
  this.activeFallbackProviderIndex = 0;
@@ -45,6 +48,25 @@ exports.SimpleFallbackJsonRpcBatchProvider = class SimpleFallbackJsonRpcBatchPro
45
48
  }
46
49
  return this._formatter;
47
50
  }
51
+ on(eventName, listener) {
52
+ let dieTimer = null;
53
+ const startDieTimer = (latestObservedBlockNumber) => {
54
+ if (dieTimer)
55
+ clearTimeout(dieTimer);
56
+ dieTimer = setTimeout(async () => {
57
+ const error = new noNewBlocksWhilePolling_error.NoNewBlocksWhilePollingError('No new blocks for a long time while polling', latestObservedBlockNumber);
58
+ this.emit('error', error);
59
+ }, this.config.maxTimeWithoutNewBlocksMs);
60
+ };
61
+ if (eventName === 'block') {
62
+ startDieTimer(-1);
63
+ super.on(eventName, function (...args) {
64
+ startDieTimer(args[0]);
65
+ return listener.apply(this, args);
66
+ });
67
+ }
68
+ return super.on(eventName, listener);
69
+ }
48
70
  get provider() {
49
71
  if (this.activeFallbackProviderIndex > this.fallbackProviders.length - 1) {
50
72
  this.activeFallbackProviderIndex = 0;
@@ -53,7 +75,7 @@ exports.SimpleFallbackJsonRpcBatchProvider = class SimpleFallbackJsonRpcBatchPro
53
75
  let attempt = 0;
54
76
  const isValid = (provider) => provider.network !== null &&
55
77
  provider.network.chainId === networks.getNetworkChain(this.config.network);
56
- while (!isValid(fallbackProvider) ||
78
+ while (!isValid(fallbackProvider) &&
57
79
  attempt < this.fallbackProviders.length) {
58
80
  fallbackProvider =
59
81
  this.fallbackProviders[this.activeFallbackProviderIndex];
@@ -96,13 +118,17 @@ exports.SimpleFallbackJsonRpcBatchProvider = class SimpleFallbackJsonRpcBatchPro
96
118
  throw new Error('All attempts to do ETH1 RPC request failed');
97
119
  }
98
120
  async detectNetwork() {
99
- const results = await Promise.allSettled(this.fallbackProviders.map((c) => c.provider.getNetwork()));
100
- results.forEach((result, i) => {
121
+ const results = await Promise.allSettled(this.fallbackProviders
122
+ .filter((c) => !c.unreachable)
123
+ .map((c) => c.provider.getNetwork()));
124
+ results.forEach((result, index) => {
101
125
  if (result.status === 'fulfilled') {
102
- this.fallbackProviders[i].network = result.value;
126
+ this.fallbackProviders[index].network = result.value;
127
+ this.fallbackProviders[index].unreachable = false;
103
128
  }
104
129
  else {
105
- this.fallbackProviders[i].network = null;
130
+ this.fallbackProviders[index].network = null;
131
+ this.fallbackProviders[index].unreachable = true;
106
132
  }
107
133
  });
108
134
  let previousNetwork = null;
@@ -139,8 +165,26 @@ exports.SimpleFallbackJsonRpcBatchProvider = class SimpleFallbackJsonRpcBatchPro
139
165
  if (this.detectNetworkFirstRun) {
140
166
  this.detectNetworkFirstRun = false;
141
167
  }
168
+ if (this.resetTimer) {
169
+ clearTimeout(this.resetTimer);
170
+ }
171
+ this.resetTimer = setTimeout(() => {
172
+ this.resetFallbacks();
173
+ }, this.config.resetIntervalMs || 10000);
142
174
  return previousNetwork;
143
175
  }
176
+ resetFallbacks() {
177
+ if (this.resetTimer) {
178
+ clearTimeout(this.resetTimer);
179
+ }
180
+ this.fallbackProviders.forEach((fallbackProvider, index) => {
181
+ var _a;
182
+ if (!((_a = this.fallbackProviders[index].network) === null || _a === void 0 ? void 0 : _a.chainId)) {
183
+ this.fallbackProviders[index].unreachable = false;
184
+ }
185
+ });
186
+ this.activeFallbackProviderIndex = 0;
187
+ }
144
188
  networksEqual(networkA, networkB) {
145
189
  return networks.networksEqual(networkA, networkB);
146
190
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lido-nestjs/execution",
3
- "version": "1.1.0",
3
+ "version": "1.4.0",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "license": "MIT",
@@ -1,8 +0,0 @@
1
- import { DynamicModule } from '@nestjs/common';
2
- import { ExecutionModuleAsyncOptions, ExecutionModuleSyncOptions } from './interfaces/module.options';
3
- export declare class ExecutionModule {
4
- static forRoot(options: ExecutionModuleSyncOptions): DynamicModule;
5
- static forFeature(options: ExecutionModuleSyncOptions): DynamicModule;
6
- static forRootAsync(options: ExecutionModuleAsyncOptions): DynamicModule;
7
- static forFeatureAsync(options: ExecutionModuleAsyncOptions): DynamicModule;
8
- }