@tstdl/base 0.89.6 → 0.89.8

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/lock/index.d.ts CHANGED
@@ -4,6 +4,4 @@
4
4
  * @module Lock
5
5
  */
6
6
  export * from './lock.js';
7
- export * from './mongo/index.js';
8
7
  export * from './provider.js';
9
- export * from './web/index.js';
package/lock/index.js CHANGED
@@ -4,6 +4,4 @@
4
4
  * @module Lock
5
5
  */
6
6
  export * from './lock.js';
7
- export * from './mongo/index.js';
8
7
  export * from './provider.js';
9
- export * from './web/index.js';
@@ -1,6 +1,3 @@
1
- import { LockProvider } from '../lock/index.js';
2
- import { Logger } from '../logger/index.js';
3
- import { MigrationStateRepository } from './migration-state-repository.js';
4
1
  export type MigrationDefinition<T = void> = {
5
2
  name: string;
6
3
  migrations: Migration<T>[];
@@ -21,9 +18,6 @@ export type MigrationResult<T> = {
21
18
  restartRequested: boolean;
22
19
  };
23
20
  export declare class Migrator {
24
- private readonly migrationStateRepository;
25
- private readonly lockProvider;
26
- private readonly logger;
27
- constructor(migrationStateRepository: MigrationStateRepository, lockProvider: LockProvider, logger: Logger);
21
+ #private;
28
22
  migrate<T>({ name, migrations }: MigrationDefinition<T>): Promise<MigrationResult<T>[]>;
29
23
  }
@@ -4,14 +4,8 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
4
4
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
5
  return c > 3 && r && Object.defineProperty(target, key, r), r;
6
6
  };
7
- var __metadata = (this && this.__metadata) || function (k, v) {
8
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
- };
10
- var __param = (this && this.__param) || function (paramIndex, decorator) {
11
- return function (target, key) { decorator(target, key, paramIndex); }
12
- };
13
7
  import { CancellationToken } from '../cancellation/index.js';
14
- import { ResolveArg, Singleton } from '../injector/index.js';
8
+ import { Injector, Singleton, inject, runInInjectionContext } from '../injector/index.js';
15
9
  import { LockProvider } from '../lock/index.js';
16
10
  import { Logger } from '../logger/index.js';
17
11
  import { toArray } from '../utils/array/array.js';
@@ -21,20 +15,16 @@ import { Timer } from '../utils/timer.js';
21
15
  import { isDefined } from '../utils/type-guards.js';
22
16
  import { MigrationStateRepository } from './migration-state-repository.js';
23
17
  let Migrator = class Migrator {
24
- migrationStateRepository;
25
- lockProvider;
26
- logger;
27
- constructor(migrationStateRepository, lockProvider, logger) {
28
- this.migrationStateRepository = migrationStateRepository;
29
- this.lockProvider = lockProvider;
30
- this.logger = logger;
31
- }
18
+ #injector = inject(Injector);
19
+ #migrationStateRepository = inject(MigrationStateRepository);
20
+ #lockProvider = inject(LockProvider, 'migrator:');
21
+ #logger = inject(Logger, 'Migrator');
32
22
  // eslint-disable-next-line max-statements, max-lines-per-function
33
23
  async migrate({ name, migrations }) {
34
24
  if (migrations.length == 0) {
35
- throw new Error('no migrations provided');
25
+ throw new Error('No migrations provided.');
36
26
  }
37
- const lock = this.lockProvider.get(`${name}`);
27
+ const lock = this.#lockProvider.get(`${name}`);
38
28
  // eslint-disable-next-line max-statements, max-lines-per-function
39
29
  const { result } = await lock.use(30000, true, async () => {
40
30
  const results = [];
@@ -43,7 +33,7 @@ let Migrator = class Migrator {
43
33
  const control = {
44
34
  restart: () => restartToken.set()
45
35
  };
46
- const currentState = await this.migrationStateRepository.tryLoadByFilter({ name });
36
+ const currentState = await this.#migrationStateRepository.tryLoadByFilter({ name });
47
37
  const currentRevision = currentState?.revision ?? 'init';
48
38
  const latestRevision = migrations.sort(compareByValueSelectionDescending((migration) => migration.to))[0].to;
49
39
  if (currentRevision == latestRevision) {
@@ -51,29 +41,29 @@ let Migrator = class Migrator {
51
41
  }
52
42
  const suitableMigrations = migrations.filter((migration) => toArray(migration.from).includes(currentRevision));
53
43
  if (suitableMigrations.length == 0) {
54
- throw new Error(`no suitable migration path from current revision ${currentRevision} to latest revision ${latestRevision} found`);
44
+ throw new Error(`No suitable migration path from current revision ${currentRevision} to latest revision ${latestRevision} found.`);
55
45
  }
56
46
  const migration = suitableMigrations.sort(compareByValueSelectionDescending((m) => m.to))[0];
57
- this.logger.warn(`starting migration for "${name}" from revision ${currentRevision} to ${migration.to}`);
47
+ this.#logger.warn(`Starting migration for "${name}" from revision ${currentRevision} to ${migration.to}.`);
58
48
  let migratorResult;
59
- const time = await Timer.measureAsync(async () => (migratorResult = await migration.migrator(control)));
49
+ const time = await Timer.measureAsync(async () => (migratorResult = await runInInjectionContext(this.#injector, async () => migration.migrator(control))));
60
50
  results.push({ from: currentRevision, to: migration.to, time, result: migratorResult, restartRequested: restartToken.isSet });
61
51
  if (restartToken.isSet) {
62
- this.logger.warn(`finished migration in ${round(time / 1000, 2)} seconds`);
63
- this.logger.warn('migration-restart requested');
52
+ this.#logger.warn(`Finished migration in ${round(time / 1000, 2)} seconds.`);
53
+ this.#logger.warn('Migration-restart requested.');
64
54
  continue;
65
55
  }
66
56
  if (isDefined(currentState)) {
67
- await this.migrationStateRepository.patchByFilter({ name }, { revision: migration.to });
57
+ await this.#migrationStateRepository.patchByFilter({ name }, { revision: migration.to });
68
58
  }
69
59
  else {
70
60
  const newState = {
71
61
  name,
72
62
  revision: migration.to
73
63
  };
74
- await this.migrationStateRepository.insert(newState);
64
+ await this.#migrationStateRepository.insert(newState);
75
65
  }
76
- this.logger.warn(`finished migration in ${round(time / 1000, 2)} seconds`);
66
+ this.#logger.warn(`Finished migration in ${round(time / 1000, 2)} seconds.`);
77
67
  }
78
68
  return results;
79
69
  });
@@ -81,9 +71,6 @@ let Migrator = class Migrator {
81
71
  }
82
72
  };
83
73
  Migrator = __decorate([
84
- Singleton(),
85
- __param(1, ResolveArg('migrator:')),
86
- __param(2, ResolveArg('Migrator')),
87
- __metadata("design:paramtypes", [MigrationStateRepository, LockProvider, Logger])
74
+ Singleton()
88
75
  ], Migrator);
89
76
  export { Migrator };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tstdl/base",
3
- "version": "0.89.6",
3
+ "version": "0.89.8",
4
4
  "author": "Patrick Hein",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -54,6 +54,8 @@
54
54
  "./json-path": "./json-path/index.js",
55
55
  "./key-value-store": "./key-value-store/index.js",
56
56
  "./lock": "./lock/index.js",
57
+ "./lock/mongo": "./lock/mongo/index.js",
58
+ "./lock/web": "./lock/web/index.js",
57
59
  "./logger": "./logger/index.js",
58
60
  "./mail": "./mail/index.js",
59
61
  "./memory": "./memory/index.js",
@@ -106,7 +108,7 @@
106
108
  "luxon": "^3.4",
107
109
  "reflect-metadata": "^0.1",
108
110
  "rxjs": "^7.8",
109
- "type-fest": "^4.3"
111
+ "type-fest": "^4.4"
110
112
  },
111
113
  "devDependencies": {
112
114
  "@mxssfd/typedoc-theme": "1.1",
@@ -121,7 +123,7 @@
121
123
  "@typescript-eslint/parser": "6.7",
122
124
  "concurrently": "8.2",
123
125
  "esbuild": "0.19",
124
- "eslint": "8.50",
126
+ "eslint": "8.51",
125
127
  "eslint-import-resolver-typescript": "3.6",
126
128
  "eslint-plugin-import": "2.28",
127
129
  "tsc-alias": "1.8",
package/types.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import type { Observable } from 'rxjs';
2
- import type { Except, UnionToIntersection } from 'type-fest';
2
+ import type { Except } from 'type-fest';
3
3
  import type { Signal } from './signals/api.js';
4
4
  export type ObjectLiteral = {};
5
5
  export type PrimitiveTypeMap = {
@@ -131,6 +131,7 @@ export type SimplifyDeep<T> = T extends BuiltIn ? T : T extends readonly any[] ?
131
131
  } : T extends Record ? {
132
132
  [K in keyof T]: SimplifyDeep<T[K]>;
133
133
  } & {} : T;
134
+ export type UnionToIntersection<Union> = (Union extends unknown ? (distributedUnion: Union) => void : never) extends ((mergedIntersection: infer Intersection) => void) ? Intersection : never;
134
135
  export type UnionToTuple<T, Tuple extends any[] = []> = UnionToIntersection<T extends any ? () => T : never> extends () => infer R ? UnionToTuple<Exclude<T, R>, [R, ...Tuple]> : Tuple;
135
136
  export type UndefinableObject<T extends Record> = {
136
137
  [K in keyof T]: T[K] | undefined;