@decaf-ts/db-decorators 0.6.1 → 0.6.3

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 (141) hide show
  1. package/LICENSE.md +21 -157
  2. package/README.md +571 -10
  3. package/dist/db-decorators.cjs +1599 -426
  4. package/dist/db-decorators.esm.cjs +1597 -428
  5. package/lib/esm/identity/decorators.d.ts +7 -0
  6. package/lib/esm/identity/decorators.js +11 -4
  7. package/lib/esm/identity/index.js +3 -3
  8. package/lib/esm/identity/utils.d.ts +36 -23
  9. package/lib/esm/identity/utils.js +38 -25
  10. package/lib/esm/index.d.ts +12 -27
  11. package/lib/esm/index.js +13 -28
  12. package/lib/esm/interfaces/BulkCrudOperator.d.ts +39 -0
  13. package/lib/esm/interfaces/BulkCrudOperator.js +1 -1
  14. package/lib/esm/interfaces/Contextual.d.ts +17 -0
  15. package/lib/esm/interfaces/Contextual.js +1 -1
  16. package/lib/esm/interfaces/CrudOperator.d.ts +26 -23
  17. package/lib/esm/interfaces/CrudOperator.js +1 -1
  18. package/lib/esm/interfaces/IRepository.d.ts +10 -2
  19. package/lib/esm/interfaces/IRepository.js +1 -1
  20. package/lib/esm/interfaces/index.js +5 -5
  21. package/lib/esm/model/constants.d.ts +11 -13
  22. package/lib/esm/model/constants.js +12 -14
  23. package/lib/esm/model/decorators.d.ts +112 -23
  24. package/lib/esm/model/decorators.js +119 -29
  25. package/lib/esm/model/index.d.ts +1 -0
  26. package/lib/esm/model/index.js +7 -6
  27. package/lib/esm/model/model.d.ts +2 -141
  28. package/lib/esm/model/model.js +2 -13
  29. package/lib/esm/model/overrides.d.ts +1 -0
  30. package/lib/esm/model/overrides.js +34 -0
  31. package/lib/esm/model/utils.d.ts +39 -0
  32. package/lib/esm/model/utils.js +42 -3
  33. package/lib/esm/model/validation.d.ts +51 -8
  34. package/lib/esm/model/validation.js +246 -107
  35. package/lib/esm/operations/Operations.d.ts +65 -3
  36. package/lib/esm/operations/Operations.js +68 -6
  37. package/lib/esm/operations/OperationsRegistry.d.ts +44 -16
  38. package/lib/esm/operations/OperationsRegistry.js +46 -18
  39. package/lib/esm/operations/constants.d.ts +27 -8
  40. package/lib/esm/operations/constants.js +16 -9
  41. package/lib/esm/operations/decorators.d.ts +140 -134
  42. package/lib/esm/operations/decorators.js +152 -137
  43. package/lib/esm/operations/index.js +6 -6
  44. package/lib/esm/operations/types.d.ts +10 -0
  45. package/lib/esm/operations/types.js +1 -1
  46. package/lib/esm/repository/BaseRepository.d.ts +322 -0
  47. package/lib/esm/repository/BaseRepository.js +297 -7
  48. package/lib/esm/repository/Context.d.ts +153 -2
  49. package/lib/esm/repository/Context.js +154 -6
  50. package/lib/esm/repository/Repository.d.ts +89 -0
  51. package/lib/esm/repository/Repository.js +102 -15
  52. package/lib/esm/repository/constants.d.ts +7 -0
  53. package/lib/esm/repository/constants.js +8 -1
  54. package/lib/esm/repository/errors.d.ts +61 -34
  55. package/lib/esm/repository/errors.js +62 -35
  56. package/lib/esm/repository/index.js +9 -9
  57. package/lib/esm/repository/types.d.ts +25 -0
  58. package/lib/esm/repository/types.js +1 -1
  59. package/lib/esm/repository/utils.d.ts +11 -0
  60. package/lib/esm/repository/utils.js +4 -4
  61. package/lib/esm/repository/wrappers.d.ts +2 -2
  62. package/lib/esm/repository/wrappers.js +5 -5
  63. package/lib/esm/validation/constants.d.ts +20 -5
  64. package/lib/esm/validation/constants.js +22 -7
  65. package/lib/esm/validation/decorators.d.ts +101 -19
  66. package/lib/esm/validation/decorators.js +109 -27
  67. package/lib/esm/validation/index.js +5 -5
  68. package/lib/esm/validation/validation.js +10 -2
  69. package/lib/esm/validation/validators/ReadOnlyValidator.d.ts +32 -8
  70. package/lib/esm/validation/validators/ReadOnlyValidator.js +34 -10
  71. package/lib/esm/validation/validators/TimestampValidator.d.ts +37 -3
  72. package/lib/esm/validation/validators/TimestampValidator.js +39 -5
  73. package/lib/esm/validation/validators/UpdateValidator.d.ts +28 -11
  74. package/lib/esm/validation/validators/UpdateValidator.js +23 -8
  75. package/lib/esm/validation/validators/index.js +4 -4
  76. package/lib/identity/decorators.cjs +8 -1
  77. package/lib/identity/decorators.d.ts +7 -0
  78. package/lib/identity/utils.cjs +35 -22
  79. package/lib/identity/utils.d.ts +36 -23
  80. package/lib/index.cjs +14 -28
  81. package/lib/index.d.ts +12 -27
  82. package/lib/interfaces/BulkCrudOperator.cjs +1 -1
  83. package/lib/interfaces/BulkCrudOperator.d.ts +39 -0
  84. package/lib/interfaces/Contextual.cjs +1 -1
  85. package/lib/interfaces/Contextual.d.ts +17 -0
  86. package/lib/interfaces/CrudOperator.cjs +1 -1
  87. package/lib/interfaces/CrudOperator.d.ts +26 -23
  88. package/lib/interfaces/IRepository.cjs +1 -1
  89. package/lib/interfaces/IRepository.d.ts +10 -2
  90. package/lib/model/constants.cjs +12 -14
  91. package/lib/model/constants.d.ts +11 -13
  92. package/lib/model/decorators.cjs +114 -24
  93. package/lib/model/decorators.d.ts +112 -23
  94. package/lib/model/index.cjs +2 -1
  95. package/lib/model/index.d.ts +1 -0
  96. package/lib/model/model.cjs +1 -13
  97. package/lib/model/model.d.ts +2 -141
  98. package/lib/model/overrides.cjs +36 -0
  99. package/lib/model/overrides.d.ts +1 -0
  100. package/lib/model/utils.cjs +40 -1
  101. package/lib/model/utils.d.ts +39 -0
  102. package/lib/model/validation.cjs +246 -104
  103. package/lib/model/validation.d.ts +51 -8
  104. package/lib/operations/Operations.cjs +66 -4
  105. package/lib/operations/Operations.d.ts +65 -3
  106. package/lib/operations/OperationsRegistry.cjs +45 -17
  107. package/lib/operations/OperationsRegistry.d.ts +44 -16
  108. package/lib/operations/constants.cjs +16 -9
  109. package/lib/operations/constants.d.ts +27 -8
  110. package/lib/operations/decorators.cjs +150 -135
  111. package/lib/operations/decorators.d.ts +140 -134
  112. package/lib/operations/types.cjs +1 -1
  113. package/lib/operations/types.d.ts +10 -0
  114. package/lib/repository/BaseRepository.cjs +291 -1
  115. package/lib/repository/BaseRepository.d.ts +322 -0
  116. package/lib/repository/Context.cjs +153 -5
  117. package/lib/repository/Context.d.ts +153 -2
  118. package/lib/repository/Repository.cjs +96 -9
  119. package/lib/repository/Repository.d.ts +89 -0
  120. package/lib/repository/constants.cjs +8 -1
  121. package/lib/repository/constants.d.ts +7 -0
  122. package/lib/repository/errors.cjs +62 -35
  123. package/lib/repository/errors.d.ts +61 -34
  124. package/lib/repository/types.cjs +1 -1
  125. package/lib/repository/types.d.ts +25 -0
  126. package/lib/repository/utils.cjs +1 -1
  127. package/lib/repository/utils.d.ts +11 -0
  128. package/lib/repository/wrappers.cjs +3 -3
  129. package/lib/repository/wrappers.d.ts +2 -2
  130. package/lib/validation/constants.cjs +21 -6
  131. package/lib/validation/constants.d.ts +20 -5
  132. package/lib/validation/decorators.cjs +102 -20
  133. package/lib/validation/decorators.d.ts +101 -19
  134. package/lib/validation/validation.cjs +9 -1
  135. package/lib/validation/validators/ReadOnlyValidator.cjs +33 -9
  136. package/lib/validation/validators/ReadOnlyValidator.d.ts +32 -8
  137. package/lib/validation/validators/TimestampValidator.cjs +38 -4
  138. package/lib/validation/validators/TimestampValidator.d.ts +37 -3
  139. package/lib/validation/validators/UpdateValidator.cjs +23 -8
  140. package/lib/validation/validators/UpdateValidator.d.ts +28 -11
  141. package/package.json +2 -2
@@ -3,17 +3,168 @@ import { Contextual } from "../interfaces/Contextual";
3
3
  import { OperationKeys } from "../operations/constants";
4
4
  import { Constructor, Model } from "@decaf-ts/decorator-validation";
5
5
  import { RepositoryFlags } from "./types";
6
+ /**
7
+ * @description Factory type for creating context instances.
8
+ * @summary Defines a function type that creates context instances with specific repository flags.
9
+ * @template F - The repository flags type extending RepositoryFlags
10
+ * @typedef {Function} ContextFactory
11
+ * @memberOf module:db-decorators
12
+ */
6
13
  export type ContextFactory<F extends RepositoryFlags> = <C extends Context<F>>(arg: Omit<F, "timestamp">) => C;
14
+ /**
15
+ * @description Default factory for creating context instances.
16
+ * @summary A factory function that creates new Context instances with the provided repository flags.
17
+ * It automatically adds a timestamp to the context and returns a properly typed context instance.
18
+ * @const DefaultContextFactory
19
+ * @memberOf module:db-decorators
20
+ */
7
21
  export declare const DefaultContextFactory: ContextFactory<any>;
8
- export declare class Context<F extends RepositoryFlags = RepositoryFlags> {
22
+ /**
23
+ * @description A context management class for handling repository operations.
24
+ * @summary The Context class provides a mechanism for managing repository operations with flags,
25
+ * parent-child relationships, and state accumulation. It allows for hierarchical context chains
26
+ * and maintains operation-specific configurations while supporting type safety through generics.
27
+ *
28
+ * @template F - Type extending RepositoryFlags that defines the context configuration
29
+ *
30
+ * @param {ObjectAccumulator<F>} cache - The internal cache storing accumulated values
31
+ *
32
+ * @class
33
+ *
34
+ * @example
35
+ * ```typescript
36
+ * // Creating a new context with repository flags
37
+ * const context = new Context<RepositoryFlags>();
38
+ *
39
+ * // Accumulating values
40
+ * const enrichedContext = context.accumulate({
41
+ * writeOperation: true,
42
+ * affectedTables: ['users'],
43
+ * operation: OperationKeys.CREATE
44
+ * });
45
+ *
46
+ * // Accessing values
47
+ * const isWrite = enrichedContext.get('writeOperation'); // true
48
+ * const tables = enrichedContext.get('affectedTables'); // ['users']
49
+ * ```
50
+ *
51
+ * @mermaid
52
+ * sequenceDiagram
53
+ * participant C as Client
54
+ * participant Ctx as Context
55
+ * participant Cache as ObjectAccumulator
56
+ *
57
+ * C->>Ctx: new Context()
58
+ * Ctx->>Cache: create cache
59
+ *
60
+ * C->>Ctx: accumulate(value)
61
+ * Ctx->>Cache: accumulate(value)
62
+ * Cache-->>Ctx: updated cache
63
+ * Ctx-->>C: updated context
64
+ *
65
+ * C->>Ctx: get(key)
66
+ * Ctx->>Cache: get(key)
67
+ * alt Key exists in cache
68
+ * Cache-->>Ctx: value
69
+ * else Key not found
70
+ * Ctx->>Ctx: check parent context
71
+ * alt Parent exists
72
+ * Ctx->>Parent: get(key)
73
+ * Parent-->>Ctx: value
74
+ * else No parent
75
+ * Ctx-->>C: throw error
76
+ * end
77
+ * end
78
+ * Ctx-->>C: requested value
79
+ */
80
+ export declare class Context<F extends RepositoryFlags> {
81
+ constructor();
9
82
  static factory: ContextFactory<any>;
10
83
  private readonly cache;
11
- constructor(obj?: F);
84
+ /**
85
+ * @description Accumulates new values into the context.
86
+ * @summary Merges the provided value object with the existing context state,
87
+ * creating a new immutable cache state.
88
+ *
89
+ * @template F - current accumulator type
90
+ * @template V - Type extending object for the values to accumulate
91
+ * @param {V} value - The object containing values to accumulate
92
+ * @returns A new context instance with accumulated values
93
+ */
12
94
  accumulate<V extends object>(value: V): Context<F & V>;
13
95
  get timestamp(): Date;
96
+ /**
97
+ * @description Retrieves a value from the context by key.
98
+ * @summary Attempts to get a value from the current context's cache.
99
+ * If not found, traverses up the parent context chain.
100
+ *
101
+ * @template K - Type extending keyof F for the key to retrieve
102
+ * @template F - Accumulator type
103
+ * @param {K} key - The key to retrieve from the context
104
+ * @returns The value associated with the key
105
+ * @throws {Error} If the key is not found in the context chain
106
+ */
14
107
  get<K extends keyof F>(key: K): F[K];
108
+ /**
109
+ * @description Creates a child context
110
+ * @summary Generates a new context instance with current context as parent
111
+ *
112
+ * @template M - Type extending Model
113
+ * @param {OperationKeys} operation - The operation type
114
+ * @param {Constructor<M>} [model] - Optional model constructor
115
+ * @returns {C} New child context instance
116
+ */
15
117
  child<M extends Model, C extends Context<F>>(operation: OperationKeys, model?: Constructor<M>): C;
118
+ /**
119
+ * @description Creates a child context from another context
120
+ * @summary Generates a new context instance with parent reference
121
+ *
122
+ * @template F - Type extending Repository Flags
123
+ * @template C - Type extending Context<F>
124
+ * @param {C} context - The parent context
125
+ * @param {Partial<F>} [overrides] - Optional flag overrides
126
+ * @returns {C} New child context instance
127
+ */
16
128
  static childFrom<F extends RepositoryFlags, C extends Context<F>>(context: C, overrides?: Partial<F>): C;
129
+ /**
130
+ * @description Creates a new context from operation parameters
131
+ * @summary Generates a context instance for specific operation
132
+ *
133
+ * @template F - Type extending Repository Flags
134
+ * @template M - Type extending Model
135
+ * @param {OperationKeys.DELETE} operation - The operation type
136
+ * @param {Partial<F>} overrides - Flag overrides
137
+ * @param {Constructor<M>} model - The model constructor
138
+ * @param {any} args - Operation arguments
139
+ * @returns {Promise<C>} Promise resolving to new context
140
+ */
17
141
  static from<M extends Model, F extends RepositoryFlags, C extends Context<F>>(operation: OperationKeys.CREATE | OperationKeys.READ | OperationKeys.UPDATE | OperationKeys.DELETE, overrides: Partial<F>, model: Constructor<M>, ...args: any[]): Promise<C>;
142
+ /**
143
+ * @description Prepares arguments for context operations
144
+ * @summary Creates a context args object with the specified operation parameters
145
+ *
146
+ * @template F - Type extending {@link RepositoryFlags}
147
+ * @template M - Type extending {@link Model}
148
+ * @param {OperationKeys.DELETE} operation - The operation type
149
+ * @param {Constructor<M>} model - The model constructor
150
+ * @param {any[]} args - Operation arguments
151
+ * @param {Contextual<F>} [contextual] - Optional contextual object
152
+ * @param {Partial<F>} [overrides] - Optional flag overrides
153
+ * @returns {Promise<ContextArgs>} Promise resolving to context arguments
154
+ *
155
+ * @mermaid
156
+ * sequenceDiagram
157
+ * participant C as Context
158
+ * participant M as Model
159
+ * participant A as Args
160
+ *
161
+ * C->>C: Receive operation request
162
+ * C->>M: Validate model constructor
163
+ * C->>C: Create child context
164
+ * C->>A: Process operation args
165
+ * A->>C: Return context args
166
+ * C->>C: Apply overrides
167
+ * C->>C: Return final context
168
+ */
18
169
  static args<M extends Model, C extends Context<F>, F extends RepositoryFlags>(operation: OperationKeys.CREATE | OperationKeys.READ | OperationKeys.UPDATE | OperationKeys.DELETE, model: Constructor<M>, args: any[], contextual?: Contextual<F>, overrides?: Partial<F>): Promise<ContextArgs<F, C>>;
19
170
  }
@@ -1,15 +1,94 @@
1
- import { DefaultRepositoryFlags } from "./constants";
1
+ import { DefaultRepositoryFlags } from "./constants.js";
2
2
  import { ObjectAccumulator } from "typed-object-accumulator";
3
+ /**
4
+ * @description Default factory for creating context instances.
5
+ * @summary A factory function that creates new Context instances with the provided repository flags.
6
+ * It automatically adds a timestamp to the context and returns a properly typed context instance.
7
+ * @const DefaultContextFactory
8
+ * @memberOf module:db-decorators
9
+ */
3
10
  export const DefaultContextFactory = (arg) => {
4
11
  return new Context().accumulate(Object.assign({}, arg, { timestamp: new Date() }));
5
12
  };
13
+ /**
14
+ * @description A context management class for handling repository operations.
15
+ * @summary The Context class provides a mechanism for managing repository operations with flags,
16
+ * parent-child relationships, and state accumulation. It allows for hierarchical context chains
17
+ * and maintains operation-specific configurations while supporting type safety through generics.
18
+ *
19
+ * @template F - Type extending RepositoryFlags that defines the context configuration
20
+ *
21
+ * @param {ObjectAccumulator<F>} cache - The internal cache storing accumulated values
22
+ *
23
+ * @class
24
+ *
25
+ * @example
26
+ * ```typescript
27
+ * // Creating a new context with repository flags
28
+ * const context = new Context<RepositoryFlags>();
29
+ *
30
+ * // Accumulating values
31
+ * const enrichedContext = context.accumulate({
32
+ * writeOperation: true,
33
+ * affectedTables: ['users'],
34
+ * operation: OperationKeys.CREATE
35
+ * });
36
+ *
37
+ * // Accessing values
38
+ * const isWrite = enrichedContext.get('writeOperation'); // true
39
+ * const tables = enrichedContext.get('affectedTables'); // ['users']
40
+ * ```
41
+ *
42
+ * @mermaid
43
+ * sequenceDiagram
44
+ * participant C as Client
45
+ * participant Ctx as Context
46
+ * participant Cache as ObjectAccumulator
47
+ *
48
+ * C->>Ctx: new Context()
49
+ * Ctx->>Cache: create cache
50
+ *
51
+ * C->>Ctx: accumulate(value)
52
+ * Ctx->>Cache: accumulate(value)
53
+ * Cache-->>Ctx: updated cache
54
+ * Ctx-->>C: updated context
55
+ *
56
+ * C->>Ctx: get(key)
57
+ * Ctx->>Cache: get(key)
58
+ * alt Key exists in cache
59
+ * Cache-->>Ctx: value
60
+ * else Key not found
61
+ * Ctx->>Ctx: check parent context
62
+ * alt Parent exists
63
+ * Ctx->>Parent: get(key)
64
+ * Parent-->>Ctx: value
65
+ * else No parent
66
+ * Ctx-->>C: throw error
67
+ * end
68
+ * end
69
+ * Ctx-->>C: requested value
70
+ */
6
71
  export class Context {
7
- static { this.factory = DefaultContextFactory; }
8
- constructor(obj) {
72
+ constructor() {
9
73
  this.cache = new ObjectAccumulator();
10
- if (obj)
11
- return this.accumulate(obj);
74
+ Object.defineProperty(this, "cache", {
75
+ value: new ObjectAccumulator(),
76
+ writable: false,
77
+ enumerable: false,
78
+ configurable: true,
79
+ });
12
80
  }
81
+ static { this.factory = DefaultContextFactory; }
82
+ /**
83
+ * @description Accumulates new values into the context.
84
+ * @summary Merges the provided value object with the existing context state,
85
+ * creating a new immutable cache state.
86
+ *
87
+ * @template F - current accumulator type
88
+ * @template V - Type extending object for the values to accumulate
89
+ * @param {V} value - The object containing values to accumulate
90
+ * @returns A new context instance with accumulated values
91
+ */
13
92
  accumulate(value) {
14
93
  Object.defineProperty(this, "cache", {
15
94
  value: this.cache.accumulate(value),
@@ -22,6 +101,17 @@ export class Context {
22
101
  get timestamp() {
23
102
  return this.cache.timestamp;
24
103
  }
104
+ /**
105
+ * @description Retrieves a value from the context by key.
106
+ * @summary Attempts to get a value from the current context's cache.
107
+ * If not found, traverses up the parent context chain.
108
+ *
109
+ * @template K - Type extending keyof F for the key to retrieve
110
+ * @template F - Accumulator type
111
+ * @param {K} key - The key to retrieve from the context
112
+ * @returns The value associated with the key
113
+ * @throws {Error} If the key is not found in the context chain
114
+ */
25
115
  get(key) {
26
116
  try {
27
117
  return this.cache.get(key);
@@ -32,15 +122,46 @@ export class Context {
32
122
  throw e;
33
123
  }
34
124
  }
125
+ /**
126
+ * @description Creates a child context
127
+ * @summary Generates a new context instance with current context as parent
128
+ *
129
+ * @template M - Type extending Model
130
+ * @param {OperationKeys} operation - The operation type
131
+ * @param {Constructor<M>} [model] - Optional model constructor
132
+ * @returns {C} New child context instance
133
+ */
35
134
  child(operation, model) {
36
135
  return Context.childFrom(this, {
37
136
  operation: operation,
38
137
  affectedTables: model ? [model] : [],
39
138
  });
40
139
  }
140
+ /**
141
+ * @description Creates a child context from another context
142
+ * @summary Generates a new context instance with parent reference
143
+ *
144
+ * @template F - Type extending Repository Flags
145
+ * @template C - Type extending Context<F>
146
+ * @param {C} context - The parent context
147
+ * @param {Partial<F>} [overrides] - Optional flag overrides
148
+ * @returns {C} New child context instance
149
+ */
41
150
  static childFrom(context, overrides) {
42
151
  return Context.factory(Object.assign({}, context.cache, overrides || {}));
43
152
  }
153
+ /**
154
+ * @description Creates a new context from operation parameters
155
+ * @summary Generates a context instance for specific operation
156
+ *
157
+ * @template F - Type extending Repository Flags
158
+ * @template M - Type extending Model
159
+ * @param {OperationKeys.DELETE} operation - The operation type
160
+ * @param {Partial<F>} overrides - Flag overrides
161
+ * @param {Constructor<M>} model - The model constructor
162
+ * @param {any} args - Operation arguments
163
+ * @returns {Promise<C>} Promise resolving to new context
164
+ */
44
165
  static async from(operation, overrides, model,
45
166
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
46
167
  ...args) {
@@ -49,6 +170,33 @@ export class Context {
49
170
  model: model,
50
171
  }));
51
172
  }
173
+ /**
174
+ * @description Prepares arguments for context operations
175
+ * @summary Creates a context args object with the specified operation parameters
176
+ *
177
+ * @template F - Type extending {@link RepositoryFlags}
178
+ * @template M - Type extending {@link Model}
179
+ * @param {OperationKeys.DELETE} operation - The operation type
180
+ * @param {Constructor<M>} model - The model constructor
181
+ * @param {any[]} args - Operation arguments
182
+ * @param {Contextual<F>} [contextual] - Optional contextual object
183
+ * @param {Partial<F>} [overrides] - Optional flag overrides
184
+ * @returns {Promise<ContextArgs>} Promise resolving to context arguments
185
+ *
186
+ * @mermaid
187
+ * sequenceDiagram
188
+ * participant C as Context
189
+ * participant M as Model
190
+ * participant A as Args
191
+ *
192
+ * C->>C: Receive operation request
193
+ * C->>M: Validate model constructor
194
+ * C->>C: Create child context
195
+ * C->>A: Process operation args
196
+ * A->>C: Return context args
197
+ * C->>C: Apply overrides
198
+ * C->>C: Return final context
199
+ */
52
200
  static async args(operation, model, args, contextual, overrides) {
53
201
  const last = args.pop();
54
202
  async function getContext() {
@@ -74,4 +222,4 @@ export class Context {
74
222
  return { context: c, args: args };
75
223
  }
76
224
  }
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Context.js","sourceRoot":"","sources":["../../../src/repository/Context.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContextArgs } from \"./utils\";\nimport { Contextual } from \"../interfaces/Contextual\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { DefaultRepositoryFlags } from \"./constants\";\nimport { ObjectAccumulator } from \"typed-object-accumulator\";\nimport { RepositoryFlags } from \"./types\";\n\nexport type ContextFactory<F extends RepositoryFlags> = <C extends Context<F>>(\n  arg: Omit<F, \"timestamp\">\n) => C;\n\nexport const DefaultContextFactory: ContextFactory<any> = <\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  arg: Omit<F, \"timestamp\">\n) => {\n  return new Context<F>().accumulate(\n    Object.assign({}, arg, { timestamp: new Date() }) as F\n  ) as C;\n};\n\nexport class Context<F extends RepositoryFlags = RepositoryFlags> {\n  static factory: ContextFactory<any> = DefaultContextFactory;\n\n  private readonly cache: F & ObjectAccumulator<F> =\n    new ObjectAccumulator() as F & ObjectAccumulator<F>;\n\n  constructor(obj?: F) {\n    if (obj) return this.accumulate(obj);\n  }\n\n  accumulate<V extends object>(value: V) {\n    Object.defineProperty(this, \"cache\", {\n      value: this.cache.accumulate(value),\n      writable: false,\n      enumerable: false,\n      configurable: true,\n    });\n    return this as unknown as Context<F & V>;\n  }\n\n  get timestamp() {\n    return this.cache.timestamp;\n  }\n\n  get<K extends keyof F>(key: K): F[K] {\n    try {\n      return this.cache.get(key);\n    } catch (e: unknown) {\n      if (this.cache.parentContext) return this.cache.parentContext.get(key);\n      throw e;\n    }\n  }\n\n  child<M extends Model, C extends Context<F>>(\n    operation: OperationKeys,\n    model?: Constructor<M>\n  ): C {\n    return Context.childFrom<F, C>(\n      this as unknown as C,\n      {\n        operation: operation,\n        affectedTables: model ? [model] : [],\n      } as unknown as Partial<F>\n    );\n  }\n\n  static childFrom<F extends RepositoryFlags, C extends Context<F>>(\n    context: C,\n    overrides?: Partial<F>\n  ): C {\n    return Context.factory(\n      Object.assign({}, context.cache, overrides || {})\n    ) as unknown as C;\n  }\n\n  static async from<\n    M extends Model,\n    F extends RepositoryFlags,\n    C extends Context<F>,\n  >(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    overrides: Partial<F>,\n    model: Constructor<M>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<C> {\n    return Context.factory(\n      Object.assign({}, DefaultRepositoryFlags, overrides, {\n        operation: operation,\n        model: model,\n      })\n    ) as C;\n  }\n\n  static async args<\n    M extends Model,\n    C extends Context<F>,\n    F extends RepositoryFlags,\n  >(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    model: Constructor<M>,\n    args: any[],\n    contextual?: Contextual<F>,\n    overrides?: Partial<F>\n  ): Promise<ContextArgs<F, C>> {\n    const last = args.pop();\n\n    async function getContext() {\n      if (contextual)\n        return contextual.context(operation, overrides || {}, model, ...args);\n      return Context.from(operation, overrides || {}, model, ...args);\n    }\n\n    let c: C;\n    if (last) {\n      if (last instanceof Context) {\n        c = last as C;\n        args.push(last);\n      } else {\n        c = (await getContext()) as C;\n        args.push(last, c);\n      }\n    } else {\n      c = (await getContext()) as C;\n      args.push(c);\n    }\n\n    return { context: c, args: args };\n  }\n}\n"]}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Context.js","sourceRoot":"","sources":["../../../src/repository/Context.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContextArgs } from \"./utils\";\nimport { Contextual } from \"../interfaces/Contextual\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { DefaultRepositoryFlags } from \"./constants\";\nimport { ObjectAccumulator } from \"typed-object-accumulator\";\nimport { RepositoryFlags } from \"./types\";\n\n/**\n * @description Factory type for creating context instances.\n * @summary Defines a function type that creates context instances with specific repository flags.\n * @template F - The repository flags type extending RepositoryFlags\n * @typedef {Function} ContextFactory\n * @memberOf module:db-decorators\n */\nexport type ContextFactory<F extends RepositoryFlags> = <C extends Context<F>>(\n  arg: Omit<F, \"timestamp\">\n) => C;\n\n/**\n * @description Default factory for creating context instances.\n * @summary A factory function that creates new Context instances with the provided repository flags.\n * It automatically adds a timestamp to the context and returns a properly typed context instance.\n * @const DefaultContextFactory\n * @memberOf module:db-decorators\n */\nexport const DefaultContextFactory: ContextFactory<any> = <\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  arg: Omit<F, \"timestamp\">\n) => {\n  return new Context<F>().accumulate(\n    Object.assign({}, arg, { timestamp: new Date() }) as F\n  ) as C;\n};\n\n/**\n * @description A context management class for handling repository operations.\n * @summary The Context class provides a mechanism for managing repository operations with flags,\n * parent-child relationships, and state accumulation. It allows for hierarchical context chains\n * and maintains operation-specific configurations while supporting type safety through generics.\n *\n * @template F - Type extending RepositoryFlags that defines the context configuration\n *\n * @param {ObjectAccumulator<F>} cache - The internal cache storing accumulated values\n *\n * @class\n *\n * @example\n * ```typescript\n * // Creating a new context with repository flags\n * const context = new Context<RepositoryFlags>();\n *\n * // Accumulating values\n * const enrichedContext = context.accumulate({\n *   writeOperation: true,\n *   affectedTables: ['users'],\n *   operation: OperationKeys.CREATE\n * });\n *\n * // Accessing values\n * const isWrite = enrichedContext.get('writeOperation'); // true\n * const tables = enrichedContext.get('affectedTables'); // ['users']\n * ```\n *\n * @mermaid\n * sequenceDiagram\n *   participant C as Client\n *   participant Ctx as Context\n *   participant Cache as ObjectAccumulator\n *\n *   C->>Ctx: new Context()\n *   Ctx->>Cache: create cache\n *\n *   C->>Ctx: accumulate(value)\n *   Ctx->>Cache: accumulate(value)\n *   Cache-->>Ctx: updated cache\n *   Ctx-->>C: updated context\n *\n *   C->>Ctx: get(key)\n *   Ctx->>Cache: get(key)\n *   alt Key exists in cache\n *     Cache-->>Ctx: value\n *   else Key not found\n *     Ctx->>Ctx: check parent context\n *     alt Parent exists\n *       Ctx->>Parent: get(key)\n *       Parent-->>Ctx: value\n *     else No parent\n *       Ctx-->>C: throw error\n *     end\n *   end\n *   Ctx-->>C: requested value\n */\nexport class Context<F extends RepositoryFlags> {\n  constructor() {\n    Object.defineProperty(this, \"cache\", {\n      value: new ObjectAccumulator<F>(),\n      writable: false,\n      enumerable: false,\n      configurable: true,\n    });\n  }\n\n  static factory: ContextFactory<any> = DefaultContextFactory;\n\n  private readonly cache: F & ObjectAccumulator<F> =\n    new ObjectAccumulator() as F & ObjectAccumulator<F>;\n\n  /**\n   * @description Accumulates new values into the context.\n   * @summary Merges the provided value object with the existing context state,\n   * creating a new immutable cache state.\n   *\n   * @template F - current accumulator type\n   * @template V - Type extending object for the values to accumulate\n   * @param {V} value - The object containing values to accumulate\n   * @returns A new context instance with accumulated values\n   */\n  accumulate<V extends object>(value: V) {\n    Object.defineProperty(this, \"cache\", {\n      value: this.cache.accumulate(value),\n      writable: false,\n      enumerable: false,\n      configurable: true,\n    });\n    return this as unknown as Context<F & V>;\n  }\n\n  get timestamp() {\n    return this.cache.timestamp;\n  }\n\n  /**\n   * @description Retrieves a value from the context by key.\n   * @summary Attempts to get a value from the current context's cache.\n   * If not found, traverses up the parent context chain.\n   *\n   * @template K - Type extending keyof F for the key to retrieve\n   * @template F - Accumulator type\n   * @param {K} key - The key to retrieve from the context\n   * @returns The value associated with the key\n   * @throws {Error} If the key is not found in the context chain\n   */\n  get<K extends keyof F>(key: K): F[K] {\n    try {\n      return this.cache.get(key);\n    } catch (e: unknown) {\n      if (this.cache.parentContext) return this.cache.parentContext.get(key);\n      throw e;\n    }\n  }\n\n  /**\n   * @description Creates a child context\n   * @summary Generates a new context instance with current context as parent\n   *\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation type\n   * @param {Constructor<M>} [model] - Optional model constructor\n   * @returns {C} New child context instance\n   */\n  child<M extends Model, C extends Context<F>>(\n    operation: OperationKeys,\n    model?: Constructor<M>\n  ): C {\n    return Context.childFrom<F, C>(\n      this as unknown as C,\n      {\n        operation: operation,\n        affectedTables: model ? [model] : [],\n      } as unknown as Partial<F>\n    );\n  }\n\n  /**\n   * @description Creates a child context from another context\n   * @summary Generates a new context instance with parent reference\n   *\n   * @template F - Type extending Repository Flags\n   * @template C - Type extending Context<F>\n   * @param {C} context - The parent context\n   * @param {Partial<F>} [overrides] - Optional flag overrides\n   * @returns {C} New child context instance\n   */\n  static childFrom<F extends RepositoryFlags, C extends Context<F>>(\n    context: C,\n    overrides?: Partial<F>\n  ): C {\n    return Context.factory(\n      Object.assign({}, context.cache, overrides || {})\n    ) as unknown as C;\n  }\n\n  /**\n   * @description Creates a new context from operation parameters\n   * @summary Generates a context instance for specific operation\n   *\n   * @template F - Type extending Repository Flags\n   * @template M - Type extending Model\n   * @param {OperationKeys.DELETE} operation - The operation type\n   * @param {Partial<F>} overrides - Flag overrides\n   * @param {Constructor<M>} model - The model constructor\n   * @param {any} args - Operation arguments\n   * @returns {Promise<C>} Promise resolving to new context\n   */\n  static async from<\n    M extends Model,\n    F extends RepositoryFlags,\n    C extends Context<F>,\n  >(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    overrides: Partial<F>,\n    model: Constructor<M>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<C> {\n    return Context.factory(\n      Object.assign({}, DefaultRepositoryFlags, overrides, {\n        operation: operation,\n        model: model,\n      })\n    ) as C;\n  }\n\n  /**\n   * @description Prepares arguments for context operations\n   * @summary Creates a context args object with the specified operation parameters\n   *\n   * @template F - Type extending {@link RepositoryFlags}\n   * @template M - Type extending {@link Model}\n   * @param {OperationKeys.DELETE} operation - The operation type\n   * @param {Constructor<M>} model - The model constructor\n   * @param {any[]} args - Operation arguments\n   * @param {Contextual<F>} [contextual] - Optional contextual object\n   * @param {Partial<F>} [overrides] - Optional flag overrides\n   * @returns {Promise<ContextArgs>} Promise resolving to context arguments\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant C as Context\n   *   participant M as Model\n   *   participant A as Args\n   *\n   *   C->>C: Receive operation request\n   *   C->>M: Validate model constructor\n   *   C->>C: Create child context\n   *   C->>A: Process operation args\n   *   A->>C: Return context args\n   *   C->>C: Apply overrides\n   *   C->>C: Return final context\n   */\n  static async args<\n    M extends Model,\n    C extends Context<F>,\n    F extends RepositoryFlags,\n  >(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    model: Constructor<M>,\n    args: any[],\n    contextual?: Contextual<F>,\n    overrides?: Partial<F>\n  ): Promise<ContextArgs<F, C>> {\n    const last = args.pop();\n\n    async function getContext() {\n      if (contextual)\n        return contextual.context(operation, overrides || {}, model, ...args);\n      return Context.from(operation, overrides || {}, model, ...args);\n    }\n\n    let c: C;\n    if (last) {\n      if (last instanceof Context) {\n        c = last as C;\n        args.push(last);\n      } else {\n        c = (await getContext()) as C;\n        args.push(last, c);\n      }\n    } else {\n      c = (await getContext()) as C;\n      args.push(c);\n    }\n\n    return { context: c, args: args };\n  }\n}\n"]}
@@ -2,11 +2,100 @@ import { BaseRepository } from "./BaseRepository";
2
2
  import { Constructor, Model } from "@decaf-ts/decorator-validation";
3
3
  import { Context } from "./Context";
4
4
  import { RepositoryFlags } from "./types";
5
+ /**
6
+ * @description Concrete repository implementation with validation support.
7
+ * @summary The Repository class extends BaseRepository to provide additional validation
8
+ * functionality. It overrides prefix methods to perform model validation before database
9
+ * operations and throws ValidationError when validation fails.
10
+ * @template M - The model type extending Model
11
+ * @template F - The repository flags type, defaults to RepositoryFlags
12
+ * @template C - The context type, defaults to Context<F>
13
+ * @class Repository
14
+ * @example
15
+ * class UserModel extends Model {
16
+ * @id()
17
+ * id: string;
18
+ *
19
+ * @required()
20
+ * @minLength(3)
21
+ * name: string;
22
+ * }
23
+ *
24
+ * class UserRepository extends Repository<UserModel> {
25
+ * constructor() {
26
+ * super(UserModel);
27
+ * }
28
+ *
29
+ * async create(model: UserModel): Promise<UserModel> {
30
+ * // Implementation with automatic validation
31
+ * return model;
32
+ * }
33
+ * }
34
+ *
35
+ * // Using the repository
36
+ * const repo = new UserRepository();
37
+ * try {
38
+ * const user = await repo.create({ name: 'Jo' }); // Will throw ValidationError
39
+ * } catch (error) {
40
+ * console.error(error); // ValidationError: name must be at least 3 characters
41
+ * }
42
+ */
5
43
  export declare abstract class Repository<M extends Model, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> extends BaseRepository<M, F, C> {
6
44
  protected constructor(clazz?: Constructor<M>);
45
+ /**
46
+ * @description Prepares a model for creation with validation.
47
+ * @summary Overrides the base createPrefix method to add validation checks.
48
+ * Creates a context, instantiates a new model, enforces decorators, and validates
49
+ * the model before allowing creation to proceed.
50
+ * @param {M} model - The model instance to prepare for creation
51
+ * @param {any[]} args - Additional arguments for the create operation
52
+ * @return A promise that resolves to an array containing the validated model and context arguments
53
+ * @throws {ValidationError} If the model fails validation
54
+ */
7
55
  protected createPrefix(model: M, ...args: any[]): Promise<[M, ...any[]]>;
56
+ /**
57
+ * @description Prepares multiple models for creation with validation.
58
+ * @summary Overrides the base createAllPrefix method to add validation checks for multiple models.
59
+ * Creates a context, instantiates new models, enforces decorators, and validates
60
+ * each model before allowing creation to proceed. Collects validation errors from all models.
61
+ * @param {M[]} models - The array of model instances to prepare for creation
62
+ * @param {any[]} args - Additional arguments for the create operation
63
+ * @return {Promise<any[]>} A promise that resolves to an array containing the validated models and context arguments
64
+ * @throws {ValidationError} If any model fails validation, with details about which models failed
65
+ */
8
66
  protected createAllPrefix(models: M[], ...args: any[]): Promise<any[]>;
67
+ /**
68
+ * @description Prepares a model for update with validation.
69
+ * @summary Overrides the base updatePrefix method to add validation checks.
70
+ * Creates a context, validates the primary key, retrieves the existing model,
71
+ * merges the old and new models, enforces decorators, and validates the model
72
+ * before allowing the update to proceed.
73
+ * @param {M} model - The model instance to prepare for update
74
+ * @param {any[]} args - Additional arguments for the update operation
75
+ * @return A promise that resolves to an array containing the validated model and context arguments
76
+ * @throws {InternalError} If the model doesn't have a primary key value
77
+ * @throws {ValidationError} If the model fails validation
78
+ */
9
79
  protected updatePrefix(model: M, ...args: any[]): Promise<[M, ...args: any[]]>;
80
+ /**
81
+ * @description Prepares multiple models for update with validation.
82
+ * @summary Overrides the base updateAllPrefix method to add validation checks for multiple models.
83
+ * Creates a context, validates primary keys, retrieves existing models, merges old and new models,
84
+ * enforces decorators, and validates each model before allowing updates to proceed.
85
+ * Collects validation errors from all models.
86
+ * @param {M[]} models - The array of model instances to prepare for update
87
+ * @param {any[]} args - Additional arguments for the update operation
88
+ * @return A promise that resolves to an array containing the validated models and context arguments
89
+ * @throws {InternalError} If any model doesn't have a primary key value
90
+ * @throws {ValidationError} If any model fails validation, with details about which models failed
91
+ */
10
92
  protected updateAllPrefix(models: M[], ...args: any[]): Promise<any[]>;
93
+ /**
94
+ * @description Creates a reflection key for database operations.
95
+ * @summary Generates a key for storing metadata in the reflection system by prefixing
96
+ * the provided key with the database reflection prefix.
97
+ * @param {string} key - The base key to prefix
98
+ * @return {string} The prefixed reflection key
99
+ */
11
100
  static key(key: string): string;
12
101
  }