@decaf-ts/core 0.5.20 → 0.5.22

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 (91) hide show
  1. package/LICENSE.md +13 -16
  2. package/README.md +252 -604
  3. package/dist/core.cjs +335 -125
  4. package/dist/core.esm.cjs +338 -128
  5. package/lib/esm/identity/decorators.js +1 -1
  6. package/lib/esm/index.d.ts +1 -1
  7. package/lib/esm/index.js +1 -1
  8. package/lib/esm/model/types.d.ts +0 -9
  9. package/lib/esm/model/types.js +1 -1
  10. package/lib/esm/persistence/Adapter.d.ts +61 -51
  11. package/lib/esm/persistence/Adapter.js +120 -47
  12. package/lib/esm/persistence/Dispatch.d.ts +2 -13
  13. package/lib/esm/persistence/Dispatch.js +7 -15
  14. package/lib/esm/persistence/errors.d.ts +2 -2
  15. package/lib/esm/persistence/errors.js +4 -4
  16. package/lib/esm/persistence/types.d.ts +2 -0
  17. package/lib/esm/persistence/types.js +1 -1
  18. package/lib/esm/query/Condition.d.ts +8 -0
  19. package/lib/esm/query/Condition.js +9 -1
  20. package/lib/esm/query/Paginator.d.ts +2 -2
  21. package/lib/esm/query/Paginator.js +1 -1
  22. package/lib/esm/query/Statement.d.ts +4 -3
  23. package/lib/esm/query/Statement.js +4 -2
  24. package/lib/esm/query/errors.d.ts +3 -3
  25. package/lib/esm/query/errors.js +6 -6
  26. package/lib/esm/ram/RamAdapter.d.ts +8 -14
  27. package/lib/esm/ram/RamAdapter.js +44 -33
  28. package/lib/esm/ram/RamContext.d.ts +14 -6
  29. package/lib/esm/ram/RamContext.js +15 -7
  30. package/lib/esm/ram/constants.d.ts +1 -2
  31. package/lib/esm/ram/constants.js +2 -3
  32. package/lib/esm/ram/types.d.ts +3 -0
  33. package/lib/esm/ram/types.js +1 -1
  34. package/lib/esm/repository/Repository.d.ts +8 -7
  35. package/lib/esm/repository/Repository.js +8 -8
  36. package/lib/esm/repository/constants.d.ts +5 -4
  37. package/lib/esm/repository/constants.js +6 -5
  38. package/lib/esm/repository/decorators.d.ts +1 -1
  39. package/lib/esm/repository/decorators.js +12 -9
  40. package/lib/esm/repository/errors.d.ts +2 -2
  41. package/lib/esm/repository/errors.js +4 -4
  42. package/lib/esm/repository/injectables.d.ts +82 -11
  43. package/lib/esm/repository/injectables.js +137 -28
  44. package/lib/esm/repository/utils.d.ts +28 -6
  45. package/lib/esm/repository/utils.js +29 -7
  46. package/lib/esm/utils/errors.d.ts +5 -5
  47. package/lib/esm/utils/errors.js +9 -9
  48. package/lib/identity/decorators.cjs +1 -1
  49. package/lib/index.cjs +1 -1
  50. package/lib/index.d.ts +1 -1
  51. package/lib/model/types.cjs +1 -1
  52. package/lib/model/types.d.ts +0 -9
  53. package/lib/persistence/Adapter.cjs +119 -46
  54. package/lib/persistence/Adapter.d.ts +61 -51
  55. package/lib/persistence/Dispatch.cjs +6 -14
  56. package/lib/persistence/Dispatch.d.ts +2 -13
  57. package/lib/persistence/errors.cjs +3 -3
  58. package/lib/persistence/errors.d.ts +2 -2
  59. package/lib/persistence/types.cjs +1 -1
  60. package/lib/persistence/types.d.ts +2 -0
  61. package/lib/query/Condition.cjs +9 -1
  62. package/lib/query/Condition.d.ts +8 -0
  63. package/lib/query/Paginator.cjs +1 -1
  64. package/lib/query/Paginator.d.ts +2 -2
  65. package/lib/query/Statement.cjs +4 -2
  66. package/lib/query/Statement.d.ts +4 -3
  67. package/lib/query/errors.cjs +5 -5
  68. package/lib/query/errors.d.ts +3 -3
  69. package/lib/ram/RamAdapter.cjs +43 -32
  70. package/lib/ram/RamAdapter.d.ts +8 -14
  71. package/lib/ram/RamContext.cjs +15 -7
  72. package/lib/ram/RamContext.d.ts +14 -6
  73. package/lib/ram/constants.cjs +2 -3
  74. package/lib/ram/constants.d.ts +1 -2
  75. package/lib/ram/types.cjs +1 -1
  76. package/lib/ram/types.d.ts +3 -0
  77. package/lib/repository/Repository.cjs +8 -8
  78. package/lib/repository/Repository.d.ts +8 -7
  79. package/lib/repository/constants.cjs +6 -5
  80. package/lib/repository/constants.d.ts +5 -4
  81. package/lib/repository/decorators.cjs +12 -9
  82. package/lib/repository/decorators.d.ts +1 -1
  83. package/lib/repository/errors.cjs +3 -3
  84. package/lib/repository/errors.d.ts +2 -2
  85. package/lib/repository/injectables.cjs +137 -28
  86. package/lib/repository/injectables.d.ts +82 -11
  87. package/lib/repository/utils.cjs +29 -7
  88. package/lib/repository/utils.d.ts +28 -6
  89. package/lib/utils/errors.cjs +8 -8
  90. package/lib/utils/errors.d.ts +5 -5
  91. package/package.json +3 -2
@@ -1,4 +1,4 @@
1
- import { BaseError } from "@decaf-ts/db-decorators";
1
+ import { InternalError } from "@decaf-ts/db-decorators";
2
2
  /**
3
3
  * @description Error thrown when observer communication fails.
4
4
  * @summary Represents a failure in observer communication between repositories.
@@ -14,9 +14,9 @@ import { BaseError } from "@decaf-ts/db-decorators";
14
14
  * }
15
15
  * }
16
16
  */
17
- export class ObserverError extends BaseError {
17
+ export class ObserverError extends InternalError {
18
18
  constructor(msg) {
19
- super(ObserverError.name, msg, 500);
19
+ super(msg, ObserverError.name, 500);
20
20
  }
21
21
  }
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlcG9zaXRvcnkvZXJyb3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUVwRDs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUNILE1BQU0sT0FBTyxhQUFjLFNBQVEsU0FBUztJQUMxQyxZQUFZLEdBQW1CO1FBQzdCLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN0QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlRXJyb3IgfSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnNcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRXJyb3IgdGhyb3duIHdoZW4gb2JzZXJ2ZXIgY29tbXVuaWNhdGlvbiBmYWlscy5cbiAqIEBzdW1tYXJ5IFJlcHJlc2VudHMgYSBmYWlsdXJlIGluIG9ic2VydmVyIGNvbW11bmljYXRpb24gYmV0d2VlbiByZXBvc2l0b3JpZXMuXG4gKiBAcGFyYW0ge3N0cmluZ3xFcnJvcn0gbXNnIC0gVGhlIGVycm9yIG1lc3NhZ2Ugb3IgRXJyb3Igb2JqZWN0LlxuICogQGNsYXNzIE9ic2VydmVyRXJyb3JcbiAqIEBjYXRlZ29yeSBFcnJvcnNcbiAqIEBleGFtcGxlXG4gKiB0cnkge1xuICogICAvLyBTb21lIHJlcG9zaXRvcnkgb2JzZXJ2ZXIgb3BlcmF0aW9uXG4gKiB9IGNhdGNoIChlcnJvcikge1xuICogICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBPYnNlcnZlckVycm9yKSB7XG4gKiAgICAgY29uc29sZS5lcnJvcignT2JzZXJ2ZXIgY29tbXVuaWNhdGlvbiBmYWlsZWQ6JywgZXJyb3IubWVzc2FnZSk7XG4gKiAgIH1cbiAqIH1cbiAqL1xuZXhwb3J0IGNsYXNzIE9ic2VydmVyRXJyb3IgZXh0ZW5kcyBCYXNlRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihtc2c6IHN0cmluZyB8IEVycm9yKSB7XG4gICAgc3VwZXIoT2JzZXJ2ZXJFcnJvci5uYW1lLCBtc2csIDUwMCk7XG4gIH1cbn1cbiJdfQ==
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlcG9zaXRvcnkvZXJyb3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUV4RDs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUNILE1BQU0sT0FBTyxhQUFjLFNBQVEsYUFBYTtJQUM5QyxZQUFZLEdBQW1CO1FBQzdCLEtBQUssQ0FBQyxHQUFHLEVBQUUsYUFBYSxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN0QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbnRlcm5hbEVycm9yIH0gZnJvbSBcIkBkZWNhZi10cy9kYi1kZWNvcmF0b3JzXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEVycm9yIHRocm93biB3aGVuIG9ic2VydmVyIGNvbW11bmljYXRpb24gZmFpbHMuXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIGEgZmFpbHVyZSBpbiBvYnNlcnZlciBjb21tdW5pY2F0aW9uIGJldHdlZW4gcmVwb3NpdG9yaWVzLlxuICogQHBhcmFtIHtzdHJpbmd8RXJyb3J9IG1zZyAtIFRoZSBlcnJvciBtZXNzYWdlIG9yIEVycm9yIG9iamVjdC5cbiAqIEBjbGFzcyBPYnNlcnZlckVycm9yXG4gKiBAY2F0ZWdvcnkgRXJyb3JzXG4gKiBAZXhhbXBsZVxuICogdHJ5IHtcbiAqICAgLy8gU29tZSByZXBvc2l0b3J5IG9ic2VydmVyIG9wZXJhdGlvblxuICogfSBjYXRjaCAoZXJyb3IpIHtcbiAqICAgaWYgKGVycm9yIGluc3RhbmNlb2YgT2JzZXJ2ZXJFcnJvcikge1xuICogICAgIGNvbnNvbGUuZXJyb3IoJ09ic2VydmVyIGNvbW11bmljYXRpb24gZmFpbGVkOicsIGVycm9yLm1lc3NhZ2UpO1xuICogICB9XG4gKiB9XG4gKi9cbmV4cG9ydCBjbGFzcyBPYnNlcnZlckVycm9yIGV4dGVuZHMgSW50ZXJuYWxFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihtc2csIE9ic2VydmVyRXJyb3IubmFtZSwgNTAwKTtcbiAgfVxufVxuIl19
@@ -1,24 +1,95 @@
1
1
  import { InjectableRegistryImp } from "@decaf-ts/injectable-decorators";
2
2
  import { Constructor } from "@decaf-ts/decorator-validation";
3
+ import { Logger } from "@decaf-ts/logging";
3
4
  /**
4
- * @description Registry for injectable repositories.
5
- * @summary Extends the base injectable registry to provide automatic repository resolution for models.
6
- * @param {void} - No constructor parameters required.
5
+ * @description Registry for injectable repositories with auto-resolution.
6
+ * @summary Provides an InjectableRegistry implementation that resolves repositories by model name or constructor. If a repository
7
+ * is not explicitly registered, it attempts to infer the correct repository using model metadata and the active or specified adapter flavour.
8
+ * @param {void} [constructor] No constructor parameters required; the superclass handles internal state.
7
9
  * @class InjectablesRegistry
8
10
  * @example
11
+ * // Basic usage: retrieve a repository by model name
9
12
  * const registry = new InjectablesRegistry();
10
13
  * const userRepo = registry.get<UserRepository>('User');
11
- * // If UserRepository exists, it will be returned
12
- * // If not, but User model exists, a repository will be created for it
14
+ * // If UserRepository is registered, it will be returned. Otherwise, a repository will be created if a User model exists.
15
+ *
16
+ * // Retrieve by constructor and specify adapter flavour
17
+ * const repoByCtor = registry.get<UserRepository>(UserModel, 'ram');
18
+ *
19
+ * // Retrieve by symbol (e.g., injectable token)
20
+ * const token = Symbol.for('UserRepository');
21
+ * const byToken = registry.get<UserRepository>(token);
22
+ * @mermaid
23
+ * sequenceDiagram
24
+ * participant C as Consumer
25
+ * participant R as InjectablesRegistry
26
+ * participant B as BaseRegistry
27
+ * participant M as Model
28
+ * participant A as Adapter
29
+ * participant RP as Repository
30
+ * C->>R: get(name, flavour?)
31
+ * activate R
32
+ * R->>B: super.get(name)
33
+ * alt Found in base registry
34
+ * B-->>R: injectable
35
+ * R-->>C: injectable
36
+ * else Not found
37
+ * R->>M: Model.get(name)
38
+ * alt Model found
39
+ * R->>A: resolve flavour (from arg/metadata/current)
40
+ * R->>RP: Repository.forModel(modelCtor, alias)
41
+ * alt Repository instance
42
+ * RP-->>R: repository instance
43
+ * R-->>C: repository instance
44
+ * else Repository ctor
45
+ * R->>A: Adapter.get(resolvedFlavour) or Adapter.current
46
+ * A-->>R: adapter instance
47
+ * R->>RP: new repoCtor(adapter, modelCtor)
48
+ * R-->>C: repository instance
49
+ * end
50
+ * else Model not found
51
+ * R-->>C: undefined
52
+ * end
53
+ * end
13
54
  */
14
55
  export declare class InjectablesRegistry extends InjectableRegistryImp {
56
+ private logger?;
57
+ protected get log(): Logger;
15
58
  constructor();
16
59
  /**
17
- * @description Gets an injectable by name with repository auto-resolution.
18
- * @summary Extends the base get method to automatically resolve repositories for models when not found directly.
19
- * @template T - The type of injectable to return.
20
- * @param {string} name - The name of the injectable to retrieve.
21
- * @return {T | undefined} - The injectable instance or undefined if not found.
60
+ * @description Retrieve an injectable with repository auto-resolution.
61
+ * @summary Attempts to get an injectable from the base registry; if not found and the name refers to a known model, it
62
+ * resolves the appropriate repository using the specified flavour or model metadata, falling back to the current adapter when needed.
63
+ * @template T The injectable type to be returned.
64
+ * @param {string | symbol | Constructor<T>} name Token, model name, or constructor associated with the injectable or model.
65
+ * @param {string} [flavour] Optional adapter flavour (e.g., "ram"). If omitted, derives from metadata or current adapter.
66
+ * @return {T | undefined} The located or auto-created injectable instance; otherwise undefined if it cannot be resolved.
67
+ * @mermaid
68
+ * sequenceDiagram
69
+ * participant G as get(name, flavour?)
70
+ * participant BR as BaseRegistry
71
+ * participant M as Model
72
+ * participant A as Adapter
73
+ * participant RP as Repository
74
+ * G->>BR: super.get(name)
75
+ * alt Found
76
+ * BR-->>G: injectable
77
+ * else Not found
78
+ * G->>M: derive modelCtor from name
79
+ * alt modelCtor resolved
80
+ * G->>A: resolve flavour (arg | metadata | current)
81
+ * G->>RP: Repository.forModel(modelCtor, alias)
82
+ * alt returns instance
83
+ * RP-->>G: Repository instance
84
+ * else returns ctor
85
+ * G->>A: Adapter.get(flavour) | Adapter.current
86
+ * A-->>G: adapter instance
87
+ * G->>RP: new repoCtor(adapter, modelCtor)
88
+ * end
89
+ * else no modelCtor
90
+ * G-->>G: return undefined
91
+ * end
92
+ * end
22
93
  */
23
- get<T>(name: symbol | Constructor<T>, flavour?: string): T | undefined;
94
+ get<T>(name: symbol | Constructor<T> | string, flavour?: string): T | undefined;
24
95
  }
@@ -4,53 +4,162 @@ import { Model, } from "@decaf-ts/decorator-validation";
4
4
  import { generateInjectableNameForRepository } from "./utils.js";
5
5
  import { PersistenceKeys } from "./../persistence/constants.js";
6
6
  import { Adapter } from "./../persistence/Adapter.js";
7
+ import { Logging } from "@decaf-ts/logging";
7
8
  /**
8
- * @description Registry for injectable repositories.
9
- * @summary Extends the base injectable registry to provide automatic repository resolution for models.
10
- * @param {void} - No constructor parameters required.
9
+ * @description Registry for injectable repositories with auto-resolution.
10
+ * @summary Provides an InjectableRegistry implementation that resolves repositories by model name or constructor. If a repository
11
+ * is not explicitly registered, it attempts to infer the correct repository using model metadata and the active or specified adapter flavour.
12
+ * @param {void} [constructor] No constructor parameters required; the superclass handles internal state.
11
13
  * @class InjectablesRegistry
12
14
  * @example
15
+ * // Basic usage: retrieve a repository by model name
13
16
  * const registry = new InjectablesRegistry();
14
17
  * const userRepo = registry.get<UserRepository>('User');
15
- * // If UserRepository exists, it will be returned
16
- * // If not, but User model exists, a repository will be created for it
18
+ * // If UserRepository is registered, it will be returned. Otherwise, a repository will be created if a User model exists.
19
+ *
20
+ * // Retrieve by constructor and specify adapter flavour
21
+ * const repoByCtor = registry.get<UserRepository>(UserModel, 'ram');
22
+ *
23
+ * // Retrieve by symbol (e.g., injectable token)
24
+ * const token = Symbol.for('UserRepository');
25
+ * const byToken = registry.get<UserRepository>(token);
26
+ * @mermaid
27
+ * sequenceDiagram
28
+ * participant C as Consumer
29
+ * participant R as InjectablesRegistry
30
+ * participant B as BaseRegistry
31
+ * participant M as Model
32
+ * participant A as Adapter
33
+ * participant RP as Repository
34
+ * C->>R: get(name, flavour?)
35
+ * activate R
36
+ * R->>B: super.get(name)
37
+ * alt Found in base registry
38
+ * B-->>R: injectable
39
+ * R-->>C: injectable
40
+ * else Not found
41
+ * R->>M: Model.get(name)
42
+ * alt Model found
43
+ * R->>A: resolve flavour (from arg/metadata/current)
44
+ * R->>RP: Repository.forModel(modelCtor, alias)
45
+ * alt Repository instance
46
+ * RP-->>R: repository instance
47
+ * R-->>C: repository instance
48
+ * else Repository ctor
49
+ * R->>A: Adapter.get(resolvedFlavour) or Adapter.current
50
+ * A-->>R: adapter instance
51
+ * R->>RP: new repoCtor(adapter, modelCtor)
52
+ * R-->>C: repository instance
53
+ * end
54
+ * else Model not found
55
+ * R-->>C: undefined
56
+ * end
57
+ * end
17
58
  */
18
59
  export class InjectablesRegistry extends InjectableRegistryImp {
60
+ get log() {
61
+ if (!this.logger)
62
+ this.logger = Logging.for(this);
63
+ return this.logger;
64
+ }
19
65
  constructor() {
20
66
  super();
21
67
  }
22
68
  /**
23
- * @description Gets an injectable by name with repository auto-resolution.
24
- * @summary Extends the base get method to automatically resolve repositories for models when not found directly.
25
- * @template T - The type of injectable to return.
26
- * @param {string} name - The name of the injectable to retrieve.
27
- * @return {T | undefined} - The injectable instance or undefined if not found.
69
+ * @description Retrieve an injectable with repository auto-resolution.
70
+ * @summary Attempts to get an injectable from the base registry; if not found and the name refers to a known model, it
71
+ * resolves the appropriate repository using the specified flavour or model metadata, falling back to the current adapter when needed.
72
+ * @template T The injectable type to be returned.
73
+ * @param {string | symbol | Constructor<T>} name Token, model name, or constructor associated with the injectable or model.
74
+ * @param {string} [flavour] Optional adapter flavour (e.g., "ram"). If omitted, derives from metadata or current adapter.
75
+ * @return {T | undefined} The located or auto-created injectable instance; otherwise undefined if it cannot be resolved.
76
+ * @mermaid
77
+ * sequenceDiagram
78
+ * participant G as get(name, flavour?)
79
+ * participant BR as BaseRegistry
80
+ * participant M as Model
81
+ * participant A as Adapter
82
+ * participant RP as Repository
83
+ * G->>BR: super.get(name)
84
+ * alt Found
85
+ * BR-->>G: injectable
86
+ * else Not found
87
+ * G->>M: derive modelCtor from name
88
+ * alt modelCtor resolved
89
+ * G->>A: resolve flavour (arg | metadata | current)
90
+ * G->>RP: Repository.forModel(modelCtor, alias)
91
+ * alt returns instance
92
+ * RP-->>G: Repository instance
93
+ * else returns ctor
94
+ * G->>A: Adapter.get(flavour) | Adapter.current
95
+ * A-->>G: adapter instance
96
+ * G->>RP: new repoCtor(adapter, modelCtor)
97
+ * end
98
+ * else no modelCtor
99
+ * G-->>G: return undefined
100
+ * end
101
+ * end
28
102
  */
29
103
  get(name, flavour) {
30
- let injectable = super.get(name);
31
- if (!injectable)
104
+ const log = this.log.for(this.get);
105
+ // First, try base registry, but guard against thrown errors
106
+ let injectable;
107
+ try {
108
+ injectable = super.get(name);
109
+ }
110
+ catch {
111
+ // do nothing. we handle it later
112
+ }
113
+ if (!injectable) {
114
+ let modelCtor;
115
+ if (typeof name === "function")
116
+ modelCtor = name;
117
+ else if (typeof name === "symbol" || typeof name === "string") {
118
+ modelCtor = Model.get(name.toString());
119
+ }
120
+ if (!modelCtor)
121
+ return undefined;
122
+ // Resolve flavour from metadata if not provided
123
+ const metaKey = Adapter.key(PersistenceKeys.ADAPTER);
124
+ const resolvedFlavour = flavour ||
125
+ Reflect.getMetadata(metaKey, modelCtor);
32
126
  try {
33
- let m = name;
34
- if (typeof name === "symbol" || typeof name === "string") {
35
- m = Model.get(name.toString());
127
+ // Determine an alias to use: prefer a directly registered adapter; otherwise, if the current adapter
128
+ // has the same flavour, use its alias to satisfy Repository.forModel/Adapter.get lookups.
129
+ let aliasToUse = resolvedFlavour;
130
+ try {
131
+ if (resolvedFlavour)
132
+ Adapter.get(resolvedFlavour);
36
133
  }
37
- if (m)
38
- injectable = Repository.forModel(m, flavour);
39
- if (injectable) {
40
- if (injectable instanceof Repository)
41
- return injectable;
42
- flavour =
43
- flavour ||
44
- Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), injectable.constructor) ||
45
- Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), m);
46
- Injectables.register(injectable, generateInjectableNameForRepository(m, flavour));
134
+ catch {
135
+ const current = Adapter.current;
136
+ if (current && current.flavour === resolvedFlavour)
137
+ aliasToUse = current.alias;
47
138
  }
48
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
139
+ injectable = Repository.forModel(modelCtor, aliasToUse);
140
+ if (injectable instanceof Repository)
141
+ return injectable;
142
+ // Otherwise, register the resolved injectable name for later retrieval
143
+ const f = resolvedFlavour ||
144
+ Reflect.getMetadata(metaKey, injectable.constructor) ||
145
+ Reflect.getMetadata(metaKey, modelCtor);
146
+ Injectables.register(injectable, generateInjectableNameForRepository(modelCtor, f));
49
147
  }
50
148
  catch (e) {
51
- return undefined;
149
+ log.debug(`No registered repository or adapter found. falling back to default adapter`);
150
+ const repoCtor = Repository["get"](modelCtor, resolvedFlavour);
151
+ if (typeof repoCtor === "function") {
152
+ const adapter = resolvedFlavour
153
+ ? Adapter.get(resolvedFlavour)
154
+ : Adapter.current;
155
+ if (!adapter)
156
+ return undefined;
157
+ const instance = new repoCtor(adapter, modelCtor);
158
+ return instance;
159
+ }
52
160
  }
161
+ }
53
162
  return injectable;
54
163
  }
55
164
  }
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0YWJsZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVwb3NpdG9yeS9pbmplY3RhYmxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wscUJBQXFCLEVBQ3JCLFdBQVcsR0FDWixNQUFNLGlDQUFpQyxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxVQUFVLEVBQUUsd0JBQXFCO0FBQzFDLE9BQU8sRUFFTCxLQUFLLEdBRU4sTUFBTSxnQ0FBZ0MsQ0FBQztBQUN4QyxPQUFPLEVBQUUsbUNBQW1DLEVBQUUsbUJBQWdCO0FBQzlELE9BQU8sRUFBRSxlQUFlLEVBQUUsc0NBQWlDO0FBQzNELE9BQU8sRUFBRSxPQUFPLEVBQUUsb0NBQStCO0FBRWpEOzs7Ozs7Ozs7O0dBVUc7QUFDSCxNQUFNLE9BQU8sbUJBQW9CLFNBQVEscUJBQXFCO0lBQzVEO1FBQ0UsS0FBSyxFQUFFLENBQUM7SUFDVixDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ00sR0FBRyxDQUNWLElBQTZCLEVBQzdCLE9BQWdCO1FBRWhCLElBQUksVUFBVSxHQUFHLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDakMsSUFBSSxDQUFDLFVBQVU7WUFDYixJQUFJLENBQUM7Z0JBQ0gsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDO2dCQUNiLElBQUksT0FBTyxJQUFJLEtBQUssUUFBUSxJQUFJLE9BQU8sSUFBSSxLQUFLLFFBQVEsRUFBRSxDQUFDO29CQUN6RCxDQUFDLEdBQUcsS0FBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQTBCLENBQUM7Z0JBQzFELENBQUM7Z0JBQ0QsSUFBSSxDQUFDO29CQUNILFVBQVUsR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQXFCLEVBQUUsT0FBTyxDQUFNLENBQUM7Z0JBQ3hFLElBQUksVUFBVSxFQUFFLENBQUM7b0JBQ2YsSUFBSSxVQUFVLFlBQVksVUFBVTt3QkFBRSxPQUFPLFVBQWUsQ0FBQztvQkFDN0QsT0FBTzt3QkFDTCxPQUFPOzRCQUNQLE9BQU8sQ0FBQyxXQUFXLENBQ2pCLE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUNwQyxVQUFVLENBQUMsV0FBVyxDQUN2Qjs0QkFDRCxPQUFPLENBQUMsV0FBVyxDQUNqQixPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsRUFDcEMsQ0FBMEIsQ0FDM0IsQ0FBQztvQkFDSixXQUFXLENBQUMsUUFBUSxDQUNsQixVQUFVLEVBQ1YsbUNBQW1DLENBQ2pDLENBQTBCLEVBQzFCLE9BQU8sQ0FDUixDQUNGLENBQUM7Z0JBQ0osQ0FBQztnQkFDRCw2REFBNkQ7WUFDL0QsQ0FBQztZQUFDLE9BQU8sQ0FBTSxFQUFFLENBQUM7Z0JBQ2hCLE9BQU8sU0FBUyxDQUFDO1lBQ25CLENBQUM7UUFDSCxPQUFPLFVBQTJCLENBQUM7SUFDckMsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgSW5qZWN0YWJsZVJlZ2lzdHJ5SW1wLFxuICBJbmplY3RhYmxlcyxcbn0gZnJvbSBcIkBkZWNhZi10cy9pbmplY3RhYmxlLWRlY29yYXRvcnNcIjtcbmltcG9ydCB7IFJlcG9zaXRvcnkgfSBmcm9tIFwiLi9SZXBvc2l0b3J5XCI7XG5pbXBvcnQge1xuICBDb25zdHJ1Y3RvcixcbiAgTW9kZWwsXG4gIE1vZGVsQ29uc3RydWN0b3IsXG59IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcbmltcG9ydCB7IGdlbmVyYXRlSW5qZWN0YWJsZU5hbWVGb3JSZXBvc2l0b3J5IH0gZnJvbSBcIi4vdXRpbHNcIjtcbmltcG9ydCB7IFBlcnNpc3RlbmNlS2V5cyB9IGZyb20gXCIuLi9wZXJzaXN0ZW5jZS9jb25zdGFudHNcIjtcbmltcG9ydCB7IEFkYXB0ZXIgfSBmcm9tIFwiLi4vcGVyc2lzdGVuY2UvQWRhcHRlclwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBSZWdpc3RyeSBmb3IgaW5qZWN0YWJsZSByZXBvc2l0b3JpZXMuXG4gKiBAc3VtbWFyeSBFeHRlbmRzIHRoZSBiYXNlIGluamVjdGFibGUgcmVnaXN0cnkgdG8gcHJvdmlkZSBhdXRvbWF0aWMgcmVwb3NpdG9yeSByZXNvbHV0aW9uIGZvciBtb2RlbHMuXG4gKiBAcGFyYW0ge3ZvaWR9IC0gTm8gY29uc3RydWN0b3IgcGFyYW1ldGVycyByZXF1aXJlZC5cbiAqIEBjbGFzcyBJbmplY3RhYmxlc1JlZ2lzdHJ5XG4gKiBAZXhhbXBsZVxuICogY29uc3QgcmVnaXN0cnkgPSBuZXcgSW5qZWN0YWJsZXNSZWdpc3RyeSgpO1xuICogY29uc3QgdXNlclJlcG8gPSByZWdpc3RyeS5nZXQ8VXNlclJlcG9zaXRvcnk+KCdVc2VyJyk7XG4gKiAvLyBJZiBVc2VyUmVwb3NpdG9yeSBleGlzdHMsIGl0IHdpbGwgYmUgcmV0dXJuZWRcbiAqIC8vIElmIG5vdCwgYnV0IFVzZXIgbW9kZWwgZXhpc3RzLCBhIHJlcG9zaXRvcnkgd2lsbCBiZSBjcmVhdGVkIGZvciBpdFxuICovXG5leHBvcnQgY2xhc3MgSW5qZWN0YWJsZXNSZWdpc3RyeSBleHRlbmRzIEluamVjdGFibGVSZWdpc3RyeUltcCB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG4gIH1cblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIEdldHMgYW4gaW5qZWN0YWJsZSBieSBuYW1lIHdpdGggcmVwb3NpdG9yeSBhdXRvLXJlc29sdXRpb24uXG4gICAqIEBzdW1tYXJ5IEV4dGVuZHMgdGhlIGJhc2UgZ2V0IG1ldGhvZCB0byBhdXRvbWF0aWNhbGx5IHJlc29sdmUgcmVwb3NpdG9yaWVzIGZvciBtb2RlbHMgd2hlbiBub3QgZm91bmQgZGlyZWN0bHkuXG4gICAqIEB0ZW1wbGF0ZSBUIC0gVGhlIHR5cGUgb2YgaW5qZWN0YWJsZSB0byByZXR1cm4uXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBuYW1lIC0gVGhlIG5hbWUgb2YgdGhlIGluamVjdGFibGUgdG8gcmV0cmlldmUuXG4gICAqIEByZXR1cm4ge1QgfCB1bmRlZmluZWR9IC0gVGhlIGluamVjdGFibGUgaW5zdGFuY2Ugb3IgdW5kZWZpbmVkIGlmIG5vdCBmb3VuZC5cbiAgICovXG4gIG92ZXJyaWRlIGdldDxUPihcbiAgICBuYW1lOiBzeW1ib2wgfCBDb25zdHJ1Y3RvcjxUPixcbiAgICBmbGF2b3VyPzogc3RyaW5nXG4gICk6IFQgfCB1bmRlZmluZWQge1xuICAgIGxldCBpbmplY3RhYmxlID0gc3VwZXIuZ2V0KG5hbWUpO1xuICAgIGlmICghaW5qZWN0YWJsZSlcbiAgICAgIHRyeSB7XG4gICAgICAgIGxldCBtID0gbmFtZTtcbiAgICAgICAgaWYgKHR5cGVvZiBuYW1lID09PSBcInN5bWJvbFwiIHx8IHR5cGVvZiBuYW1lID09PSBcInN0cmluZ1wiKSB7XG4gICAgICAgICAgbSA9IE1vZGVsLmdldChuYW1lLnRvU3RyaW5nKCkpIGFzIE1vZGVsQ29uc3RydWN0b3I8YW55PjtcbiAgICAgICAgfVxuICAgICAgICBpZiAobSlcbiAgICAgICAgICBpbmplY3RhYmxlID0gUmVwb3NpdG9yeS5mb3JNb2RlbChtIGFzIENvbnN0cnVjdG9yPGFueT4sIGZsYXZvdXIpIGFzIFQ7XG4gICAgICAgIGlmIChpbmplY3RhYmxlKSB7XG4gICAgICAgICAgaWYgKGluamVjdGFibGUgaW5zdGFuY2VvZiBSZXBvc2l0b3J5KSByZXR1cm4gaW5qZWN0YWJsZSBhcyBUO1xuICAgICAgICAgIGZsYXZvdXIgPVxuICAgICAgICAgICAgZmxhdm91ciB8fFxuICAgICAgICAgICAgUmVmbGVjdC5nZXRNZXRhZGF0YShcbiAgICAgICAgICAgICAgQWRhcHRlci5rZXkoUGVyc2lzdGVuY2VLZXlzLkFEQVBURVIpLFxuICAgICAgICAgICAgICBpbmplY3RhYmxlLmNvbnN0cnVjdG9yXG4gICAgICAgICAgICApIHx8XG4gICAgICAgICAgICBSZWZsZWN0LmdldE1ldGFkYXRhKFxuICAgICAgICAgICAgICBBZGFwdGVyLmtleShQZXJzaXN0ZW5jZUtleXMuQURBUFRFUiksXG4gICAgICAgICAgICAgIG0gYXMgTW9kZWxDb25zdHJ1Y3Rvcjxhbnk+XG4gICAgICAgICAgICApO1xuICAgICAgICAgIEluamVjdGFibGVzLnJlZ2lzdGVyKFxuICAgICAgICAgICAgaW5qZWN0YWJsZSxcbiAgICAgICAgICAgIGdlbmVyYXRlSW5qZWN0YWJsZU5hbWVGb3JSZXBvc2l0b3J5KFxuICAgICAgICAgICAgICBtIGFzIE1vZGVsQ29uc3RydWN0b3I8YW55PixcbiAgICAgICAgICAgICAgZmxhdm91clxuICAgICAgICAgICAgKVxuICAgICAgICAgICk7XG4gICAgICAgIH1cbiAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFyc1xuICAgICAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgICB9XG4gICAgcmV0dXJuIGluamVjdGFibGUgYXMgVCB8IHVuZGVmaW5lZDtcbiAgfVxufVxuIl19
165
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"injectables.js","sourceRoot":"","sources":["../../../src/repository/injectables.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,qBAAqB,EACrB,WAAW,GACZ,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,wBAAqB;AAC1C,OAAO,EAEL,KAAK,GAEN,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,mCAAmC,EAAE,mBAAgB;AAC9D,OAAO,EAAE,eAAe,EAAE,sCAAiC;AAC3D,OAAO,EAAE,OAAO,EAAE,oCAA+B;AACjD,OAAO,EAAU,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAEpD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkDG;AACH,MAAM,OAAO,mBAAoB,SAAQ,qBAAqB;IAG5D,IAAc,GAAG;QACf,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,IAAW,CAAC,CAAC;QACzD,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;QACE,KAAK,EAAE,CAAC;IACV,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAkCG;IACM,GAAG,CACV,IAAsC,EACtC,OAAgB;QAEhB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnC,4DAA4D;QAC5D,IAAI,UAAyB,CAAC;QAC9B,IAAI,CAAC;YACH,UAAU,GAAG,KAAK,CAAC,GAAG,CAAC,IAAW,CAAC,CAAC;QACtC,CAAC;QAAC,MAAM,CAAC;YACP,iCAAiC;QACnC,CAAC;QAED,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,IAAI,SAAuC,CAAC;YAC5C,IAAI,OAAO,IAAI,KAAK,UAAU;gBAAE,SAAS,GAAG,IAAwB,CAAC;iBAChE,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;gBAC9D,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAA0B,CAAC;YAClE,CAAC;YAED,IAAI,CAAC,SAAS;gBAAE,OAAO,SAAS,CAAC;YAEjC,gDAAgD;YAChD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;YACrD,MAAM,eAAe,GACnB,OAAO;gBACN,OAAO,CAAC,WAAW,CAAC,OAAO,EAAE,SAAS,CAAwB,CAAC;YAElE,IAAI,CAAC;gBACH,qGAAqG;gBACrG,0FAA0F;gBAC1F,IAAI,UAAU,GAAG,eAAe,CAAC;gBACjC,IAAI,CAAC;oBACH,IAAI,eAAe;wBAAE,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;gBACpD,CAAC;gBAAC,MAAM,CAAC;oBACP,MAAM,OAAO,GAAG,OAAO,CAAC,OAAc,CAAC;oBACvC,IAAI,OAAO,IAAI,OAAO,CAAC,OAAO,KAAK,eAAe;wBAChD,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC;gBAC/B,CAAC;gBAED,UAAU,GAAG,UAAU,CAAC,QAAQ,CAC9B,SAA6B,EAC7B,UAAU,CACN,CAAC;gBACP,IAAI,UAAU,YAAY,UAAU;oBAAE,OAAO,UAAe,CAAC;gBAE7D,uEAAuE;gBACvE,MAAM,CAAC,GACL,eAAe;oBACd,OAAO,CAAC,WAAW,CAAC,OAAO,EAAG,UAAkB,CAAC,WAAW,CAE/C;oBACb,OAAO,CAAC,WAAW,CAAC,OAAO,EAAE,SAAS,CAAwB,CAAC;gBAClE,WAAW,CAAC,QAAQ,CAClB,UAAU,EACV,mCAAmC,CACjC,SAAkC,EAClC,CAAW,CACZ,CACF,CAAC;YACJ,CAAC;YAAC,OAAO,CAAU,EAAE,CAAC;gBACpB,GAAG,CAAC,KAAK,CACP,4EAA4E,CAC7E,CAAC;gBACF,MAAM,QAAQ,GAAI,UAAkB,CAAC,KAAK,CAAC,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;gBACxE,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE,CAAC;oBACnC,MAAM,OAAO,GAAG,eAAe;wBAC7B,CAAC,CAAE,OAAO,CAAC,GAAG,CAAC,eAAe,CAAS;wBACvC,CAAC,CAAE,OAAO,CAAC,OAAe,CAAC;oBAC7B,IAAI,CAAC,OAAO;wBAAE,OAAO,SAAS,CAAC;oBAC/B,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;oBAClD,OAAO,QAAa,CAAC;gBACvB,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,UAA2B,CAAC;IACrC,CAAC;CACF","sourcesContent":["import {\n  InjectableRegistryImp,\n  Injectables,\n} from \"@decaf-ts/injectable-decorators\";\nimport { Repository } from \"./Repository\";\nimport {\n  Constructor,\n  Model,\n  ModelConstructor,\n} from \"@decaf-ts/decorator-validation\";\nimport { generateInjectableNameForRepository } from \"./utils\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\n\n/**\n * @description Registry for injectable repositories with auto-resolution.\n * @summary Provides an InjectableRegistry implementation that resolves repositories by model name or constructor. If a repository\n * is not explicitly registered, it attempts to infer the correct repository using model metadata and the active or specified adapter flavour.\n * @param {void} [constructor] No constructor parameters required; the superclass handles internal state.\n * @class InjectablesRegistry\n * @example\n * // Basic usage: retrieve a repository by model name\n * const registry = new InjectablesRegistry();\n * const userRepo = registry.get<UserRepository>('User');\n * // If UserRepository is registered, it will be returned. Otherwise, a repository will be created if a User model exists.\n *\n * // Retrieve by constructor and specify adapter flavour\n * const repoByCtor = registry.get<UserRepository>(UserModel, 'ram');\n *\n * // Retrieve by symbol (e.g., injectable token)\n * const token = Symbol.for('UserRepository');\n * const byToken = registry.get<UserRepository>(token);\n * @mermaid\n * sequenceDiagram\n *   participant C as Consumer\n *   participant R as InjectablesRegistry\n *   participant B as BaseRegistry\n *   participant M as Model\n *   participant A as Adapter\n *   participant RP as Repository\n *   C->>R: get(name, flavour?)\n *   activate R\n *   R->>B: super.get(name)\n *   alt Found in base registry\n *     B-->>R: injectable\n *     R-->>C: injectable\n *   else Not found\n *     R->>M: Model.get(name)\n *     alt Model found\n *       R->>A: resolve flavour (from arg/metadata/current)\n *       R->>RP: Repository.forModel(modelCtor, alias)\n *       alt Repository instance\n *         RP-->>R: repository instance\n *         R-->>C: repository instance\n *       else Repository ctor\n *         R->>A: Adapter.get(resolvedFlavour) or Adapter.current\n *         A-->>R: adapter instance\n *         R->>RP: new repoCtor(adapter, modelCtor)\n *         R-->>C: repository instance\n *       end\n *     else Model not found\n *       R-->>C: undefined\n *     end\n *   end\n */\nexport class InjectablesRegistry extends InjectableRegistryImp {\n  private logger?: Logger;\n\n  protected get log(): Logger {\n    if (!this.logger) this.logger = Logging.for(this as any);\n    return this.logger;\n  }\n\n  constructor() {\n    super();\n  }\n\n  /**\n   * @description Retrieve an injectable with repository auto-resolution.\n   * @summary Attempts to get an injectable from the base registry; if not found and the name refers to a known model, it\n   * resolves the appropriate repository using the specified flavour or model metadata, falling back to the current adapter when needed.\n   * @template T The injectable type to be returned.\n   * @param {string | symbol | Constructor<T>} name Token, model name, or constructor associated with the injectable or model.\n   * @param {string} [flavour] Optional adapter flavour (e.g., \"ram\"). If omitted, derives from metadata or current adapter.\n   * @return {T | undefined} The located or auto-created injectable instance; otherwise undefined if it cannot be resolved.\n   * @mermaid\n   * sequenceDiagram\n   *   participant G as get(name, flavour?)\n   *   participant BR as BaseRegistry\n   *   participant M as Model\n   *   participant A as Adapter\n   *   participant RP as Repository\n   *   G->>BR: super.get(name)\n   *   alt Found\n   *     BR-->>G: injectable\n   *   else Not found\n   *     G->>M: derive modelCtor from name\n   *     alt modelCtor resolved\n   *       G->>A: resolve flavour (arg | metadata | current)\n   *       G->>RP: Repository.forModel(modelCtor, alias)\n   *       alt returns instance\n   *         RP-->>G: Repository instance\n   *       else returns ctor\n   *         G->>A: Adapter.get(flavour) | Adapter.current\n   *         A-->>G: adapter instance\n   *         G->>RP: new repoCtor(adapter, modelCtor)\n   *       end\n   *     else no modelCtor\n   *       G-->>G: return undefined\n   *     end\n   *   end\n   */\n  override get<T>(\n    name: symbol | Constructor<T> | string,\n    flavour?: string\n  ): T | undefined {\n    const log = this.log.for(this.get);\n    // First, try base registry, but guard against thrown errors\n    let injectable: T | undefined;\n    try {\n      injectable = super.get(name as any);\n    } catch {\n      // do nothing. we handle it later\n    }\n\n    if (!injectable) {\n      let modelCtor: Constructor<any> | undefined;\n      if (typeof name === \"function\") modelCtor = name as Constructor<any>;\n      else if (typeof name === \"symbol\" || typeof name === \"string\") {\n        modelCtor = Model.get(name.toString()) as ModelConstructor<any>;\n      }\n\n      if (!modelCtor) return undefined;\n\n      // Resolve flavour from metadata if not provided\n      const metaKey = Adapter.key(PersistenceKeys.ADAPTER);\n      const resolvedFlavour =\n        flavour ||\n        (Reflect.getMetadata(metaKey, modelCtor) as string | undefined);\n\n      try {\n        // Determine an alias to use: prefer a directly registered adapter; otherwise, if the current adapter\n        // has the same flavour, use its alias to satisfy Repository.forModel/Adapter.get lookups.\n        let aliasToUse = resolvedFlavour;\n        try {\n          if (resolvedFlavour) Adapter.get(resolvedFlavour);\n        } catch {\n          const current = Adapter.current as any;\n          if (current && current.flavour === resolvedFlavour)\n            aliasToUse = current.alias;\n        }\n\n        injectable = Repository.forModel(\n          modelCtor as Constructor<any>,\n          aliasToUse\n        ) as T;\n        if (injectable instanceof Repository) return injectable as T;\n\n        // Otherwise, register the resolved injectable name for later retrieval\n        const f =\n          resolvedFlavour ||\n          (Reflect.getMetadata(metaKey, (injectable as any).constructor) as\n            | string\n            | undefined) ||\n          (Reflect.getMetadata(metaKey, modelCtor) as string | undefined);\n        Injectables.register(\n          injectable,\n          generateInjectableNameForRepository(\n            modelCtor as ModelConstructor<any>,\n            f as string\n          )\n        );\n      } catch (e: unknown) {\n        log.debug(\n          `No registered repository or adapter found. falling back to default adapter`\n        );\n        const repoCtor = (Repository as any)[\"get\"](modelCtor, resolvedFlavour);\n        if (typeof repoCtor === \"function\") {\n          const adapter = resolvedFlavour\n            ? (Adapter.get(resolvedFlavour) as any)\n            : (Adapter.current as any);\n          if (!adapter) return undefined;\n          const instance = new repoCtor(adapter, modelCtor);\n          return instance as T;\n        }\n      }\n    }\n\n    return injectable as T | undefined;\n  }\n}\n"]}
@@ -2,13 +2,35 @@ import { Constructor } from "@decaf-ts/decorator-validation";
2
2
  import { Model } from "@decaf-ts/decorator-validation";
3
3
  /**
4
4
  * @description Generates a unique injectable name for a repository.
5
- * @summary Creates a standardized name for repository injectables based on model and adapter flavour.
6
- * @template T - The model type that extends Model.
7
- * @param {Constructor<T> | T} model - The model constructor or instance.
8
- * @param {string} [flavour] - Optional adapter flavour. If not provided, it will be retrieved from the model metadata.
9
- * @return {string} The generated injectable name.
10
- * @throws {InternalError} If no flavour is provided and none can be retrieved from the model.
5
+ * @summary Creates a standardized injectable token for repositories using the adapter flavour and model table name.
6
+ * This helps the DI system register and resolve repository instances consistently across adapters.
7
+ * @template T The model type that extends Model.
8
+ * @param {Constructor<T> | T} model The model constructor or instance from which to derive the table name.
9
+ * @param {string} [flavour] Optional adapter flavour/alias. If omitted, it is read from model metadata.
10
+ * @return {string} A namespaced injectable token for the repository (e.g., "db:repo:ram:users").
11
+ * @throws {InternalError} If the flavour cannot be determined from arguments or metadata.
11
12
  * @function generateInjectableNameForRepository
13
+ * @mermaid
14
+ * sequenceDiagram
15
+ * participant C as Caller
16
+ * participant U as generateInjectableNameForRepository
17
+ * participant R as Reflect Metadata
18
+ * participant A as Adapter
19
+ * participant S as String Formatter
20
+ * C->>U: call(model, flavour?)
21
+ * alt flavour provided
22
+ * U-->>U: use provided flavour
23
+ * else flavour not provided
24
+ * U->>A: Adapter.key(ADAPTER)
25
+ * U->>R: getMetadata(key, model|model.ctor)
26
+ * alt metadata present
27
+ * R-->>U: flavour
28
+ * else missing
29
+ * U-->>C: throw InternalError
30
+ * end
31
+ * end
32
+ * U->>S: sf(INJECTABLE, flavour, Repository.table(model))
33
+ * S-->>C: token string
12
34
  * @memberOf module:core
13
35
  */
14
36
  export declare function generateInjectableNameForRepository<T extends Model>(model: Constructor<T> | T, flavour?: string): string;
@@ -6,13 +6,35 @@ import { Model } from "@decaf-ts/decorator-validation";
6
6
  import { Repository } from "./Repository.js";
7
7
  /**
8
8
  * @description Generates a unique injectable name for a repository.
9
- * @summary Creates a standardized name for repository injectables based on model and adapter flavour.
10
- * @template T - The model type that extends Model.
11
- * @param {Constructor<T> | T} model - The model constructor or instance.
12
- * @param {string} [flavour] - Optional adapter flavour. If not provided, it will be retrieved from the model metadata.
13
- * @return {string} The generated injectable name.
14
- * @throws {InternalError} If no flavour is provided and none can be retrieved from the model.
9
+ * @summary Creates a standardized injectable token for repositories using the adapter flavour and model table name.
10
+ * This helps the DI system register and resolve repository instances consistently across adapters.
11
+ * @template T The model type that extends Model.
12
+ * @param {Constructor<T> | T} model The model constructor or instance from which to derive the table name.
13
+ * @param {string} [flavour] Optional adapter flavour/alias. If omitted, it is read from model metadata.
14
+ * @return {string} A namespaced injectable token for the repository (e.g., "db:repo:ram:users").
15
+ * @throws {InternalError} If the flavour cannot be determined from arguments or metadata.
15
16
  * @function generateInjectableNameForRepository
17
+ * @mermaid
18
+ * sequenceDiagram
19
+ * participant C as Caller
20
+ * participant U as generateInjectableNameForRepository
21
+ * participant R as Reflect Metadata
22
+ * participant A as Adapter
23
+ * participant S as String Formatter
24
+ * C->>U: call(model, flavour?)
25
+ * alt flavour provided
26
+ * U-->>U: use provided flavour
27
+ * else flavour not provided
28
+ * U->>A: Adapter.key(ADAPTER)
29
+ * U->>R: getMetadata(key, model|model.ctor)
30
+ * alt metadata present
31
+ * R-->>U: flavour
32
+ * else missing
33
+ * U-->>C: throw InternalError
34
+ * end
35
+ * end
36
+ * U->>S: sf(INJECTABLE, flavour, Repository.table(model))
37
+ * S-->>C: token string
16
38
  * @memberOf module:core
17
39
  */
18
40
  export function generateInjectableNameForRepository(model, flavour) {
@@ -24,4 +46,4 @@ export function generateInjectableNameForRepository(model, flavour) {
24
46
  }
25
47
  return sf(PersistenceKeys.INJECTABLE, flavour, Repository.table(model));
26
48
  }
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVwb3NpdG9yeS91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDeEQsT0FBTyxFQUFlLEVBQUUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxPQUFPLEVBQUUsb0NBQStCO0FBQ2pELE9BQU8sRUFBRSxlQUFlLEVBQUUsc0NBQWlDO0FBQzNELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RCxPQUFPLEVBQUUsVUFBVSxFQUFFLHdCQUFxQjtBQUUxQzs7Ozs7Ozs7OztHQVVHO0FBQ0gsTUFBTSxVQUFVLG1DQUFtQyxDQUNqRCxLQUF5QixFQUN6QixPQUFnQjtJQUVoQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDYixNQUFNLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNqRCxPQUFPLEdBQUcsT0FBTyxDQUFDLFdBQVcsQ0FDM0IsR0FBRyxFQUNILEtBQUssWUFBWSxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FDbkQsQ0FBQztRQUNGLElBQUksQ0FBQyxPQUFPO1lBQ1YsTUFBTSxJQUFJLGFBQWEsQ0FDckIseUNBQXlDLEtBQUssWUFBWSxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQ3hHLENBQUM7SUFDTixDQUFDO0lBQ0QsT0FBTyxFQUFFLENBQUMsZUFBZSxDQUFDLFVBQVUsRUFBRSxPQUFPLEVBQUUsVUFBVSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0FBQzFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbnRlcm5hbEVycm9yIH0gZnJvbSBcIkBkZWNhZi10cy9kYi1kZWNvcmF0b3JzXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3Rvciwgc2YgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBBZGFwdGVyIH0gZnJvbSBcIi4uL3BlcnNpc3RlbmNlL0FkYXB0ZXJcIjtcbmltcG9ydCB7IFBlcnNpc3RlbmNlS2V5cyB9IGZyb20gXCIuLi9wZXJzaXN0ZW5jZS9jb25zdGFudHNcIjtcbmltcG9ydCB7IE1vZGVsIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuaW1wb3J0IHsgUmVwb3NpdG9yeSB9IGZyb20gXCIuL1JlcG9zaXRvcnlcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gR2VuZXJhdGVzIGEgdW5pcXVlIGluamVjdGFibGUgbmFtZSBmb3IgYSByZXBvc2l0b3J5LlxuICogQHN1bW1hcnkgQ3JlYXRlcyBhIHN0YW5kYXJkaXplZCBuYW1lIGZvciByZXBvc2l0b3J5IGluamVjdGFibGVzIGJhc2VkIG9uIG1vZGVsIGFuZCBhZGFwdGVyIGZsYXZvdXIuXG4gKiBAdGVtcGxhdGUgVCAtIFRoZSBtb2RlbCB0eXBlIHRoYXQgZXh0ZW5kcyBNb2RlbC5cbiAqIEBwYXJhbSB7Q29uc3RydWN0b3I8VD4gfCBUfSBtb2RlbCAtIFRoZSBtb2RlbCBjb25zdHJ1Y3RvciBvciBpbnN0YW5jZS5cbiAqIEBwYXJhbSB7c3RyaW5nfSBbZmxhdm91cl0gLSBPcHRpb25hbCBhZGFwdGVyIGZsYXZvdXIuIElmIG5vdCBwcm92aWRlZCwgaXQgd2lsbCBiZSByZXRyaWV2ZWQgZnJvbSB0aGUgbW9kZWwgbWV0YWRhdGEuXG4gKiBAcmV0dXJuIHtzdHJpbmd9IFRoZSBnZW5lcmF0ZWQgaW5qZWN0YWJsZSBuYW1lLlxuICogQHRocm93cyB7SW50ZXJuYWxFcnJvcn0gSWYgbm8gZmxhdm91ciBpcyBwcm92aWRlZCBhbmQgbm9uZSBjYW4gYmUgcmV0cmlldmVkIGZyb20gdGhlIG1vZGVsLlxuICogQGZ1bmN0aW9uIGdlbmVyYXRlSW5qZWN0YWJsZU5hbWVGb3JSZXBvc2l0b3J5XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmNvcmVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdlbmVyYXRlSW5qZWN0YWJsZU5hbWVGb3JSZXBvc2l0b3J5PFQgZXh0ZW5kcyBNb2RlbD4oXG4gIG1vZGVsOiBDb25zdHJ1Y3RvcjxUPiB8IFQsXG4gIGZsYXZvdXI/OiBzdHJpbmdcbik6IHN0cmluZyB7XG4gIGlmICghZmxhdm91cikge1xuICAgIGNvbnN0IGtleSA9IEFkYXB0ZXIua2V5KFBlcnNpc3RlbmNlS2V5cy5BREFQVEVSKTtcbiAgICBmbGF2b3VyID0gUmVmbGVjdC5nZXRNZXRhZGF0YShcbiAgICAgIGtleSxcbiAgICAgIG1vZGVsIGluc3RhbmNlb2YgTW9kZWwgPyBtb2RlbC5jb25zdHJ1Y3RvciA6IG1vZGVsXG4gICAgKTtcbiAgICBpZiAoIWZsYXZvdXIpXG4gICAgICB0aHJvdyBuZXcgSW50ZXJuYWxFcnJvcihcbiAgICAgICAgYENvdWxkIG5vdCByZXRyaWV2ZSBmbGF2b3VyIGZyb20gbW9kZWwgJHttb2RlbCBpbnN0YW5jZW9mIE1vZGVsID8gbW9kZWwuY29uc3RydWN0b3IubmFtZSA6IG1vZGVsLm5hbWV9YFxuICAgICAgKTtcbiAgfVxuICByZXR1cm4gc2YoUGVyc2lzdGVuY2VLZXlzLklOSkVDVEFCTEUsIGZsYXZvdXIsIFJlcG9zaXRvcnkudGFibGUobW9kZWwpKTtcbn1cbiJdfQ==
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVwb3NpdG9yeS91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDeEQsT0FBTyxFQUFlLEVBQUUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxPQUFPLEVBQUUsb0NBQStCO0FBQ2pELE9BQU8sRUFBRSxlQUFlLEVBQUUsc0NBQWlDO0FBQzNELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RCxPQUFPLEVBQUUsVUFBVSxFQUFFLHdCQUFxQjtBQUUxQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FnQ0c7QUFDSCxNQUFNLFVBQVUsbUNBQW1DLENBQ2pELEtBQXlCLEVBQ3pCLE9BQWdCO0lBRWhCLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNiLE1BQU0sR0FBRyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2pELE9BQU8sR0FBRyxPQUFPLENBQUMsV0FBVyxDQUMzQixHQUFHLEVBQ0gsS0FBSyxZQUFZLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUNuRCxDQUFDO1FBQ0YsSUFBSSxDQUFDLE9BQU87WUFDVixNQUFNLElBQUksYUFBYSxDQUNyQix5Q0FBeUMsS0FBSyxZQUFZLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FDeEcsQ0FBQztJQUNOLENBQUM7SUFDRCxPQUFPLEVBQUUsQ0FBQyxlQUFlLENBQUMsVUFBVSxFQUFFLE9BQU8sRUFBRSxVQUFVLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7QUFDMUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEludGVybmFsRXJyb3IgfSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnNcIjtcbmltcG9ydCB7IENvbnN0cnVjdG9yLCBzZiB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcbmltcG9ydCB7IEFkYXB0ZXIgfSBmcm9tIFwiLi4vcGVyc2lzdGVuY2UvQWRhcHRlclwiO1xuaW1wb3J0IHsgUGVyc2lzdGVuY2VLZXlzIH0gZnJvbSBcIi4uL3BlcnNpc3RlbmNlL2NvbnN0YW50c1wiO1xuaW1wb3J0IHsgTW9kZWwgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBSZXBvc2l0b3J5IH0gZnJvbSBcIi4vUmVwb3NpdG9yeVwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBHZW5lcmF0ZXMgYSB1bmlxdWUgaW5qZWN0YWJsZSBuYW1lIGZvciBhIHJlcG9zaXRvcnkuXG4gKiBAc3VtbWFyeSBDcmVhdGVzIGEgc3RhbmRhcmRpemVkIGluamVjdGFibGUgdG9rZW4gZm9yIHJlcG9zaXRvcmllcyB1c2luZyB0aGUgYWRhcHRlciBmbGF2b3VyIGFuZCBtb2RlbCB0YWJsZSBuYW1lLlxuICogVGhpcyBoZWxwcyB0aGUgREkgc3lzdGVtIHJlZ2lzdGVyIGFuZCByZXNvbHZlIHJlcG9zaXRvcnkgaW5zdGFuY2VzIGNvbnNpc3RlbnRseSBhY3Jvc3MgYWRhcHRlcnMuXG4gKiBAdGVtcGxhdGUgVCBUaGUgbW9kZWwgdHlwZSB0aGF0IGV4dGVuZHMgTW9kZWwuXG4gKiBAcGFyYW0ge0NvbnN0cnVjdG9yPFQ+IHwgVH0gbW9kZWwgVGhlIG1vZGVsIGNvbnN0cnVjdG9yIG9yIGluc3RhbmNlIGZyb20gd2hpY2ggdG8gZGVyaXZlIHRoZSB0YWJsZSBuYW1lLlxuICogQHBhcmFtIHtzdHJpbmd9IFtmbGF2b3VyXSBPcHRpb25hbCBhZGFwdGVyIGZsYXZvdXIvYWxpYXMuIElmIG9taXR0ZWQsIGl0IGlzIHJlYWQgZnJvbSBtb2RlbCBtZXRhZGF0YS5cbiAqIEByZXR1cm4ge3N0cmluZ30gQSBuYW1lc3BhY2VkIGluamVjdGFibGUgdG9rZW4gZm9yIHRoZSByZXBvc2l0b3J5IChlLmcuLCBcImRiOnJlcG86cmFtOnVzZXJzXCIpLlxuICogQHRocm93cyB7SW50ZXJuYWxFcnJvcn0gSWYgdGhlIGZsYXZvdXIgY2Fubm90IGJlIGRldGVybWluZWQgZnJvbSBhcmd1bWVudHMgb3IgbWV0YWRhdGEuXG4gKiBAZnVuY3Rpb24gZ2VuZXJhdGVJbmplY3RhYmxlTmFtZUZvclJlcG9zaXRvcnlcbiAqIEBtZXJtYWlkXG4gKiBzZXF1ZW5jZURpYWdyYW1cbiAqICAgcGFydGljaXBhbnQgQyBhcyBDYWxsZXJcbiAqICAgcGFydGljaXBhbnQgVSBhcyBnZW5lcmF0ZUluamVjdGFibGVOYW1lRm9yUmVwb3NpdG9yeVxuICogICBwYXJ0aWNpcGFudCBSIGFzIFJlZmxlY3QgTWV0YWRhdGFcbiAqICAgcGFydGljaXBhbnQgQSBhcyBBZGFwdGVyXG4gKiAgIHBhcnRpY2lwYW50IFMgYXMgU3RyaW5nIEZvcm1hdHRlclxuICogICBDLT4+VTogY2FsbChtb2RlbCwgZmxhdm91cj8pXG4gKiAgIGFsdCBmbGF2b3VyIHByb3ZpZGVkXG4gKiAgICAgVS0tPj5VOiB1c2UgcHJvdmlkZWQgZmxhdm91clxuICogICBlbHNlIGZsYXZvdXIgbm90IHByb3ZpZGVkXG4gKiAgICAgVS0+PkE6IEFkYXB0ZXIua2V5KEFEQVBURVIpXG4gKiAgICAgVS0+PlI6IGdldE1ldGFkYXRhKGtleSwgbW9kZWx8bW9kZWwuY3RvcilcbiAqICAgICBhbHQgbWV0YWRhdGEgcHJlc2VudFxuICogICAgICAgUi0tPj5VOiBmbGF2b3VyXG4gKiAgICAgZWxzZSBtaXNzaW5nXG4gKiAgICAgICBVLS0+PkM6IHRocm93IEludGVybmFsRXJyb3JcbiAqICAgICBlbmRcbiAqICAgZW5kXG4gKiAgIFUtPj5TOiBzZihJTkpFQ1RBQkxFLCBmbGF2b3VyLCBSZXBvc2l0b3J5LnRhYmxlKG1vZGVsKSlcbiAqICAgUy0tPj5DOiB0b2tlbiBzdHJpbmdcbiAqIEBtZW1iZXJPZiBtb2R1bGU6Y29yZVxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVJbmplY3RhYmxlTmFtZUZvclJlcG9zaXRvcnk8VCBleHRlbmRzIE1vZGVsPihcbiAgbW9kZWw6IENvbnN0cnVjdG9yPFQ+IHwgVCxcbiAgZmxhdm91cj86IHN0cmluZ1xuKTogc3RyaW5nIHtcbiAgaWYgKCFmbGF2b3VyKSB7XG4gICAgY29uc3Qga2V5ID0gQWRhcHRlci5rZXkoUGVyc2lzdGVuY2VLZXlzLkFEQVBURVIpO1xuICAgIGZsYXZvdXIgPSBSZWZsZWN0LmdldE1ldGFkYXRhKFxuICAgICAga2V5LFxuICAgICAgbW9kZWwgaW5zdGFuY2VvZiBNb2RlbCA/IG1vZGVsLmNvbnN0cnVjdG9yIDogbW9kZWxcbiAgICApO1xuICAgIGlmICghZmxhdm91cilcbiAgICAgIHRocm93IG5ldyBJbnRlcm5hbEVycm9yKFxuICAgICAgICBgQ291bGQgbm90IHJldHJpZXZlIGZsYXZvdXIgZnJvbSBtb2RlbCAke21vZGVsIGluc3RhbmNlb2YgTW9kZWwgPyBtb2RlbC5jb25zdHJ1Y3Rvci5uYW1lIDogbW9kZWwubmFtZX1gXG4gICAgICApO1xuICB9XG4gIHJldHVybiBzZihQZXJzaXN0ZW5jZUtleXMuSU5KRUNUQUJMRSwgZmxhdm91ciwgUmVwb3NpdG9yeS50YWJsZShtb2RlbCkpO1xufVxuIl19
@@ -1,4 +1,4 @@
1
- import { BaseError } from "@decaf-ts/db-decorators";
1
+ import { BadRequestError, InternalError } from "@decaf-ts/db-decorators";
2
2
  /**
3
3
  * @description Error thrown when a user is not authorized to perform an action
4
4
  * @summary This error is thrown when a user attempts to access a resource or perform an action without proper authentication
@@ -13,8 +13,8 @@ import { BaseError } from "@decaf-ts/db-decorators";
13
13
  * }
14
14
  * ```
15
15
  */
16
- export declare class AuthorizationError extends BaseError {
17
- constructor(msg: string | Error);
16
+ export declare class AuthorizationError extends BadRequestError {
17
+ constructor(msg: string | Error, name?: string, code?: number);
18
18
  }
19
19
  /**
20
20
  * @description Error thrown when a user is forbidden from accessing a resource
@@ -31,7 +31,7 @@ export declare class AuthorizationError extends BaseError {
31
31
  * }
32
32
  * ```
33
33
  */
34
- export declare class ForbiddenError extends BaseError {
34
+ export declare class ForbiddenError extends AuthorizationError {
35
35
  constructor(msg: string | Error);
36
36
  }
37
37
  /**
@@ -51,6 +51,6 @@ export declare class ForbiddenError extends BaseError {
51
51
  * }
52
52
  * ```
53
53
  */
54
- export declare class ConnectionError extends BaseError {
54
+ export declare class ConnectionError extends InternalError {
55
55
  constructor(msg: string | Error);
56
56
  }
@@ -1,4 +1,4 @@
1
- import { BaseError } from "@decaf-ts/db-decorators";
1
+ import { BadRequestError, InternalError } from "@decaf-ts/db-decorators";
2
2
  /**
3
3
  * @description Error thrown when a user is not authorized to perform an action
4
4
  * @summary This error is thrown when a user attempts to access a resource or perform an action without proper authentication
@@ -13,9 +13,9 @@ import { BaseError } from "@decaf-ts/db-decorators";
13
13
  * }
14
14
  * ```
15
15
  */
16
- export class AuthorizationError extends BaseError {
17
- constructor(msg) {
18
- super(AuthorizationError.name, msg, 401);
16
+ export class AuthorizationError extends BadRequestError {
17
+ constructor(msg, name = AuthorizationError.name, code = 401) {
18
+ super(msg, name, code);
19
19
  }
20
20
  }
21
21
  /**
@@ -33,9 +33,9 @@ export class AuthorizationError extends BaseError {
33
33
  * }
34
34
  * ```
35
35
  */
36
- export class ForbiddenError extends BaseError {
36
+ export class ForbiddenError extends AuthorizationError {
37
37
  constructor(msg) {
38
- super(ForbiddenError.name, msg, 403);
38
+ super(msg, ForbiddenError.name, 403);
39
39
  }
40
40
  }
41
41
  /**
@@ -55,9 +55,9 @@ export class ForbiddenError extends BaseError {
55
55
  * }
56
56
  * ```
57
57
  */
58
- export class ConnectionError extends BaseError {
58
+ export class ConnectionError extends InternalError {
59
59
  constructor(msg) {
60
- super(ConnectionError.name, msg, 503);
60
+ super(msg, ConnectionError.name, 503);
61
61
  }
62
62
  }
63
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFcEQ7Ozs7Ozs7Ozs7Ozs7R0FhRztBQUNILE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxTQUFTO0lBQy9DLFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLGtCQUFrQixDQUFDLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDM0MsQ0FBQztDQUNGO0FBRUQ7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFDSCxNQUFNLE9BQU8sY0FBZSxTQUFRLFNBQVM7SUFDM0MsWUFBWSxHQUFtQjtRQUM3QixLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDdkMsQ0FBQztDQUNGO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7R0FnQkc7QUFDSCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxTQUFTO0lBQzVDLFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VFcnJvciB9IGZyb20gXCJAZGVjYWYtdHMvZGItZGVjb3JhdG9yc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBFcnJvciB0aHJvd24gd2hlbiBhIHVzZXIgaXMgbm90IGF1dGhvcml6ZWQgdG8gcGVyZm9ybSBhbiBhY3Rpb25cbiAqIEBzdW1tYXJ5IFRoaXMgZXJyb3IgaXMgdGhyb3duIHdoZW4gYSB1c2VyIGF0dGVtcHRzIHRvIGFjY2VzcyBhIHJlc291cmNlIG9yIHBlcmZvcm0gYW4gYWN0aW9uIHdpdGhvdXQgcHJvcGVyIGF1dGhlbnRpY2F0aW9uXG4gKiBAcGFyYW0ge3N0cmluZ3xFcnJvcn0gbXNnIC0gVGhlIGVycm9yIG1lc3NhZ2Ugb3IgRXJyb3Igb2JqZWN0XG4gKiBAY2xhc3MgQXV0aG9yaXphdGlvbkVycm9yXG4gKiBAY2F0ZWdvcnkgRXJyb3JzXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogLy8gRXhhbXBsZSBvZiB0aHJvd2luZyBhbiBBdXRob3JpemF0aW9uRXJyb3JcbiAqIGlmICghdXNlci5pc0F1dGhlbnRpY2F0ZWQoKSkge1xuICogICB0aHJvdyBuZXcgQXV0aG9yaXphdGlvbkVycm9yKCdVc2VyIG5vdCBhdXRoZW50aWNhdGVkJyk7XG4gKiB9XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGNsYXNzIEF1dGhvcml6YXRpb25FcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihBdXRob3JpemF0aW9uRXJyb3IubmFtZSwgbXNnLCA0MDEpO1xuICB9XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEVycm9yIHRocm93biB3aGVuIGEgdXNlciBpcyBmb3JiaWRkZW4gZnJvbSBhY2Nlc3NpbmcgYSByZXNvdXJjZVxuICogQHN1bW1hcnkgVGhpcyBlcnJvciBpcyB0aHJvd24gd2hlbiBhbiBhdXRoZW50aWNhdGVkIHVzZXIgYXR0ZW1wdHMgdG8gYWNjZXNzIGEgcmVzb3VyY2Ugb3IgcGVyZm9ybSBhbiBhY3Rpb24gdGhleSBkb24ndCBoYXZlIHBlcm1pc3Npb24gZm9yXG4gKiBAcGFyYW0ge3N0cmluZ3xFcnJvcn0gbXNnIC0gVGhlIGVycm9yIG1lc3NhZ2Ugb3IgRXJyb3Igb2JqZWN0XG4gKiBAcmV0dXJuIHt2b2lkfVxuICogQGNsYXNzIEZvcmJpZGRlbkVycm9yXG4gKiBAY2F0ZWdvcnkgRXJyb3JzXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogLy8gRXhhbXBsZSBvZiB0aHJvd2luZyBhIEZvcmJpZGRlbkVycm9yXG4gKiBpZiAoIXVzZXIuaGFzUGVybWlzc2lvbignYWRtaW4nKSkge1xuICogICB0aHJvdyBuZXcgRm9yYmlkZGVuRXJyb3IoJ1VzZXIgZG9lcyBub3QgaGF2ZSBhZG1pbiBwZXJtaXNzaW9ucycpO1xuICogfVxuICogYGBgXG4gKi9cbmV4cG9ydCBjbGFzcyBGb3JiaWRkZW5FcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihGb3JiaWRkZW5FcnJvci5uYW1lLCBtc2csIDQwMyk7XG4gIH1cbn1cblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRXJyb3IgdGhyb3duIHdoZW4gYSBjb25uZWN0aW9uIHRvIGEgc2VydmljZSBmYWlsc1xuICogQHN1bW1hcnkgVGhpcyBlcnJvciBpcyB0aHJvd24gd2hlbiB0aGUgYXBwbGljYXRpb24gZmFpbHMgdG8gZXN0YWJsaXNoIGEgY29ubmVjdGlvbiB0byBhIHJlcXVpcmVkIHNlcnZpY2Ugb3IgcmVzb3VyY2VcbiAqIEBwYXJhbSB7c3RyaW5nfEVycm9yfSBtc2cgLSBUaGUgZXJyb3IgbWVzc2FnZSBvciBFcnJvciBvYmplY3RcbiAqIEByZXR1cm4ge3ZvaWR9XG4gKiBAY2xhc3MgQ29ubmVjdGlvbkVycm9yXG4gKiBAY2F0ZWdvcnkgRXJyb3JzXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogLy8gRXhhbXBsZSBvZiB0aHJvd2luZyBhIENvbm5lY3Rpb25FcnJvclxuICogdHJ5IHtcbiAqICAgYXdhaXQgZGF0YWJhc2UuY29ubmVjdCgpO1xuICogfSBjYXRjaCAoZXJyb3IpIHtcbiAqICAgdGhyb3cgbmV3IENvbm5lY3Rpb25FcnJvcignRmFpbGVkIHRvIGNvbm5lY3QgdG8gZGF0YWJhc2UnKTtcbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgQ29ubmVjdGlvbkVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcbiAgY29uc3RydWN0b3IobXNnOiBzdHJpbmcgfCBFcnJvcikge1xuICAgIHN1cGVyKENvbm5lY3Rpb25FcnJvci5uYW1lLCBtc2csIDUwMyk7XG4gIH1cbn1cbiJdfQ==
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRXpFOzs7Ozs7Ozs7Ozs7O0dBYUc7QUFDSCxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsZUFBZTtJQUNyRCxZQUFZLEdBQW1CLEVBQUUsSUFBSSxHQUFHLGtCQUFrQixDQUFDLElBQUksRUFBRSxJQUFJLEdBQUcsR0FBRztRQUN6RSxLQUFLLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztJQUN6QixDQUFDO0NBQ0Y7QUFFRDs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUNILE1BQU0sT0FBTyxjQUFlLFNBQVEsa0JBQWtCO0lBQ3BELFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLEdBQUcsRUFBRSxjQUFjLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7Q0FDRjtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0gsTUFBTSxPQUFPLGVBQWdCLFNBQVEsYUFBYTtJQUNoRCxZQUFZLEdBQW1CO1FBQzdCLEtBQUssQ0FBQyxHQUFHLEVBQUUsZUFBZSxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN4QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYWRSZXF1ZXN0RXJyb3IsIEludGVybmFsRXJyb3IgfSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnNcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRXJyb3IgdGhyb3duIHdoZW4gYSB1c2VyIGlzIG5vdCBhdXRob3JpemVkIHRvIHBlcmZvcm0gYW4gYWN0aW9uXG4gKiBAc3VtbWFyeSBUaGlzIGVycm9yIGlzIHRocm93biB3aGVuIGEgdXNlciBhdHRlbXB0cyB0byBhY2Nlc3MgYSByZXNvdXJjZSBvciBwZXJmb3JtIGFuIGFjdGlvbiB3aXRob3V0IHByb3BlciBhdXRoZW50aWNhdGlvblxuICogQHBhcmFtIHtzdHJpbmd8RXJyb3J9IG1zZyAtIFRoZSBlcnJvciBtZXNzYWdlIG9yIEVycm9yIG9iamVjdFxuICogQGNsYXNzIEF1dGhvcml6YXRpb25FcnJvclxuICogQGNhdGVnb3J5IEVycm9yc1xuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIC8vIEV4YW1wbGUgb2YgdGhyb3dpbmcgYW4gQXV0aG9yaXphdGlvbkVycm9yXG4gKiBpZiAoIXVzZXIuaXNBdXRoZW50aWNhdGVkKCkpIHtcbiAqICAgdGhyb3cgbmV3IEF1dGhvcml6YXRpb25FcnJvcignVXNlciBub3QgYXV0aGVudGljYXRlZCcpO1xuICogfVxuICogYGBgXG4gKi9cbmV4cG9ydCBjbGFzcyBBdXRob3JpemF0aW9uRXJyb3IgZXh0ZW5kcyBCYWRSZXF1ZXN0RXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihtc2c6IHN0cmluZyB8IEVycm9yLCBuYW1lID0gQXV0aG9yaXphdGlvbkVycm9yLm5hbWUsIGNvZGUgPSA0MDEpIHtcbiAgICBzdXBlcihtc2csIG5hbWUsIGNvZGUpO1xuICB9XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEVycm9yIHRocm93biB3aGVuIGEgdXNlciBpcyBmb3JiaWRkZW4gZnJvbSBhY2Nlc3NpbmcgYSByZXNvdXJjZVxuICogQHN1bW1hcnkgVGhpcyBlcnJvciBpcyB0aHJvd24gd2hlbiBhbiBhdXRoZW50aWNhdGVkIHVzZXIgYXR0ZW1wdHMgdG8gYWNjZXNzIGEgcmVzb3VyY2Ugb3IgcGVyZm9ybSBhbiBhY3Rpb24gdGhleSBkb24ndCBoYXZlIHBlcm1pc3Npb24gZm9yXG4gKiBAcGFyYW0ge3N0cmluZ3xFcnJvcn0gbXNnIC0gVGhlIGVycm9yIG1lc3NhZ2Ugb3IgRXJyb3Igb2JqZWN0XG4gKiBAcmV0dXJuIHt2b2lkfVxuICogQGNsYXNzIEZvcmJpZGRlbkVycm9yXG4gKiBAY2F0ZWdvcnkgRXJyb3JzXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogLy8gRXhhbXBsZSBvZiB0aHJvd2luZyBhIEZvcmJpZGRlbkVycm9yXG4gKiBpZiAoIXVzZXIuaGFzUGVybWlzc2lvbignYWRtaW4nKSkge1xuICogICB0aHJvdyBuZXcgRm9yYmlkZGVuRXJyb3IoJ1VzZXIgZG9lcyBub3QgaGF2ZSBhZG1pbiBwZXJtaXNzaW9ucycpO1xuICogfVxuICogYGBgXG4gKi9cbmV4cG9ydCBjbGFzcyBGb3JiaWRkZW5FcnJvciBleHRlbmRzIEF1dGhvcml6YXRpb25FcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihtc2csIEZvcmJpZGRlbkVycm9yLm5hbWUsIDQwMyk7XG4gIH1cbn1cblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRXJyb3IgdGhyb3duIHdoZW4gYSBjb25uZWN0aW9uIHRvIGEgc2VydmljZSBmYWlsc1xuICogQHN1bW1hcnkgVGhpcyBlcnJvciBpcyB0aHJvd24gd2hlbiB0aGUgYXBwbGljYXRpb24gZmFpbHMgdG8gZXN0YWJsaXNoIGEgY29ubmVjdGlvbiB0byBhIHJlcXVpcmVkIHNlcnZpY2Ugb3IgcmVzb3VyY2VcbiAqIEBwYXJhbSB7c3RyaW5nfEVycm9yfSBtc2cgLSBUaGUgZXJyb3IgbWVzc2FnZSBvciBFcnJvciBvYmplY3RcbiAqIEByZXR1cm4ge3ZvaWR9XG4gKiBAY2xhc3MgQ29ubmVjdGlvbkVycm9yXG4gKiBAY2F0ZWdvcnkgRXJyb3JzXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogLy8gRXhhbXBsZSBvZiB0aHJvd2luZyBhIENvbm5lY3Rpb25FcnJvclxuICogdHJ5IHtcbiAqICAgYXdhaXQgZGF0YWJhc2UuY29ubmVjdCgpO1xuICogfSBjYXRjaCAoZXJyb3IpIHtcbiAqICAgdGhyb3cgbmV3IENvbm5lY3Rpb25FcnJvcignRmFpbGVkIHRvIGNvbm5lY3QgdG8gZGF0YWJhc2UnKTtcbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgQ29ubmVjdGlvbkVycm9yIGV4dGVuZHMgSW50ZXJuYWxFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihtc2csIENvbm5lY3Rpb25FcnJvci5uYW1lLCA1MDMpO1xuICB9XG59XG4iXX0=
@@ -109,4 +109,4 @@ function pk(opts = SequenceOptions_1.DefaultSequenceOptions) {
109
109
  })
110
110
  .apply();
111
111
  }
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/identity/decorators.ts"],"names":[],"mappings":";;AA8DA,gCA0CC;AAsBD,gBAgCC;AA9JD,yEAMwC;AACxC,yEAGuC;AACvC,2DAMiC;AACjC,+DAA4D;AAC5D,0DAA4C;AAC5C,uCAA+C;AAG/C,0DAA+C;AAC/C,qDAA6C;AAE7C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACI,KAAK,UAAU,UAAU,CAQ9B,OAAmB,EACnB,IAAO,EACP,GAAY,EACZ,KAAQ;IAER,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;QAChD,OAAO;IACT,CAAC;IAED,MAAM,kBAAkB,GAAG,UACzB,MAAS,EACT,WAAmB,EACnB,KAA+B;QAE/B,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE;YACzC,UAAU,EAAE,IAAI;YAChB,QAAQ,EAAE,KAAK;YACf,YAAY,EAAE,IAAI;YAClB,KAAK,EAAE,KAAK;SACb,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,IAAI,CAAC,IAAI,CAAC,IAAI;QAAE,IAAI,CAAC,IAAI,GAAG,IAAA,4BAAoB,EAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAC9D,IAAI,QAAkB,CAAC;IACvB,IAAI,CAAC;QACH,QAAQ,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,MAAM,IAAI,6BAAa,CACrB,kCAAkC,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE,CACpD,CAAC;IACJ,CAAC;IAED,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;IACnC,kBAAkB,CAAC,KAAK,EAAE,GAAa,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,SAAgB,EAAE,CAChB,OAGI,wCAAsB;IAE1B,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,wCAAsB,EAAE,IAAI,EAAE;QACrD,SAAS,EACP,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,CAAC,SAAS,KAAK,WAAW;YAChD,CAAC,CAAC,IAAI;YACN,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,wCAAsB,CAAC,SAAS;KACzD,CAAoB,CAAC;IAEtB,MAAM,GAAG,GAAG,uBAAU,CAAC,GAAG,CAAC,sBAAM,CAAC,EAAE,CAAC,CAAC;IACtC,SAAS,KAAK,CAAC,OAAwB;QACrC,OAAO,SAAS,KAAK,CAAC,GAAQ,EAAE,IAAS;YACvC,OAAO,IAAA,kBAAK,EACV,IAAA,kBAAK,EAAC,CAAC,2BAAc,CAAC,GAAG,EAAE,2BAAc,CAAC,GAAG,CAAC,CAAC,EAC/C,IAAA,+BAAQ,GAAE,EACV,IAAA,wBAAQ,GAAE,EACV,IAAA,mCAAY,EAAC,GAAG,EAAE,OAAO,CAAC,EAC1B,IAAA,wBAAQ,EAAC,UAAU,EAAE,OAAO,CAAC,EAC7B,IAAA,mCAAY,EAAC,sBAAM,CAAC,EAAE,EAAE,IAAI,CAAC,CAC9B,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QACf,CAAC,CAAC;IACJ,CAAC;IACD,OAAO,iCAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CAAC;QACN,SAAS,EAAE,KAAK;QAChB,IAAI,EAAE,CAAC,IAAI,CAAC;KACb,CAAC;SACD,KAAK,EAAE,CAAC;AACb,CAAC","sourcesContent":["import {\n  Decoration,\n  Model,\n  prop,\n  propMetadata,\n  required,\n} from \"@decaf-ts/decorator-validation\";\nimport {\n  DefaultSequenceOptions,\n  SequenceOptions,\n} from \"../interfaces/SequenceOptions\";\nimport {\n  DBKeys,\n  InternalError,\n  onCreate,\n  readonly,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport { Repo, Repository } from \"../repository/Repository\";\nimport { index } from \"../model/decorators\";\nimport { sequenceNameForModel } from \"./utils\";\nimport { Sequence } from \"../persistence/Sequence\";\nimport { Context } from \"@decaf-ts/db-decorators\";\nimport { OrderDirection } from \"../repository\";\nimport { apply } from \"@decaf-ts/reflection\";\n\n/**\n * @description Callback function for primary key creation\n * @summary Handles the creation of primary key values for models using sequences\n * @template M - Type that extends Model\n * @template R - Type that extends Repo<M, F, C>\n * @template V - Type that extends SequenceOptions\n * @template F - Type that extends RepositoryFlags\n * @template C - Type that extends Context<F>\n * @param {Context<F>} context - The execution context\n * @param {V} data - The sequence options\n * @param key - The property key to set as primary key\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the primary key is set\n * @function pkOnCreate\n * @category Property Decorators\n * @mermaid\n * sequenceDiagram\n *   participant Model\n *   participant pkOnCreate\n *   participant Adapter\n *   participant Sequence\n *\n *   Model->>pkOnCreate: Call with model instance\n *   Note over pkOnCreate: Check if key already exists\n *   alt Key exists or no type specified\n *     pkOnCreate-->>Model: Return early\n *   else Key needs to be created\n *     pkOnCreate->>pkOnCreate: Generate sequence name if not provided\n *     pkOnCreate->>Adapter: Request Sequence(data)\n *     Adapter->>Sequence: Create sequence\n *     Sequence-->>pkOnCreate: Return sequence\n *     pkOnCreate->>Sequence: Call next()\n *     Sequence-->>pkOnCreate: Return next value\n *     pkOnCreate->>Model: Set primary key value\n *   end\n */\nexport async function pkOnCreate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends SequenceOptions,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  this: R,\n  context: Context<F>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  if (!data.type || !data.generated || model[key]) {\n    return;\n  }\n\n  const setPrimaryKeyValue = function <M extends Model>(\n    target: M,\n    propertyKey: string,\n    value: string | number | bigint\n  ) {\n    Object.defineProperty(target, propertyKey, {\n      enumerable: true,\n      writable: false,\n      configurable: true,\n      value: value,\n    });\n  };\n\n  if (!data.name) data.name = sequenceNameForModel(model, \"pk\");\n  let sequence: Sequence;\n  try {\n    sequence = await this.adapter.Sequence(data);\n  } catch (e: any) {\n    throw new InternalError(\n      `Failed to instantiate Sequence ${data.name}: ${e}`\n    );\n  }\n\n  const next = await sequence.next();\n  setPrimaryKeyValue(model, key as string, next);\n}\n\n/**\n * @description Primary Key Decorator\n * @summary Marks a property as the model's primary key with automatic sequence generation\n * This decorator combines multiple behaviors: it marks the property as unique, required,\n * and ensures the index is created properly according to the provided sequence options.\n * @param {Omit<SequenceOptions, \"cycle\" | \"startWith\" | \"incrementBy\">} opts - Options for the sequence generation\n * @return {PropertyDecorator} A property decorator that can be applied to model properties\n * @function pk\n * @category Property Decorators\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @pk()\n *   id!: string;\n *\n *   @required()\n *   username!: string;\n * }\n * ```\n */\nexport function pk(\n  opts: Omit<\n    SequenceOptions,\n    \"cycle\" | \"startWith\" | \"incrementBy\"\n  > = DefaultSequenceOptions\n) {\n  opts = Object.assign({}, DefaultSequenceOptions, opts, {\n    generated:\n      opts.type && typeof opts.generated === \"undefined\"\n        ? true\n        : opts.generated || DefaultSequenceOptions.generated,\n  }) as SequenceOptions;\n\n  const key = Repository.key(DBKeys.ID);\n  function pkDec(options: SequenceOptions) {\n    return function pkDec(obj: any, attr: any) {\n      return apply(\n        index([OrderDirection.ASC, OrderDirection.DSC]),\n        required(),\n        readonly(),\n        propMetadata(key, options),\n        onCreate(pkOnCreate, options),\n        propMetadata(DBKeys.ID, attr)\n      )(obj, attr);\n    };\n  }\n  return Decoration.for(key)\n    .define({\n      decorator: pkDec,\n      args: [opts],\n    })\n    .apply();\n}\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/identity/decorators.ts"],"names":[],"mappings":";;AA6DA,gCA0CC;AAsBD,gBAgCC;AA7JD,yEAKwC;AACxC,yEAGuC;AACvC,2DAMiC;AACjC,+DAA4D;AAC5D,0DAA4C;AAC5C,uCAA+C;AAG/C,0DAA+C;AAC/C,qDAA6C;AAE7C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACI,KAAK,UAAU,UAAU,CAQ9B,OAAmB,EACnB,IAAO,EACP,GAAY,EACZ,KAAQ;IAER,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;QAChD,OAAO;IACT,CAAC;IAED,MAAM,kBAAkB,GAAG,UACzB,MAAS,EACT,WAAmB,EACnB,KAA+B;QAE/B,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE;YACzC,UAAU,EAAE,IAAI;YAChB,QAAQ,EAAE,KAAK;YACf,YAAY,EAAE,IAAI;YAClB,KAAK,EAAE,KAAK;SACb,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,IAAI,CAAC,IAAI,CAAC,IAAI;QAAE,IAAI,CAAC,IAAI,GAAG,IAAA,4BAAoB,EAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAC9D,IAAI,QAAkB,CAAC;IACvB,IAAI,CAAC;QACH,QAAQ,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,MAAM,IAAI,6BAAa,CACrB,kCAAkC,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE,CACpD,CAAC;IACJ,CAAC;IAED,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;IACnC,kBAAkB,CAAC,KAAK,EAAE,GAAa,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,SAAgB,EAAE,CAChB,OAGI,wCAAsB;IAE1B,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,wCAAsB,EAAE,IAAI,EAAE;QACrD,SAAS,EACP,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,CAAC,SAAS,KAAK,WAAW;YAChD,CAAC,CAAC,IAAI;YACN,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,wCAAsB,CAAC,SAAS;KACzD,CAAoB,CAAC;IAEtB,MAAM,GAAG,GAAG,uBAAU,CAAC,GAAG,CAAC,sBAAM,CAAC,EAAE,CAAC,CAAC;IACtC,SAAS,KAAK,CAAC,OAAwB;QACrC,OAAO,SAAS,KAAK,CAAC,GAAQ,EAAE,IAAS;YACvC,OAAO,IAAA,kBAAK,EACV,IAAA,kBAAK,EAAC,CAAC,2BAAc,CAAC,GAAG,EAAE,2BAAc,CAAC,GAAG,CAAC,CAAC,EAC/C,IAAA,+BAAQ,GAAE,EACV,IAAA,wBAAQ,GAAE,EACV,IAAA,mCAAY,EAAC,GAAG,EAAE,OAAO,CAAC,EAC1B,IAAA,wBAAQ,EAAC,UAAU,EAAE,OAAO,CAAC,EAC7B,IAAA,mCAAY,EAAC,sBAAM,CAAC,EAAE,EAAE,IAAI,CAAC,CAC9B,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QACf,CAAC,CAAC;IACJ,CAAC;IACD,OAAO,iCAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CAAC;QACN,SAAS,EAAE,KAAK;QAChB,IAAI,EAAE,CAAC,IAAI,CAAC;KACb,CAAC;SACD,KAAK,EAAE,CAAC;AACb,CAAC","sourcesContent":["import {\n  Decoration,\n  Model,\n  propMetadata,\n  required,\n} from \"@decaf-ts/decorator-validation\";\nimport {\n  DefaultSequenceOptions,\n  SequenceOptions,\n} from \"../interfaces/SequenceOptions\";\nimport {\n  DBKeys,\n  InternalError,\n  onCreate,\n  readonly,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport { Repo, Repository } from \"../repository/Repository\";\nimport { index } from \"../model/decorators\";\nimport { sequenceNameForModel } from \"./utils\";\nimport { Sequence } from \"../persistence/Sequence\";\nimport { Context } from \"@decaf-ts/db-decorators\";\nimport { OrderDirection } from \"../repository\";\nimport { apply } from \"@decaf-ts/reflection\";\n\n/**\n * @description Callback function for primary key creation\n * @summary Handles the creation of primary key values for models using sequences\n * @template M - Type that extends Model\n * @template R - Type that extends Repo<M, F, C>\n * @template V - Type that extends SequenceOptions\n * @template F - Type that extends RepositoryFlags\n * @template C - Type that extends Context<F>\n * @param {Context<F>} context - The execution context\n * @param {V} data - The sequence options\n * @param key - The property key to set as primary key\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the primary key is set\n * @function pkOnCreate\n * @category Property Decorators\n * @mermaid\n * sequenceDiagram\n *   participant Model\n *   participant pkOnCreate\n *   participant Adapter\n *   participant Sequence\n *\n *   Model->>pkOnCreate: Call with model instance\n *   Note over pkOnCreate: Check if key already exists\n *   alt Key exists or no type specified\n *     pkOnCreate-->>Model: Return early\n *   else Key needs to be created\n *     pkOnCreate->>pkOnCreate: Generate sequence name if not provided\n *     pkOnCreate->>Adapter: Request Sequence(data)\n *     Adapter->>Sequence: Create sequence\n *     Sequence-->>pkOnCreate: Return sequence\n *     pkOnCreate->>Sequence: Call next()\n *     Sequence-->>pkOnCreate: Return next value\n *     pkOnCreate->>Model: Set primary key value\n *   end\n */\nexport async function pkOnCreate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends SequenceOptions,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  this: R,\n  context: Context<F>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  if (!data.type || !data.generated || model[key]) {\n    return;\n  }\n\n  const setPrimaryKeyValue = function <M extends Model>(\n    target: M,\n    propertyKey: string,\n    value: string | number | bigint\n  ) {\n    Object.defineProperty(target, propertyKey, {\n      enumerable: true,\n      writable: false,\n      configurable: true,\n      value: value,\n    });\n  };\n\n  if (!data.name) data.name = sequenceNameForModel(model, \"pk\");\n  let sequence: Sequence;\n  try {\n    sequence = await this.adapter.Sequence(data);\n  } catch (e: any) {\n    throw new InternalError(\n      `Failed to instantiate Sequence ${data.name}: ${e}`\n    );\n  }\n\n  const next = await sequence.next();\n  setPrimaryKeyValue(model, key as string, next);\n}\n\n/**\n * @description Primary Key Decorator\n * @summary Marks a property as the model's primary key with automatic sequence generation\n * This decorator combines multiple behaviors: it marks the property as unique, required,\n * and ensures the index is created properly according to the provided sequence options.\n * @param {Omit<SequenceOptions, \"cycle\" | \"startWith\" | \"incrementBy\">} opts - Options for the sequence generation\n * @return {PropertyDecorator} A property decorator that can be applied to model properties\n * @function pk\n * @category Property Decorators\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @pk()\n *   id!: string;\n *\n *   @required()\n *   username!: string;\n * }\n * ```\n */\nexport function pk(\n  opts: Omit<\n    SequenceOptions,\n    \"cycle\" | \"startWith\" | \"incrementBy\"\n  > = DefaultSequenceOptions\n) {\n  opts = Object.assign({}, DefaultSequenceOptions, opts, {\n    generated:\n      opts.type && typeof opts.generated === \"undefined\"\n        ? true\n        : opts.generated || DefaultSequenceOptions.generated,\n  }) as SequenceOptions;\n\n  const key = Repository.key(DBKeys.ID);\n  function pkDec(options: SequenceOptions) {\n    return function pkDec(obj: any, attr: any) {\n      return apply(\n        index([OrderDirection.ASC, OrderDirection.DSC]),\n        required(),\n        readonly(),\n        propMetadata(key, options),\n        onCreate(pkOnCreate, options),\n        propMetadata(DBKeys.ID, attr)\n      )(obj, attr);\n    };\n  }\n  return Decoration.for(key)\n    .define({\n      decorator: pkDec,\n      args: [opts],\n    })\n    .apply();\n}\n"]}
package/lib/index.cjs CHANGED
@@ -40,5 +40,5 @@ __exportStar(require("./persistence/index.cjs"), exports);
40
40
  * @const VERSION
41
41
  * @memberOf module:core
42
42
  */
43
- exports.VERSION = "0.5.20";
43
+ exports.VERSION = "0.5.22";
44
44
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFSCx1REFBbUQ7QUFDbkQsMkVBQThEO0FBRTlELGtGQUFrRjtBQUNsRixtQ0FBVyxDQUFDLFdBQVcsQ0FBQyxJQUFJLGdDQUFtQixFQUFFLENBQUMsQ0FBQztBQUVuRCx1REFBMkI7QUFDM0IseURBQTZCO0FBQzdCLG9EQUF3QjtBQUN4QixvREFBd0I7QUFDeEIseURBQTZCO0FBQzdCLG9EQUF3QjtBQUN4Qix5QkFBeUI7QUFDekIsMERBQThCO0FBRTlCOzs7OztHQUtHO0FBQ1UsUUFBQSxPQUFPLEdBQUcsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbW9kdWxlIGNvcmVcbiAqIEBkZXNjcmlwdGlvbiBDb3JlIG1vZHVsZSBmb3IgdGhlIERlY2FmIFR5cGVTY3JpcHQgZnJhbWV3b3JrXG4gKiBAc3VtbWFyeSBUaGlzIG1vZHVsZSBwcm92aWRlcyB0aGUgZm91bmRhdGlvbmFsIGNvbXBvbmVudHMgb2YgdGhlIERlY2FmIGZyYW1ld29yaywgaW5jbHVkaW5nIGlkZW50aXR5IG1hbmFnZW1lbnQsIFxuICogbW9kZWwgZGVmaW5pdGlvbnMsIHJlcG9zaXRvcnkgcGF0dGVybnMsIHBlcnNpc3RlbmNlIGxheWVyLCBxdWVyeSBidWlsZGluZywgYW5kIHV0aWxpdHkgZnVuY3Rpb25zLlxuICogSXQgZXhwb3J0cyBmdW5jdGlvbmFsaXR5IGZyb20gdmFyaW91cyBzdWJtb2R1bGVzIGFuZCBzZXRzIHVwIHRoZSBpbmplY3RhYmxlIHJlZ2lzdHJ5IGZvciByZXBvc2l0b3J5IGRlY29yYXRvcnMuXG4gKi9cblxuaW1wb3J0IHsgSW5qZWN0YWJsZXNSZWdpc3RyeSB9IGZyb20gXCIuL3JlcG9zaXRvcnlcIjtcbmltcG9ydCB7IEluamVjdGFibGVzIH0gZnJvbSBcIkBkZWNhZi10cy9pbmplY3RhYmxlLWRlY29yYXRvcnNcIjtcblxuLy8gb3ZlcnJpZGVzIHRoZSBwcmV2aW91cyBJbmplY3RhYmxlcyByZWdpc3RyeSB0byBlbmFibGUgdGhlIEByZXBvc2l0b3J5IGRlY29yYXRvclxuSW5qZWN0YWJsZXMuc2V0UmVnaXN0cnkobmV3IEluamVjdGFibGVzUmVnaXN0cnkoKSk7XG5cbmV4cG9ydCAqIGZyb20gXCIuL2lkZW50aXR5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9pbnRlcmZhY2VzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vcXVlcnlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3JlcG9zaXRvcnlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWxzXCI7XG4vL2xlZnQgdG8gbGFzdCBvbiBwdXJwb3NlXG5leHBvcnQgKiBmcm9tIFwiLi9wZXJzaXN0ZW5jZVwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBTdG9yZXMgdGhlIGN1cnJlbnQgcGFja2FnZSB2ZXJzaW9uXG4gKiBAc3VtbWFyeSBBIGNvbnN0YW50IHJlcHJlc2VudGluZyB0aGUgdmVyc2lvbiBvZiB0aGUgY29yZSBwYWNrYWdlXG4gKiBAY29uc3QgVkVSU0lPTlxuICogQG1lbWJlck9mIG1vZHVsZTpjb3JlXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gXCIjI1ZFUlNJT04jI1wiO1xuIl19