@decaf-ts/db-decorators 0.6.7 → 0.6.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/db-decorators.cjs +5 -72
- package/dist/db-decorators.esm.cjs +5 -72
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.js +1 -1
- package/lib/esm/repository/Context.d.ts +3 -65
- package/lib/esm/repository/Context.js +4 -71
- package/lib/index.cjs +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/repository/Context.cjs +4 -71
- package/lib/repository/Context.d.ts +3 -65
- package/package.json +1 -1
package/lib/esm/index.d.ts
CHANGED
package/lib/esm/index.js
CHANGED
|
@@ -15,5 +15,5 @@ export * from "./validation/index.js";
|
|
|
15
15
|
* @const VERSION
|
|
16
16
|
* @memberOf module:db-decorators
|
|
17
17
|
*/
|
|
18
|
-
export const VERSION = "0.6.
|
|
18
|
+
export const VERSION = "0.6.8";
|
|
19
19
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsb0NBQTJCO0FBQzNCLHNDQUE2QjtBQUM3QixpQ0FBd0I7QUFDeEIsc0NBQTZCO0FBQzdCLHNDQUE2QjtBQUM3QixzQ0FBNkI7QUFFN0I7Ozs7R0FJRztBQUdIOzs7OztHQUtHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2lkZW50aXR5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9pbnRlcmZhY2VzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vb3BlcmF0aW9uc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcmVwb3NpdG9yeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmFsaWRhdGlvblwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBEYXRhYmFzZSBkZWNvcmF0b3JzIGZvciBUeXBlU2NyaXB0IGFwcGxpY2F0aW9uc1xuICogQHN1bW1hcnkgQSBjb21wcmVoZW5zaXZlIGxpYnJhcnkgcHJvdmlkaW5nIGRlY29yYXRvcnMgYW5kIHV0aWxpdGllcyBmb3IgZGF0YWJhc2Ugb3BlcmF0aW9ucywgbW9kZWwgZGVmaW5pdGlvbnMsIHZhbGlkYXRpb24sIGFuZCByZXBvc2l0b3J5IHBhdHRlcm5zIGluIFR5cGVTY3JpcHQgYXBwbGljYXRpb25zXG4gKiBAbW9kdWxlIGRiLWRlY29yYXRvcnNcbiAqL1xuXG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEN1cnJlbnQgdmVyc2lvbiBvZiB0aGUgcmVmbGVjdGlvbiBwYWNrYWdlXG4gKiBAc3VtbWFyeSBTdG9yZXMgdGhlIHNlbWFudGljIHZlcnNpb24gbnVtYmVyIG9mIHRoZSBwYWNrYWdlXG4gKiBAY29uc3QgVkVSU0lPTlxuICogQG1lbWJlck9mIG1vZHVsZTpkYi1kZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gXCIjI1ZFUlNJT04jI1wiO1xuIl19
|
|
@@ -2,6 +2,7 @@ import { ContextArgs } from "./utils";
|
|
|
2
2
|
import { Contextual } from "../interfaces/Contextual";
|
|
3
3
|
import { OperationKeys } from "../operations/constants";
|
|
4
4
|
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
|
5
|
+
import { ObjectAccumulator } from "typed-object-accumulator";
|
|
5
6
|
import { RepositoryFlags } from "./types";
|
|
6
7
|
/**
|
|
7
8
|
* @description Factory type for creating context instances.
|
|
@@ -80,91 +81,28 @@ export declare const DefaultContextFactory: ContextFactory<any>;
|
|
|
80
81
|
export declare class Context<F extends RepositoryFlags> {
|
|
81
82
|
constructor();
|
|
82
83
|
static factory: ContextFactory<any>;
|
|
83
|
-
|
|
84
|
+
readonly cache: RepositoryFlags & ObjectAccumulator<any>;
|
|
84
85
|
/**
|
|
85
86
|
* @description Accumulates new values into the context.
|
|
86
87
|
* @summary Merges the provided value object with the existing context state,
|
|
87
88
|
* 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
89
|
*/
|
|
94
90
|
accumulate<V extends object>(value: V): Context<F & V>;
|
|
95
|
-
get timestamp():
|
|
91
|
+
get timestamp(): F["timestamp"];
|
|
96
92
|
/**
|
|
97
93
|
* @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
94
|
*/
|
|
107
95
|
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
|
-
*/
|
|
117
|
-
child<M extends Model, C extends Context<F>>(operation: OperationKeys, model?: Constructor<M>): C;
|
|
118
96
|
/**
|
|
119
97
|
* @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
98
|
*/
|
|
128
99
|
static childFrom<F extends RepositoryFlags, C extends Context<F>>(context: C, overrides?: Partial<F>): C;
|
|
129
100
|
/**
|
|
130
101
|
* @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
102
|
*/
|
|
141
103
|
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
104
|
/**
|
|
143
105
|
* @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
106
|
*/
|
|
169
107
|
static args<M extends Model<any>, 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>>;
|
|
170
108
|
}
|
|
@@ -83,11 +83,6 @@ export class Context {
|
|
|
83
83
|
* @description Accumulates new values into the context.
|
|
84
84
|
* @summary Merges the provided value object with the existing context state,
|
|
85
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
86
|
*/
|
|
92
87
|
accumulate(value) {
|
|
93
88
|
Object.defineProperty(this, "cache", {
|
|
@@ -103,64 +98,26 @@ export class Context {
|
|
|
103
98
|
}
|
|
104
99
|
/**
|
|
105
100
|
* @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
101
|
*/
|
|
115
102
|
get(key) {
|
|
116
103
|
try {
|
|
117
104
|
return this.cache.get(key);
|
|
118
105
|
}
|
|
119
106
|
catch (e) {
|
|
120
|
-
|
|
121
|
-
|
|
107
|
+
const parent = this.cache.parentContext;
|
|
108
|
+
if (parent)
|
|
109
|
+
return parent.get(key);
|
|
122
110
|
throw e;
|
|
123
111
|
}
|
|
124
112
|
}
|
|
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
|
-
*/
|
|
134
|
-
child(operation, model) {
|
|
135
|
-
return Context.childFrom(this, {
|
|
136
|
-
operation: operation,
|
|
137
|
-
affectedTables: model ? [model] : [],
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
113
|
/**
|
|
141
114
|
* @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
115
|
*/
|
|
150
116
|
static childFrom(context, overrides) {
|
|
151
117
|
return Context.factory(Object.assign({}, context.cache, overrides || {}));
|
|
152
118
|
}
|
|
153
119
|
/**
|
|
154
120
|
* @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
121
|
*/
|
|
165
122
|
static async from(operation, overrides, model,
|
|
166
123
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
@@ -172,30 +129,6 @@ export class Context {
|
|
|
172
129
|
}
|
|
173
130
|
/**
|
|
174
131
|
* @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
132
|
*/
|
|
200
133
|
static async args(operation, model, args, contextual, overrides) {
|
|
201
134
|
const last = args.pop();
|
|
@@ -223,4 +156,4 @@ export class Context {
|
|
|
223
156
|
return { context: c, args: args };
|
|
224
157
|
}
|
|
225
158
|
}
|
|
226
|
-
//# 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<any>,\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        args.push(last);\n        c = (await getContext()) as C;\n        args.push(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"]}
|
|
159
|
+
//# 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  readonly cache: RepositoryFlags & ObjectAccumulator<any> =\n    new ObjectAccumulator() as unknown as RepositoryFlags &\n      ObjectAccumulator<any>;\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  accumulate<V extends object>(value: V) {\n    Object.defineProperty(this, \"cache\", {\n      value: (this.cache as ObjectAccumulator<any>).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 as any).timestamp as F[\"timestamp\"];\n  }\n\n  /**\n   * @description Retrieves a value from the context by key.\n   */\n  get<K extends keyof F>(key: K): F[K] {\n    try {\n      return (this.cache as ObjectAccumulator<any>).get(\n        key as unknown as string\n      ) as F[K];\n    } catch (e: unknown) {\n      const parent = (this.cache as any).parentContext as\n        | Context<F>\n        | undefined;\n      if (parent) return parent.get(key);\n      throw e;\n    }\n  }\n\n  /**\n   * @description Creates a child context from another context\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 as any).cache, overrides || {})\n    ) as unknown as C;\n  }\n\n  /**\n   * @description Creates a new context from operation parameters\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 as RepositoryFlags, overrides, {\n        operation: operation,\n        model: model,\n      })\n    ) as C;\n  }\n\n  /**\n   * @description Prepares arguments for context operations\n   */\n  static async args<\n    M extends Model<any>,\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        args.push(last);\n        c = (await getContext()) as C;\n        args.push(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"]}
|
package/lib/index.cjs
CHANGED
|
@@ -32,5 +32,5 @@ __exportStar(require("./validation/index.cjs"), exports);
|
|
|
32
32
|
* @const VERSION
|
|
33
33
|
* @memberOf module:db-decorators
|
|
34
34
|
*/
|
|
35
|
-
exports.VERSION = "0.6.
|
|
35
|
+
exports.VERSION = "0.6.8";
|
|
36
36
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSx1REFBMkI7QUFDM0IseURBQTZCO0FBQzdCLG9EQUF3QjtBQUN4Qix5REFBNkI7QUFDN0IseURBQTZCO0FBQzdCLHlEQUE2QjtBQUU3Qjs7OztHQUlHO0FBR0g7Ozs7O0dBS0c7QUFDVSxRQUFBLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9pZGVudGl0eVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaW50ZXJmYWNlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vbW9kZWxcIjtcbmV4cG9ydCAqIGZyb20gXCIuL29wZXJhdGlvbnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3JlcG9zaXRvcnlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZhbGlkYXRpb25cIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRGF0YWJhc2UgZGVjb3JhdG9ycyBmb3IgVHlwZVNjcmlwdCBhcHBsaWNhdGlvbnNcbiAqIEBzdW1tYXJ5IEEgY29tcHJlaGVuc2l2ZSBsaWJyYXJ5IHByb3ZpZGluZyBkZWNvcmF0b3JzIGFuZCB1dGlsaXRpZXMgZm9yIGRhdGFiYXNlIG9wZXJhdGlvbnMsIG1vZGVsIGRlZmluaXRpb25zLCB2YWxpZGF0aW9uLCBhbmQgcmVwb3NpdG9yeSBwYXR0ZXJucyBpbiBUeXBlU2NyaXB0IGFwcGxpY2F0aW9uc1xuICogQG1vZHVsZSBkYi1kZWNvcmF0b3JzXG4gKi9cblxuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBDdXJyZW50IHZlcnNpb24gb2YgdGhlIHJlZmxlY3Rpb24gcGFja2FnZVxuICogQHN1bW1hcnkgU3RvcmVzIHRoZSBzZW1hbnRpYyB2ZXJzaW9uIG51bWJlciBvZiB0aGUgcGFja2FnZVxuICogQGNvbnN0IFZFUlNJT05cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGItZGVjb3JhdG9yc1xuICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiIyNWRVJTSU9OIyNcIjtcbiJdfQ==
|
package/lib/index.d.ts
CHANGED
|
@@ -87,11 +87,6 @@ class Context {
|
|
|
87
87
|
* @description Accumulates new values into the context.
|
|
88
88
|
* @summary Merges the provided value object with the existing context state,
|
|
89
89
|
* creating a new immutable cache state.
|
|
90
|
-
*
|
|
91
|
-
* @template F - current accumulator type
|
|
92
|
-
* @template V - Type extending object for the values to accumulate
|
|
93
|
-
* @param {V} value - The object containing values to accumulate
|
|
94
|
-
* @returns A new context instance with accumulated values
|
|
95
90
|
*/
|
|
96
91
|
accumulate(value) {
|
|
97
92
|
Object.defineProperty(this, "cache", {
|
|
@@ -107,64 +102,26 @@ class Context {
|
|
|
107
102
|
}
|
|
108
103
|
/**
|
|
109
104
|
* @description Retrieves a value from the context by key.
|
|
110
|
-
* @summary Attempts to get a value from the current context's cache.
|
|
111
|
-
* If not found, traverses up the parent context chain.
|
|
112
|
-
*
|
|
113
|
-
* @template K - Type extending keyof F for the key to retrieve
|
|
114
|
-
* @template F - Accumulator type
|
|
115
|
-
* @param {K} key - The key to retrieve from the context
|
|
116
|
-
* @returns The value associated with the key
|
|
117
|
-
* @throws {Error} If the key is not found in the context chain
|
|
118
105
|
*/
|
|
119
106
|
get(key) {
|
|
120
107
|
try {
|
|
121
108
|
return this.cache.get(key);
|
|
122
109
|
}
|
|
123
110
|
catch (e) {
|
|
124
|
-
|
|
125
|
-
|
|
111
|
+
const parent = this.cache.parentContext;
|
|
112
|
+
if (parent)
|
|
113
|
+
return parent.get(key);
|
|
126
114
|
throw e;
|
|
127
115
|
}
|
|
128
116
|
}
|
|
129
|
-
/**
|
|
130
|
-
* @description Creates a child context
|
|
131
|
-
* @summary Generates a new context instance with current context as parent
|
|
132
|
-
*
|
|
133
|
-
* @template M - Type extending Model
|
|
134
|
-
* @param {OperationKeys} operation - The operation type
|
|
135
|
-
* @param {Constructor<M>} [model] - Optional model constructor
|
|
136
|
-
* @returns {C} New child context instance
|
|
137
|
-
*/
|
|
138
|
-
child(operation, model) {
|
|
139
|
-
return Context.childFrom(this, {
|
|
140
|
-
operation: operation,
|
|
141
|
-
affectedTables: model ? [model] : [],
|
|
142
|
-
});
|
|
143
|
-
}
|
|
144
117
|
/**
|
|
145
118
|
* @description Creates a child context from another context
|
|
146
|
-
* @summary Generates a new context instance with parent reference
|
|
147
|
-
*
|
|
148
|
-
* @template F - Type extending Repository Flags
|
|
149
|
-
* @template C - Type extending Context<F>
|
|
150
|
-
* @param {C} context - The parent context
|
|
151
|
-
* @param {Partial<F>} [overrides] - Optional flag overrides
|
|
152
|
-
* @returns {C} New child context instance
|
|
153
119
|
*/
|
|
154
120
|
static childFrom(context, overrides) {
|
|
155
121
|
return Context.factory(Object.assign({}, context.cache, overrides || {}));
|
|
156
122
|
}
|
|
157
123
|
/**
|
|
158
124
|
* @description Creates a new context from operation parameters
|
|
159
|
-
* @summary Generates a context instance for specific operation
|
|
160
|
-
*
|
|
161
|
-
* @template F - Type extending Repository Flags
|
|
162
|
-
* @template M - Type extending Model
|
|
163
|
-
* @param {OperationKeys.DELETE} operation - The operation type
|
|
164
|
-
* @param {Partial<F>} overrides - Flag overrides
|
|
165
|
-
* @param {Constructor<M>} model - The model constructor
|
|
166
|
-
* @param {any} args - Operation arguments
|
|
167
|
-
* @returns {Promise<C>} Promise resolving to new context
|
|
168
125
|
*/
|
|
169
126
|
static async from(operation, overrides, model,
|
|
170
127
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
@@ -176,30 +133,6 @@ class Context {
|
|
|
176
133
|
}
|
|
177
134
|
/**
|
|
178
135
|
* @description Prepares arguments for context operations
|
|
179
|
-
* @summary Creates a context args object with the specified operation parameters
|
|
180
|
-
*
|
|
181
|
-
* @template F - Type extending {@link RepositoryFlags}
|
|
182
|
-
* @template M - Type extending {@link Model}
|
|
183
|
-
* @param {OperationKeys.DELETE} operation - The operation type
|
|
184
|
-
* @param {Constructor<M>} model - The model constructor
|
|
185
|
-
* @param {any[]} args - Operation arguments
|
|
186
|
-
* @param {Contextual<F>} [contextual] - Optional contextual object
|
|
187
|
-
* @param {Partial<F>} [overrides] - Optional flag overrides
|
|
188
|
-
* @returns {Promise<ContextArgs>} Promise resolving to context arguments
|
|
189
|
-
*
|
|
190
|
-
* @mermaid
|
|
191
|
-
* sequenceDiagram
|
|
192
|
-
* participant C as Context
|
|
193
|
-
* participant M as Model
|
|
194
|
-
* participant A as Args
|
|
195
|
-
*
|
|
196
|
-
* C->>C: Receive operation request
|
|
197
|
-
* C->>M: Validate model constructor
|
|
198
|
-
* C->>C: Create child context
|
|
199
|
-
* C->>A: Process operation args
|
|
200
|
-
* A->>C: Return context args
|
|
201
|
-
* C->>C: Apply overrides
|
|
202
|
-
* C->>C: Return final context
|
|
203
136
|
*/
|
|
204
137
|
static async args(operation, model, args, contextual, overrides) {
|
|
205
138
|
const last = args.pop();
|
|
@@ -228,4 +161,4 @@ class Context {
|
|
|
228
161
|
}
|
|
229
162
|
}
|
|
230
163
|
exports.Context = Context;
|
|
231
|
-
//# 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<any>,\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        args.push(last);\n        c = (await getContext()) as C;\n        args.push(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"]}
|
|
164
|
+
//# 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  readonly cache: RepositoryFlags & ObjectAccumulator<any> =\n    new ObjectAccumulator() as unknown as RepositoryFlags &\n      ObjectAccumulator<any>;\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  accumulate<V extends object>(value: V) {\n    Object.defineProperty(this, \"cache\", {\n      value: (this.cache as ObjectAccumulator<any>).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 as any).timestamp as F[\"timestamp\"];\n  }\n\n  /**\n   * @description Retrieves a value from the context by key.\n   */\n  get<K extends keyof F>(key: K): F[K] {\n    try {\n      return (this.cache as ObjectAccumulator<any>).get(\n        key as unknown as string\n      ) as F[K];\n    } catch (e: unknown) {\n      const parent = (this.cache as any).parentContext as\n        | Context<F>\n        | undefined;\n      if (parent) return parent.get(key);\n      throw e;\n    }\n  }\n\n  /**\n   * @description Creates a child context from another context\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 as any).cache, overrides || {})\n    ) as unknown as C;\n  }\n\n  /**\n   * @description Creates a new context from operation parameters\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 as RepositoryFlags, overrides, {\n        operation: operation,\n        model: model,\n      })\n    ) as C;\n  }\n\n  /**\n   * @description Prepares arguments for context operations\n   */\n  static async args<\n    M extends Model<any>,\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        args.push(last);\n        c = (await getContext()) as C;\n        args.push(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,6 +2,7 @@ import { ContextArgs } from "./utils";
|
|
|
2
2
|
import { Contextual } from "../interfaces/Contextual";
|
|
3
3
|
import { OperationKeys } from "../operations/constants";
|
|
4
4
|
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
|
5
|
+
import { ObjectAccumulator } from "typed-object-accumulator";
|
|
5
6
|
import { RepositoryFlags } from "./types";
|
|
6
7
|
/**
|
|
7
8
|
* @description Factory type for creating context instances.
|
|
@@ -80,91 +81,28 @@ export declare const DefaultContextFactory: ContextFactory<any>;
|
|
|
80
81
|
export declare class Context<F extends RepositoryFlags> {
|
|
81
82
|
constructor();
|
|
82
83
|
static factory: ContextFactory<any>;
|
|
83
|
-
|
|
84
|
+
readonly cache: RepositoryFlags & ObjectAccumulator<any>;
|
|
84
85
|
/**
|
|
85
86
|
* @description Accumulates new values into the context.
|
|
86
87
|
* @summary Merges the provided value object with the existing context state,
|
|
87
88
|
* 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
89
|
*/
|
|
94
90
|
accumulate<V extends object>(value: V): Context<F & V>;
|
|
95
|
-
get timestamp():
|
|
91
|
+
get timestamp(): F["timestamp"];
|
|
96
92
|
/**
|
|
97
93
|
* @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
94
|
*/
|
|
107
95
|
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
|
-
*/
|
|
117
|
-
child<M extends Model, C extends Context<F>>(operation: OperationKeys, model?: Constructor<M>): C;
|
|
118
96
|
/**
|
|
119
97
|
* @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
98
|
*/
|
|
128
99
|
static childFrom<F extends RepositoryFlags, C extends Context<F>>(context: C, overrides?: Partial<F>): C;
|
|
129
100
|
/**
|
|
130
101
|
* @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
102
|
*/
|
|
141
103
|
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
104
|
/**
|
|
143
105
|
* @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
106
|
*/
|
|
169
107
|
static args<M extends Model<any>, 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>>;
|
|
170
108
|
}
|