@decaf-ts/db-decorators 0.6.1 → 0.6.2
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/LICENSE.md +21 -157
- package/README.md +571 -10
- package/dist/db-decorators.cjs +1352 -322
- package/dist/db-decorators.esm.cjs +1352 -323
- package/lib/esm/identity/decorators.d.ts +7 -0
- package/lib/esm/identity/decorators.js +11 -4
- package/lib/esm/identity/index.js +3 -3
- package/lib/esm/identity/utils.d.ts +36 -23
- package/lib/esm/identity/utils.js +38 -25
- package/lib/esm/index.d.ts +12 -27
- package/lib/esm/index.js +13 -28
- package/lib/esm/interfaces/BulkCrudOperator.d.ts +39 -0
- package/lib/esm/interfaces/BulkCrudOperator.js +1 -1
- package/lib/esm/interfaces/Contextual.d.ts +17 -0
- package/lib/esm/interfaces/Contextual.js +1 -1
- package/lib/esm/interfaces/CrudOperator.d.ts +26 -23
- package/lib/esm/interfaces/CrudOperator.js +1 -1
- package/lib/esm/interfaces/IRepository.d.ts +10 -2
- package/lib/esm/interfaces/IRepository.js +1 -1
- package/lib/esm/interfaces/index.js +5 -5
- package/lib/esm/model/constants.d.ts +11 -13
- package/lib/esm/model/constants.js +12 -14
- package/lib/esm/model/decorators.d.ts +112 -23
- package/lib/esm/model/decorators.js +119 -29
- package/lib/esm/model/index.d.ts +1 -0
- package/lib/esm/model/index.js +7 -6
- package/lib/esm/model/model.d.ts +2 -141
- package/lib/esm/model/model.js +2 -13
- package/lib/esm/model/overrides.d.ts +1 -0
- package/lib/esm/model/overrides.js +23 -0
- package/lib/esm/model/utils.d.ts +39 -0
- package/lib/esm/model/utils.js +42 -3
- package/lib/esm/model/validation.d.ts +26 -8
- package/lib/esm/model/validation.js +29 -11
- package/lib/esm/operations/Operations.d.ts +65 -3
- package/lib/esm/operations/Operations.js +68 -6
- package/lib/esm/operations/OperationsRegistry.d.ts +44 -16
- package/lib/esm/operations/OperationsRegistry.js +46 -18
- package/lib/esm/operations/constants.d.ts +27 -8
- package/lib/esm/operations/constants.js +16 -9
- package/lib/esm/operations/decorators.d.ts +140 -134
- package/lib/esm/operations/decorators.js +152 -137
- package/lib/esm/operations/index.js +6 -6
- package/lib/esm/operations/types.d.ts +10 -0
- package/lib/esm/operations/types.js +1 -1
- package/lib/esm/repository/BaseRepository.d.ts +322 -0
- package/lib/esm/repository/BaseRepository.js +297 -7
- package/lib/esm/repository/Context.d.ts +153 -2
- package/lib/esm/repository/Context.js +154 -6
- package/lib/esm/repository/Repository.d.ts +89 -0
- package/lib/esm/repository/Repository.js +96 -7
- package/lib/esm/repository/constants.d.ts +7 -0
- package/lib/esm/repository/constants.js +8 -1
- package/lib/esm/repository/errors.d.ts +61 -34
- package/lib/esm/repository/errors.js +62 -35
- package/lib/esm/repository/index.js +9 -9
- package/lib/esm/repository/types.d.ts +25 -0
- package/lib/esm/repository/types.js +1 -1
- package/lib/esm/repository/utils.d.ts +11 -0
- package/lib/esm/repository/utils.js +4 -4
- package/lib/esm/repository/wrappers.d.ts +2 -2
- package/lib/esm/repository/wrappers.js +5 -5
- package/lib/esm/validation/constants.d.ts +20 -5
- package/lib/esm/validation/constants.js +22 -7
- package/lib/esm/validation/decorators.d.ts +101 -19
- package/lib/esm/validation/decorators.js +109 -27
- package/lib/esm/validation/index.js +5 -5
- package/lib/esm/validation/validation.js +10 -2
- package/lib/esm/validation/validators/ReadOnlyValidator.d.ts +32 -8
- package/lib/esm/validation/validators/ReadOnlyValidator.js +34 -10
- package/lib/esm/validation/validators/TimestampValidator.d.ts +37 -3
- package/lib/esm/validation/validators/TimestampValidator.js +39 -5
- package/lib/esm/validation/validators/UpdateValidator.d.ts +28 -11
- package/lib/esm/validation/validators/UpdateValidator.js +23 -8
- package/lib/esm/validation/validators/index.js +4 -4
- package/lib/identity/decorators.cjs +8 -1
- package/lib/identity/decorators.d.ts +7 -0
- package/lib/identity/utils.cjs +35 -22
- package/lib/identity/utils.d.ts +36 -23
- package/lib/index.cjs +14 -28
- package/lib/index.d.ts +12 -27
- package/lib/interfaces/BulkCrudOperator.cjs +1 -1
- package/lib/interfaces/BulkCrudOperator.d.ts +39 -0
- package/lib/interfaces/Contextual.cjs +1 -1
- package/lib/interfaces/Contextual.d.ts +17 -0
- package/lib/interfaces/CrudOperator.cjs +1 -1
- package/lib/interfaces/CrudOperator.d.ts +26 -23
- package/lib/interfaces/IRepository.cjs +1 -1
- package/lib/interfaces/IRepository.d.ts +10 -2
- package/lib/model/constants.cjs +12 -14
- package/lib/model/constants.d.ts +11 -13
- package/lib/model/decorators.cjs +114 -24
- package/lib/model/decorators.d.ts +112 -23
- package/lib/model/index.cjs +2 -1
- package/lib/model/index.d.ts +1 -0
- package/lib/model/model.cjs +1 -13
- package/lib/model/model.d.ts +2 -141
- package/lib/model/overrides.cjs +25 -0
- package/lib/model/overrides.d.ts +1 -0
- package/lib/model/utils.cjs +40 -1
- package/lib/model/utils.d.ts +39 -0
- package/lib/model/validation.cjs +27 -9
- package/lib/model/validation.d.ts +26 -8
- package/lib/operations/Operations.cjs +66 -4
- package/lib/operations/Operations.d.ts +65 -3
- package/lib/operations/OperationsRegistry.cjs +45 -17
- package/lib/operations/OperationsRegistry.d.ts +44 -16
- package/lib/operations/constants.cjs +16 -9
- package/lib/operations/constants.d.ts +27 -8
- package/lib/operations/decorators.cjs +150 -135
- package/lib/operations/decorators.d.ts +140 -134
- package/lib/operations/types.cjs +1 -1
- package/lib/operations/types.d.ts +10 -0
- package/lib/repository/BaseRepository.cjs +291 -1
- package/lib/repository/BaseRepository.d.ts +322 -0
- package/lib/repository/Context.cjs +153 -5
- package/lib/repository/Context.d.ts +153 -2
- package/lib/repository/Repository.cjs +90 -1
- package/lib/repository/Repository.d.ts +89 -0
- package/lib/repository/constants.cjs +8 -1
- package/lib/repository/constants.d.ts +7 -0
- package/lib/repository/errors.cjs +62 -35
- package/lib/repository/errors.d.ts +61 -34
- package/lib/repository/types.cjs +1 -1
- package/lib/repository/types.d.ts +25 -0
- package/lib/repository/utils.cjs +1 -1
- package/lib/repository/utils.d.ts +11 -0
- package/lib/repository/wrappers.cjs +3 -3
- package/lib/repository/wrappers.d.ts +2 -2
- package/lib/validation/constants.cjs +21 -6
- package/lib/validation/constants.d.ts +20 -5
- package/lib/validation/decorators.cjs +102 -20
- package/lib/validation/decorators.d.ts +101 -19
- package/lib/validation/validation.cjs +9 -1
- package/lib/validation/validators/ReadOnlyValidator.cjs +33 -9
- package/lib/validation/validators/ReadOnlyValidator.d.ts +32 -8
- package/lib/validation/validators/TimestampValidator.cjs +38 -4
- package/lib/validation/validators/TimestampValidator.d.ts +37 -3
- package/lib/validation/validators/UpdateValidator.cjs +23 -8
- package/lib/validation/validators/UpdateValidator.d.ts +28 -11
- package/package.json +2 -2
|
@@ -1,13 +1,61 @@
|
|
|
1
|
-
import { enforceDBDecorators } from "./utils";
|
|
2
|
-
import { OperationKeys } from "
|
|
3
|
-
import { InternalError, ValidationError } from "./errors";
|
|
4
|
-
import { BaseRepository } from "./BaseRepository";
|
|
5
|
-
import { DBKeys } from "
|
|
6
|
-
import { Context } from "./Context";
|
|
1
|
+
import { enforceDBDecorators } from "./utils.js";
|
|
2
|
+
import { OperationKeys } from "./../operations/constants.js";
|
|
3
|
+
import { InternalError, ValidationError } from "./errors.js";
|
|
4
|
+
import { BaseRepository } from "./BaseRepository.js";
|
|
5
|
+
import { DBKeys } from "./../model/constants.js";
|
|
6
|
+
import { Context } from "./Context.js";
|
|
7
|
+
/**
|
|
8
|
+
* @description Concrete repository implementation with validation support.
|
|
9
|
+
* @summary The Repository class extends BaseRepository to provide additional validation
|
|
10
|
+
* functionality. It overrides prefix methods to perform model validation before database
|
|
11
|
+
* operations and throws ValidationError when validation fails.
|
|
12
|
+
* @template M - The model type extending Model
|
|
13
|
+
* @template F - The repository flags type, defaults to RepositoryFlags
|
|
14
|
+
* @template C - The context type, defaults to Context<F>
|
|
15
|
+
* @class Repository
|
|
16
|
+
* @example
|
|
17
|
+
* class UserModel extends Model {
|
|
18
|
+
* @id()
|
|
19
|
+
* id: string;
|
|
20
|
+
*
|
|
21
|
+
* @required()
|
|
22
|
+
* @minLength(3)
|
|
23
|
+
* name: string;
|
|
24
|
+
* }
|
|
25
|
+
*
|
|
26
|
+
* class UserRepository extends Repository<UserModel> {
|
|
27
|
+
* constructor() {
|
|
28
|
+
* super(UserModel);
|
|
29
|
+
* }
|
|
30
|
+
*
|
|
31
|
+
* async create(model: UserModel): Promise<UserModel> {
|
|
32
|
+
* // Implementation with automatic validation
|
|
33
|
+
* return model;
|
|
34
|
+
* }
|
|
35
|
+
* }
|
|
36
|
+
*
|
|
37
|
+
* // Using the repository
|
|
38
|
+
* const repo = new UserRepository();
|
|
39
|
+
* try {
|
|
40
|
+
* const user = await repo.create({ name: 'Jo' }); // Will throw ValidationError
|
|
41
|
+
* } catch (error) {
|
|
42
|
+
* console.error(error); // ValidationError: name must be at least 3 characters
|
|
43
|
+
* }
|
|
44
|
+
*/
|
|
7
45
|
export class Repository extends BaseRepository {
|
|
8
46
|
constructor(clazz) {
|
|
9
47
|
super(clazz);
|
|
10
48
|
}
|
|
49
|
+
/**
|
|
50
|
+
* @description Prepares a model for creation with validation.
|
|
51
|
+
* @summary Overrides the base createPrefix method to add validation checks.
|
|
52
|
+
* Creates a context, instantiates a new model, enforces decorators, and validates
|
|
53
|
+
* the model before allowing creation to proceed.
|
|
54
|
+
* @param {M} model - The model instance to prepare for creation
|
|
55
|
+
* @param {any[]} args - Additional arguments for the create operation
|
|
56
|
+
* @return A promise that resolves to an array containing the validated model and context arguments
|
|
57
|
+
* @throws {ValidationError} If the model fails validation
|
|
58
|
+
*/
|
|
11
59
|
async createPrefix(model, ...args) {
|
|
12
60
|
const contextArgs = await Context.args(OperationKeys.CREATE, this.class, args);
|
|
13
61
|
model = new this.class(model);
|
|
@@ -17,6 +65,16 @@ export class Repository extends BaseRepository {
|
|
|
17
65
|
throw new ValidationError(errors.toString());
|
|
18
66
|
return [model, ...contextArgs.args];
|
|
19
67
|
}
|
|
68
|
+
/**
|
|
69
|
+
* @description Prepares multiple models for creation with validation.
|
|
70
|
+
* @summary Overrides the base createAllPrefix method to add validation checks for multiple models.
|
|
71
|
+
* Creates a context, instantiates new models, enforces decorators, and validates
|
|
72
|
+
* each model before allowing creation to proceed. Collects validation errors from all models.
|
|
73
|
+
* @param {M[]} models - The array of model instances to prepare for creation
|
|
74
|
+
* @param {any[]} args - Additional arguments for the create operation
|
|
75
|
+
* @return {Promise<any[]>} A promise that resolves to an array containing the validated models and context arguments
|
|
76
|
+
* @throws {ValidationError} If any model fails validation, with details about which models failed
|
|
77
|
+
*/
|
|
20
78
|
async createAllPrefix(models, ...args) {
|
|
21
79
|
const contextArgs = await Context.args(OperationKeys.CREATE, this.class, args);
|
|
22
80
|
await Promise.all(models.map(async (m) => {
|
|
@@ -38,6 +96,18 @@ export class Repository extends BaseRepository {
|
|
|
38
96
|
throw new ValidationError(errors);
|
|
39
97
|
return [models, ...contextArgs.args];
|
|
40
98
|
}
|
|
99
|
+
/**
|
|
100
|
+
* @description Prepares a model for update with validation.
|
|
101
|
+
* @summary Overrides the base updatePrefix method to add validation checks.
|
|
102
|
+
* Creates a context, validates the primary key, retrieves the existing model,
|
|
103
|
+
* merges the old and new models, enforces decorators, and validates the model
|
|
104
|
+
* before allowing the update to proceed.
|
|
105
|
+
* @param {M} model - The model instance to prepare for update
|
|
106
|
+
* @param {any[]} args - Additional arguments for the update operation
|
|
107
|
+
* @return A promise that resolves to an array containing the validated model and context arguments
|
|
108
|
+
* @throws {InternalError} If the model doesn't have a primary key value
|
|
109
|
+
* @throws {ValidationError} If the model fails validation
|
|
110
|
+
*/
|
|
41
111
|
async updatePrefix(model, ...args) {
|
|
42
112
|
const contextArgs = await Context.args(OperationKeys.UPDATE, this.class, args);
|
|
43
113
|
const pk = model[this.pk];
|
|
@@ -51,6 +121,18 @@ export class Repository extends BaseRepository {
|
|
|
51
121
|
throw new ValidationError(errors.toString());
|
|
52
122
|
return [model, ...contextArgs.args];
|
|
53
123
|
}
|
|
124
|
+
/**
|
|
125
|
+
* @description Prepares multiple models for update with validation.
|
|
126
|
+
* @summary Overrides the base updateAllPrefix method to add validation checks for multiple models.
|
|
127
|
+
* Creates a context, validates primary keys, retrieves existing models, merges old and new models,
|
|
128
|
+
* enforces decorators, and validates each model before allowing updates to proceed.
|
|
129
|
+
* Collects validation errors from all models.
|
|
130
|
+
* @param {M[]} models - The array of model instances to prepare for update
|
|
131
|
+
* @param {any[]} args - Additional arguments for the update operation
|
|
132
|
+
* @return A promise that resolves to an array containing the validated models and context arguments
|
|
133
|
+
* @throws {InternalError} If any model doesn't have a primary key value
|
|
134
|
+
* @throws {ValidationError} If any model fails validation, with details about which models failed
|
|
135
|
+
*/
|
|
54
136
|
async updateAllPrefix(models, ...args) {
|
|
55
137
|
const contextArgs = await Context.args(OperationKeys.UPDATE, this.class, args);
|
|
56
138
|
const ids = models.map((m) => {
|
|
@@ -76,8 +158,15 @@ export class Repository extends BaseRepository {
|
|
|
76
158
|
throw new ValidationError(errors);
|
|
77
159
|
return [models, ...contextArgs.args];
|
|
78
160
|
}
|
|
161
|
+
/**
|
|
162
|
+
* @description Creates a reflection key for database operations.
|
|
163
|
+
* @summary Generates a key for storing metadata in the reflection system by prefixing
|
|
164
|
+
* the provided key with the database reflection prefix.
|
|
165
|
+
* @param {string} key - The base key to prefix
|
|
166
|
+
* @return {string} The prefixed reflection key
|
|
167
|
+
*/
|
|
79
168
|
static key(key) {
|
|
80
169
|
return DBKeys.REFLECT + key;
|
|
81
170
|
}
|
|
82
171
|
}
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Repository.js","sourceRoot":"","sources":["../../../src/repository/Repository.ts"],"names":[],"mappings":"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","sourcesContent":["import { enforceDBDecorators } from \"./utils\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { InternalError, ValidationError } from \"./errors\";\nimport { BaseRepository } from \"./BaseRepository\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { DBKeys } from \"../model/constants\";\nimport { Context } from \"./Context\";\nimport { RepositoryFlags } from \"./types\";\n\nexport abstract class Repository<\n  M extends Model,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> extends BaseRepository<M, F, C> {\n  protected constructor(clazz?: Constructor<M>) {\n    super(clazz);\n  }\n\n  protected override async createPrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...any[]]> {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args\n    );\n    model = new this.class(model);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.CREATE,\n      OperationKeys.ON\n    );\n\n    const errors = model.hasErrors();\n    if (errors) throw new ValidationError(errors.toString());\n\n    return [model, ...contextArgs.args];\n  }\n\n  protected override async createAllPrefix(\n    models: M[],\n    ...args: any[]\n  ): Promise<any[]> {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args\n    );\n    await Promise.all(\n      models.map(async (m) => {\n        m = new this.class(m);\n        await enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.CREATE,\n          OperationKeys.ON\n        );\n        return m;\n      })\n    );\n    const errors = models\n      .map((m) => m.hasErrors())\n      .reduce((accum: string | undefined, e, i) => {\n        if (e)\n          accum =\n            typeof accum === \"string\"\n              ? accum + `\\n - ${i}: ${e.toString()}`\n              : ` - ${i}: ${e.toString()}`;\n        return accum;\n      }, undefined);\n    if (errors) throw new ValidationError(errors);\n    return [models, ...contextArgs.args];\n  }\n\n  protected override async updatePrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...args: any[]]> {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args\n    );\n    const pk = (model as any)[this.pk];\n    if (!pk)\n      throw new InternalError(\n        `No value for the Id is defined under the property ${this.pk as string}`\n      );\n\n    const oldModel: M = await this.read(pk);\n\n    model = this.merge(oldModel, model);\n\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.UPDATE,\n      OperationKeys.ON,\n      oldModel\n    );\n\n    const errors = model.hasErrors(oldModel as any);\n    if (errors) throw new ValidationError(errors.toString());\n    return [model, ...contextArgs.args];\n  }\n\n  protected override async updateAllPrefix(models: M[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args\n    );\n    const ids = models.map((m) => {\n      const id = m[this.pk];\n      if (typeof id === \"undefined\")\n        throw new InternalError(\n          `No value for the Id is defined under the property ${this.pk as string}`\n        );\n      return id as string;\n    });\n    const oldModels: M[] = await this.readAll(ids, ...contextArgs.args);\n    models = models.map((m, i) => this.merge(oldModels[i], m));\n    await Promise.all(\n      models.map((m, i) =>\n        enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.UPDATE,\n          OperationKeys.ON,\n          oldModels[i]\n        )\n      )\n    );\n\n    const errors = models\n      .map((m, i) => m.hasErrors(oldModels[i] as any))\n      .reduce((accum: string | undefined, e, i) => {\n        if (e)\n          accum =\n            typeof accum === \"string\"\n              ? accum + `\\n - ${i}: ${e.toString()}`\n              : ` - ${i}: ${e.toString()}`;\n        return accum;\n      }, undefined);\n    if (errors) throw new ValidationError(errors);\n    return [models, ...contextArgs.args];\n  }\n\n  static key(key: string) {\n    return DBKeys.REFLECT + key;\n  }\n}\n"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Repository.js","sourceRoot":"","sources":["../../../src/repository/Repository.ts"],"names":[],"mappings":"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","sourcesContent":["import { enforceDBDecorators } from \"./utils\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { InternalError, ValidationError } from \"./errors\";\nimport { BaseRepository } from \"./BaseRepository\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { DBKeys } from \"../model/constants\";\nimport { Context } from \"./Context\";\nimport { RepositoryFlags } from \"./types\";\n\n/**\n * @description Concrete repository implementation with validation support.\n * @summary The Repository class extends BaseRepository to provide additional validation\n * functionality. It overrides prefix methods to perform model validation before database\n * operations and throws ValidationError when validation fails.\n * @template M - The model type extending Model\n * @template F - The repository flags type, defaults to RepositoryFlags\n * @template C - The context type, defaults to Context<F>\n * @class Repository\n * @example\n * class UserModel extends Model {\n *   @id()\n *   id: string;\n *\n *   @required()\n *   @minLength(3)\n *   name: string;\n * }\n *\n * class UserRepository extends Repository<UserModel> {\n *   constructor() {\n *     super(UserModel);\n *   }\n *\n *   async create(model: UserModel): Promise<UserModel> {\n *     // Implementation with automatic validation\n *     return model;\n *   }\n * }\n *\n * // Using the repository\n * const repo = new UserRepository();\n * try {\n *   const user = await repo.create({ name: 'Jo' }); // Will throw ValidationError\n * } catch (error) {\n *   console.error(error); // ValidationError: name must be at least 3 characters\n * }\n */\nexport abstract class Repository<\n  M extends Model,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> extends BaseRepository<M, F, C> {\n  protected constructor(clazz?: Constructor<M>) {\n    super(clazz);\n  }\n\n  /**\n   * @description Prepares a model for creation with validation.\n   * @summary Overrides the base createPrefix method to add validation checks.\n   * Creates a context, instantiates a new model, enforces decorators, and validates\n   * the model before allowing creation to proceed.\n   * @param {M} model - The model instance to prepare for creation\n   * @param {any[]} args - Additional arguments for the create operation\n   * @return A promise that resolves to an array containing the validated model and context arguments\n   * @throws {ValidationError} If the model fails validation\n   */\n  protected override async createPrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...any[]]> {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args\n    );\n    model = new this.class(model);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.CREATE,\n      OperationKeys.ON\n    );\n\n    const errors = model.hasErrors();\n    if (errors) throw new ValidationError(errors.toString());\n\n    return [model, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepares multiple models for creation with validation.\n   * @summary Overrides the base createAllPrefix method to add validation checks for multiple models.\n   * Creates a context, instantiates new models, enforces decorators, and validates\n   * each model before allowing creation to proceed. Collects validation errors from all models.\n   * @param {M[]} models - The array of model instances to prepare for creation\n   * @param {any[]} args - Additional arguments for the create operation\n   * @return {Promise<any[]>} A promise that resolves to an array containing the validated models and context arguments\n   * @throws {ValidationError} If any model fails validation, with details about which models failed\n   */\n  protected override async createAllPrefix(\n    models: M[],\n    ...args: any[]\n  ): Promise<any[]> {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args\n    );\n    await Promise.all(\n      models.map(async (m) => {\n        m = new this.class(m);\n        await enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.CREATE,\n          OperationKeys.ON\n        );\n        return m;\n      })\n    );\n    const errors = models\n      .map((m) => m.hasErrors())\n      .reduce((accum: string | undefined, e, i) => {\n        if (e)\n          accum =\n            typeof accum === \"string\"\n              ? accum + `\\n - ${i}: ${e.toString()}`\n              : ` - ${i}: ${e.toString()}`;\n        return accum;\n      }, undefined);\n    if (errors) throw new ValidationError(errors);\n    return [models, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepares a model for update with validation.\n   * @summary Overrides the base updatePrefix method to add validation checks.\n   * Creates a context, validates the primary key, retrieves the existing model,\n   * merges the old and new models, enforces decorators, and validates the model\n   * before allowing the update to proceed.\n   * @param {M} model - The model instance to prepare for update\n   * @param {any[]} args - Additional arguments for the update operation\n   * @return A promise that resolves to an array containing the validated model and context arguments\n   * @throws {InternalError} If the model doesn't have a primary key value\n   * @throws {ValidationError} If the model fails validation\n   */\n  protected override async updatePrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...args: any[]]> {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args\n    );\n    const pk = (model as any)[this.pk];\n    if (!pk)\n      throw new InternalError(\n        `No value for the Id is defined under the property ${this.pk as string}`\n      );\n\n    const oldModel: M = await this.read(pk);\n\n    model = this.merge(oldModel, model);\n\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.UPDATE,\n      OperationKeys.ON,\n      oldModel\n    );\n\n    const errors = model.hasErrors(oldModel as any);\n    if (errors) throw new ValidationError(errors.toString());\n    return [model, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepares multiple models for update with validation.\n   * @summary Overrides the base updateAllPrefix method to add validation checks for multiple models.\n   * Creates a context, validates primary keys, retrieves existing models, merges old and new models,\n   * enforces decorators, and validates each model before allowing updates to proceed.\n   * Collects validation errors from all models.\n   * @param {M[]} models - The array of model instances to prepare for update\n   * @param {any[]} args - Additional arguments for the update operation\n   * @return A promise that resolves to an array containing the validated models and context arguments\n   * @throws {InternalError} If any model doesn't have a primary key value\n   * @throws {ValidationError} If any model fails validation, with details about which models failed\n   */\n  protected override async updateAllPrefix(models: M[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args\n    );\n    const ids = models.map((m) => {\n      const id = m[this.pk];\n      if (typeof id === \"undefined\")\n        throw new InternalError(\n          `No value for the Id is defined under the property ${this.pk as string}`\n        );\n      return id as string;\n    });\n    const oldModels: M[] = await this.readAll(ids, ...contextArgs.args);\n    models = models.map((m, i) => this.merge(oldModels[i], m));\n    await Promise.all(\n      models.map((m, i) =>\n        enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.UPDATE,\n          OperationKeys.ON,\n          oldModels[i]\n        )\n      )\n    );\n\n    const errors = models\n      .map((m, i) => m.hasErrors(oldModels[i] as any))\n      .reduce((accum: string | undefined, e, i) => {\n        if (e)\n          accum =\n            typeof accum === \"string\"\n              ? accum + `\\n - ${i}: ${e.toString()}`\n              : ` - ${i}: ${e.toString()}`;\n        return accum;\n      }, undefined);\n    if (errors) throw new ValidationError(errors);\n    return [models, ...contextArgs.args];\n  }\n\n  /**\n   * @description Creates a reflection key for database operations.\n   * @summary Generates a key for storing metadata in the reflection system by prefixing\n   * the provided key with the database reflection prefix.\n   * @param {string} key - The base key to prefix\n   * @return {string} The prefixed reflection key\n   */\n  static key(key: string) {\n    return DBKeys.REFLECT + key;\n  }\n}\n"]}
|
|
@@ -1,2 +1,9 @@
|
|
|
1
1
|
import { RepositoryFlags } from "./types";
|
|
2
|
+
/**
|
|
3
|
+
* @description Default configuration flags for repository operations.
|
|
4
|
+
* @summary Provides default values for repository operation flags, excluding the timestamp property.
|
|
5
|
+
* These flags control behavior such as context handling, validation, error handling, and more.
|
|
6
|
+
* @const DefaultRepositoryFlags
|
|
7
|
+
* @memberOf module:db-decorators
|
|
8
|
+
*/
|
|
2
9
|
export declare const DefaultRepositoryFlags: Omit<RepositoryFlags, "timestamp">;
|
|
@@ -1,3 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description Default configuration flags for repository operations.
|
|
3
|
+
* @summary Provides default values for repository operation flags, excluding the timestamp property.
|
|
4
|
+
* These flags control behavior such as context handling, validation, error handling, and more.
|
|
5
|
+
* @const DefaultRepositoryFlags
|
|
6
|
+
* @memberOf module:db-decorators
|
|
7
|
+
*/
|
|
1
8
|
export const DefaultRepositoryFlags = {
|
|
2
9
|
parentContext: undefined,
|
|
3
10
|
childContexts: [],
|
|
@@ -9,4 +16,4 @@ export const DefaultRepositoryFlags = {
|
|
|
9
16
|
breakOnHandlerError: true,
|
|
10
17
|
rebuildWithTransient: true,
|
|
11
18
|
};
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlcG9zaXRvcnkvY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUF1QztJQUN4RSxhQUFhLEVBQUUsU0FBUztJQUN4QixhQUFhLEVBQUUsRUFBRTtJQUNqQiwyQkFBMkIsRUFBRSxFQUFFO0lBQy9CLFFBQVEsRUFBRSxFQUFFO0lBQ1osY0FBYyxFQUFFLEtBQUs7SUFDckIsY0FBYyxFQUFFLEVBQUU7SUFDbEIsU0FBUyxFQUFFLFNBQVM7SUFDcEIsbUJBQW1CLEVBQUUsSUFBSTtJQUN6QixvQkFBb0IsRUFBRSxJQUFJO0NBQzNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZXBvc2l0b3J5RmxhZ3MgfSBmcm9tIFwiLi90eXBlc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBEZWZhdWx0IGNvbmZpZ3VyYXRpb24gZmxhZ3MgZm9yIHJlcG9zaXRvcnkgb3BlcmF0aW9ucy5cbiAqIEBzdW1tYXJ5IFByb3ZpZGVzIGRlZmF1bHQgdmFsdWVzIGZvciByZXBvc2l0b3J5IG9wZXJhdGlvbiBmbGFncywgZXhjbHVkaW5nIHRoZSB0aW1lc3RhbXAgcHJvcGVydHkuXG4gKiBUaGVzZSBmbGFncyBjb250cm9sIGJlaGF2aW9yIHN1Y2ggYXMgY29udGV4dCBoYW5kbGluZywgdmFsaWRhdGlvbiwgZXJyb3IgaGFuZGxpbmcsIGFuZCBtb3JlLlxuICogQGNvbnN0IERlZmF1bHRSZXBvc2l0b3J5RmxhZ3NcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGItZGVjb3JhdG9yc1xuICovXG5leHBvcnQgY29uc3QgRGVmYXVsdFJlcG9zaXRvcnlGbGFnczogT21pdDxSZXBvc2l0b3J5RmxhZ3MsIFwidGltZXN0YW1wXCI+ID0ge1xuICBwYXJlbnRDb250ZXh0OiB1bmRlZmluZWQsXG4gIGNoaWxkQ29udGV4dHM6IFtdLFxuICBpZ25vcmVkVmFsaWRhdGlvblByb3BlcnRpZXM6IFtdLFxuICBjYWxsQXJnczogW10sXG4gIHdyaXRlT3BlcmF0aW9uOiBmYWxzZSxcbiAgYWZmZWN0ZWRUYWJsZXM6IFtdLFxuICBvcGVyYXRpb246IHVuZGVmaW5lZCxcbiAgYnJlYWtPbkhhbmRsZXJFcnJvcjogdHJ1ZSxcbiAgcmVidWlsZFdpdGhUcmFuc2llbnQ6IHRydWUsXG59O1xuIl19
|
|
@@ -1,69 +1,96 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @
|
|
3
|
-
*
|
|
4
|
-
* @param {string}
|
|
5
|
-
*
|
|
6
|
-
* @
|
|
7
|
-
* @
|
|
2
|
+
* @description Base error class for the repository module
|
|
3
|
+
* @summary Abstract base error class that all other error types extend from. Provides common error handling functionality.
|
|
4
|
+
* @param {string} name - The name of the error
|
|
5
|
+
* @param {string|Error} msg - The error message or Error object
|
|
6
|
+
* @param {number} code - The HTTP status code associated with this error
|
|
7
|
+
* @class BaseError
|
|
8
|
+
* @example
|
|
9
|
+
* // This is an abstract class and should not be instantiated directly
|
|
10
|
+
* // Instead, use one of the concrete error classes:
|
|
11
|
+
* throw new ValidationError('Invalid data provided');
|
|
8
12
|
*/
|
|
9
13
|
export declare abstract class BaseError extends Error {
|
|
10
14
|
readonly code: number;
|
|
11
15
|
protected constructor(name: string, msg: string | Error, code?: number);
|
|
12
16
|
}
|
|
13
17
|
/**
|
|
14
|
-
* @
|
|
15
|
-
*
|
|
16
|
-
* @param {string} msg
|
|
17
|
-
*
|
|
18
|
+
* @description Error thrown when validation fails
|
|
19
|
+
* @summary Represents a failure in the Model details, typically thrown when data validation fails
|
|
20
|
+
* @param {string|Error} msg - The error message or Error object
|
|
21
|
+
* @return {ValidationError} A new ValidationError instance
|
|
18
22
|
* @class ValidationError
|
|
19
|
-
* @
|
|
23
|
+
* @example
|
|
24
|
+
* // Throw a validation error when data is invalid
|
|
25
|
+
* if (!isValid(data)) {
|
|
26
|
+
* throw new ValidationError('Invalid data format');
|
|
27
|
+
* }
|
|
20
28
|
*/
|
|
21
29
|
export declare class ValidationError extends BaseError {
|
|
22
30
|
constructor(msg: string | Error);
|
|
23
31
|
}
|
|
24
32
|
/**
|
|
25
|
-
* @
|
|
26
|
-
*
|
|
27
|
-
* @param {string} msg
|
|
28
|
-
*
|
|
33
|
+
* @description Error thrown for internal system failures
|
|
34
|
+
* @summary Represents an internal failure (should mean an error in code) with HTTP 500 status code
|
|
35
|
+
* @param {string|Error} msg - The error message or Error object
|
|
36
|
+
* @return {InternalError} A new InternalError instance
|
|
29
37
|
* @class InternalError
|
|
30
|
-
* @
|
|
38
|
+
* @example
|
|
39
|
+
* // Throw an internal error when an unexpected condition occurs
|
|
40
|
+
* try {
|
|
41
|
+
* // Some operation
|
|
42
|
+
* } catch (error) {
|
|
43
|
+
* throw new InternalError('Unexpected internal error occurred');
|
|
44
|
+
* }
|
|
31
45
|
*/
|
|
32
46
|
export declare class InternalError extends BaseError {
|
|
33
47
|
constructor(msg: string | Error);
|
|
34
48
|
}
|
|
35
49
|
/**
|
|
36
|
-
* @
|
|
37
|
-
*
|
|
38
|
-
* @param {string} msg
|
|
39
|
-
*
|
|
50
|
+
* @description Error thrown when serialization or deserialization fails
|
|
51
|
+
* @summary Represents a failure in the Model de/serialization, typically when converting between data formats
|
|
52
|
+
* @param {string|Error} msg - The error message or Error object
|
|
53
|
+
* @return {SerializationError} A new SerializationError instance
|
|
40
54
|
* @class SerializationError
|
|
41
|
-
* @
|
|
42
|
-
*
|
|
55
|
+
* @example
|
|
56
|
+
* // Throw a serialization error when JSON parsing fails
|
|
57
|
+
* try {
|
|
58
|
+
* const data = JSON.parse(invalidJson);
|
|
59
|
+
* } catch (error) {
|
|
60
|
+
* throw new SerializationError('Failed to parse JSON data');
|
|
61
|
+
* }
|
|
43
62
|
*/
|
|
44
63
|
export declare class SerializationError extends BaseError {
|
|
45
64
|
constructor(msg: string | Error);
|
|
46
65
|
}
|
|
47
66
|
/**
|
|
48
|
-
* @
|
|
49
|
-
*
|
|
50
|
-
* @param {string} msg
|
|
51
|
-
*
|
|
67
|
+
* @description Error thrown when a requested resource is not found
|
|
68
|
+
* @summary Represents a failure in finding a model, resulting in a 404 HTTP status code
|
|
69
|
+
* @param {string|Error} msg - The error message or Error object
|
|
70
|
+
* @return {NotFoundError} A new NotFoundError instance
|
|
52
71
|
* @class NotFoundError
|
|
53
|
-
* @
|
|
54
|
-
*
|
|
72
|
+
* @example
|
|
73
|
+
* // Throw a not found error when a record doesn't exist
|
|
74
|
+
* const user = await repository.findById(id);
|
|
75
|
+
* if (!user) {
|
|
76
|
+
* throw new NotFoundError(`User with ID ${id} not found`);
|
|
77
|
+
* }
|
|
55
78
|
*/
|
|
56
79
|
export declare class NotFoundError extends BaseError {
|
|
57
80
|
constructor(msg: string | Error);
|
|
58
81
|
}
|
|
59
82
|
/**
|
|
60
|
-
* @
|
|
61
|
-
*
|
|
62
|
-
* @param {string} msg
|
|
63
|
-
*
|
|
83
|
+
* @description Error thrown when a conflict occurs in the storage
|
|
84
|
+
* @summary Represents a conflict in the storage, typically when trying to create a duplicate resource
|
|
85
|
+
* @param {string|Error} msg - The error message or Error object
|
|
86
|
+
* @return {ConflictError} A new ConflictError instance
|
|
64
87
|
* @class ConflictError
|
|
65
|
-
* @
|
|
66
|
-
*
|
|
88
|
+
* @example
|
|
89
|
+
* // Throw a conflict error when trying to create a duplicate record
|
|
90
|
+
* const existingUser = await repository.findByEmail(email);
|
|
91
|
+
* if (existingUser) {
|
|
92
|
+
* throw new ConflictError(`User with email ${email} already exists`);
|
|
93
|
+
* }
|
|
67
94
|
*/
|
|
68
95
|
export declare class ConflictError extends BaseError {
|
|
69
96
|
constructor(msg: string | Error);
|
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @
|
|
3
|
-
*
|
|
4
|
-
* @param {string}
|
|
5
|
-
*
|
|
6
|
-
* @
|
|
7
|
-
* @
|
|
2
|
+
* @description Base error class for the repository module
|
|
3
|
+
* @summary Abstract base error class that all other error types extend from. Provides common error handling functionality.
|
|
4
|
+
* @param {string} name - The name of the error
|
|
5
|
+
* @param {string|Error} msg - The error message or Error object
|
|
6
|
+
* @param {number} code - The HTTP status code associated with this error
|
|
7
|
+
* @class BaseError
|
|
8
|
+
* @example
|
|
9
|
+
* // This is an abstract class and should not be instantiated directly
|
|
10
|
+
* // Instead, use one of the concrete error classes:
|
|
11
|
+
* throw new ValidationError('Invalid data provided');
|
|
8
12
|
*/
|
|
9
13
|
export class BaseError extends Error {
|
|
10
14
|
constructor(name, msg, code = 500) {
|
|
@@ -18,12 +22,16 @@ export class BaseError extends Error {
|
|
|
18
22
|
}
|
|
19
23
|
}
|
|
20
24
|
/**
|
|
21
|
-
* @
|
|
22
|
-
*
|
|
23
|
-
* @param {string} msg
|
|
24
|
-
*
|
|
25
|
+
* @description Error thrown when validation fails
|
|
26
|
+
* @summary Represents a failure in the Model details, typically thrown when data validation fails
|
|
27
|
+
* @param {string|Error} msg - The error message or Error object
|
|
28
|
+
* @return {ValidationError} A new ValidationError instance
|
|
25
29
|
* @class ValidationError
|
|
26
|
-
* @
|
|
30
|
+
* @example
|
|
31
|
+
* // Throw a validation error when data is invalid
|
|
32
|
+
* if (!isValid(data)) {
|
|
33
|
+
* throw new ValidationError('Invalid data format');
|
|
34
|
+
* }
|
|
27
35
|
*/
|
|
28
36
|
export class ValidationError extends BaseError {
|
|
29
37
|
constructor(msg) {
|
|
@@ -31,12 +39,18 @@ export class ValidationError extends BaseError {
|
|
|
31
39
|
}
|
|
32
40
|
}
|
|
33
41
|
/**
|
|
34
|
-
* @
|
|
35
|
-
*
|
|
36
|
-
* @param {string} msg
|
|
37
|
-
*
|
|
42
|
+
* @description Error thrown for internal system failures
|
|
43
|
+
* @summary Represents an internal failure (should mean an error in code) with HTTP 500 status code
|
|
44
|
+
* @param {string|Error} msg - The error message or Error object
|
|
45
|
+
* @return {InternalError} A new InternalError instance
|
|
38
46
|
* @class InternalError
|
|
39
|
-
* @
|
|
47
|
+
* @example
|
|
48
|
+
* // Throw an internal error when an unexpected condition occurs
|
|
49
|
+
* try {
|
|
50
|
+
* // Some operation
|
|
51
|
+
* } catch (error) {
|
|
52
|
+
* throw new InternalError('Unexpected internal error occurred');
|
|
53
|
+
* }
|
|
40
54
|
*/
|
|
41
55
|
export class InternalError extends BaseError {
|
|
42
56
|
constructor(msg) {
|
|
@@ -44,13 +58,18 @@ export class InternalError extends BaseError {
|
|
|
44
58
|
}
|
|
45
59
|
}
|
|
46
60
|
/**
|
|
47
|
-
* @
|
|
48
|
-
*
|
|
49
|
-
* @param {string} msg
|
|
50
|
-
*
|
|
61
|
+
* @description Error thrown when serialization or deserialization fails
|
|
62
|
+
* @summary Represents a failure in the Model de/serialization, typically when converting between data formats
|
|
63
|
+
* @param {string|Error} msg - The error message or Error object
|
|
64
|
+
* @return {SerializationError} A new SerializationError instance
|
|
51
65
|
* @class SerializationError
|
|
52
|
-
* @
|
|
53
|
-
*
|
|
66
|
+
* @example
|
|
67
|
+
* // Throw a serialization error when JSON parsing fails
|
|
68
|
+
* try {
|
|
69
|
+
* const data = JSON.parse(invalidJson);
|
|
70
|
+
* } catch (error) {
|
|
71
|
+
* throw new SerializationError('Failed to parse JSON data');
|
|
72
|
+
* }
|
|
54
73
|
*/
|
|
55
74
|
export class SerializationError extends BaseError {
|
|
56
75
|
constructor(msg) {
|
|
@@ -58,13 +77,17 @@ export class SerializationError extends BaseError {
|
|
|
58
77
|
}
|
|
59
78
|
}
|
|
60
79
|
/**
|
|
61
|
-
* @
|
|
62
|
-
*
|
|
63
|
-
* @param {string} msg
|
|
64
|
-
*
|
|
80
|
+
* @description Error thrown when a requested resource is not found
|
|
81
|
+
* @summary Represents a failure in finding a model, resulting in a 404 HTTP status code
|
|
82
|
+
* @param {string|Error} msg - The error message or Error object
|
|
83
|
+
* @return {NotFoundError} A new NotFoundError instance
|
|
65
84
|
* @class NotFoundError
|
|
66
|
-
* @
|
|
67
|
-
*
|
|
85
|
+
* @example
|
|
86
|
+
* // Throw a not found error when a record doesn't exist
|
|
87
|
+
* const user = await repository.findById(id);
|
|
88
|
+
* if (!user) {
|
|
89
|
+
* throw new NotFoundError(`User with ID ${id} not found`);
|
|
90
|
+
* }
|
|
68
91
|
*/
|
|
69
92
|
export class NotFoundError extends BaseError {
|
|
70
93
|
constructor(msg) {
|
|
@@ -72,17 +95,21 @@ export class NotFoundError extends BaseError {
|
|
|
72
95
|
}
|
|
73
96
|
}
|
|
74
97
|
/**
|
|
75
|
-
* @
|
|
76
|
-
*
|
|
77
|
-
* @param {string} msg
|
|
78
|
-
*
|
|
98
|
+
* @description Error thrown when a conflict occurs in the storage
|
|
99
|
+
* @summary Represents a conflict in the storage, typically when trying to create a duplicate resource
|
|
100
|
+
* @param {string|Error} msg - The error message or Error object
|
|
101
|
+
* @return {ConflictError} A new ConflictError instance
|
|
79
102
|
* @class ConflictError
|
|
80
|
-
* @
|
|
81
|
-
*
|
|
103
|
+
* @example
|
|
104
|
+
* // Throw a conflict error when trying to create a duplicate record
|
|
105
|
+
* const existingUser = await repository.findByEmail(email);
|
|
106
|
+
* if (existingUser) {
|
|
107
|
+
* throw new ConflictError(`User with email ${email} already exists`);
|
|
108
|
+
* }
|
|
82
109
|
*/
|
|
83
110
|
export class ConflictError extends BaseError {
|
|
84
111
|
constructor(msg) {
|
|
85
112
|
super(ConflictError.name, msg, 409);
|
|
86
113
|
}
|
|
87
114
|
}
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlcG9zaXRvcnkvZXJyb3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsTUFBTSxPQUFnQixTQUFVLFNBQVEsS0FBSztJQUUzQyxZQUFzQixJQUFZLEVBQUUsR0FBbUIsRUFBRSxPQUFlLEdBQUc7UUFDekUsSUFBSSxHQUFHLFlBQVksU0FBUztZQUFFLE9BQU8sR0FBRyxDQUFDO1FBQ3pDLE1BQU0sT0FBTyxHQUFHLElBQUksSUFBSSxLQUFLLEdBQUcsWUFBWSxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ3hFLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksR0FBRyxZQUFZLEtBQUs7WUFBRSxJQUFJLENBQUMsS0FBSyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUM7SUFDbkQsQ0FBQztDQUNGO0FBRUQ7Ozs7Ozs7Ozs7O0dBV0c7QUFDSCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxTQUFTO0lBQzVDLFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLENBQUM7Q0FDRjtBQUNEOzs7Ozs7Ozs7Ozs7O0dBYUc7QUFDSCxNQUFNLE9BQU8sYUFBYyxTQUFRLFNBQVM7SUFDMUMsWUFBWSxHQUFtQjtRQUM3QixLQUFLLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDdEMsQ0FBQztDQUNGO0FBQ0Q7Ozs7Ozs7Ozs7Ozs7R0FhRztBQUNILE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxTQUFTO0lBQy9DLFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLGtCQUFrQixDQUFDLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDM0MsQ0FBQztDQUNGO0FBRUQ7Ozs7Ozs7Ozs7OztHQVlHO0FBQ0gsTUFBTSxPQUFPLGFBQWMsU0FBUSxTQUFTO0lBQzFDLFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7Q0FDRjtBQUNEOzs7Ozs7Ozs7Ozs7R0FZRztBQUNILE1BQU0sT0FBTyxhQUFjLFNBQVEsU0FBUztJQUMxQyxZQUFZLEdBQW1CO1FBQzdCLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN0QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBCYXNlIGVycm9yIGNsYXNzIGZvciB0aGUgcmVwb3NpdG9yeSBtb2R1bGVcbiAqIEBzdW1tYXJ5IEFic3RyYWN0IGJhc2UgZXJyb3IgY2xhc3MgdGhhdCBhbGwgb3RoZXIgZXJyb3IgdHlwZXMgZXh0ZW5kIGZyb20uIFByb3ZpZGVzIGNvbW1vbiBlcnJvciBoYW5kbGluZyBmdW5jdGlvbmFsaXR5LlxuICogQHBhcmFtIHtzdHJpbmd9IG5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgZXJyb3JcbiAqIEBwYXJhbSB7c3RyaW5nfEVycm9yfSBtc2cgLSBUaGUgZXJyb3IgbWVzc2FnZSBvciBFcnJvciBvYmplY3RcbiAqIEBwYXJhbSB7bnVtYmVyfSBjb2RlIC0gVGhlIEhUVFAgc3RhdHVzIGNvZGUgYXNzb2NpYXRlZCB3aXRoIHRoaXMgZXJyb3JcbiAqIEBjbGFzcyBCYXNlRXJyb3JcbiAqIEBleGFtcGxlXG4gKiAvLyBUaGlzIGlzIGFuIGFic3RyYWN0IGNsYXNzIGFuZCBzaG91bGQgbm90IGJlIGluc3RhbnRpYXRlZCBkaXJlY3RseVxuICogLy8gSW5zdGVhZCwgdXNlIG9uZSBvZiB0aGUgY29uY3JldGUgZXJyb3IgY2xhc3NlczpcbiAqIHRocm93IG5ldyBWYWxpZGF0aW9uRXJyb3IoJ0ludmFsaWQgZGF0YSBwcm92aWRlZCcpO1xuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICByZWFkb25seSBjb2RlITogbnVtYmVyO1xuICBwcm90ZWN0ZWQgY29uc3RydWN0b3IobmFtZTogc3RyaW5nLCBtc2c6IHN0cmluZyB8IEVycm9yLCBjb2RlOiBudW1iZXIgPSA1MDApIHtcbiAgICBpZiAobXNnIGluc3RhbmNlb2YgQmFzZUVycm9yKSByZXR1cm4gbXNnO1xuICAgIGNvbnN0IG1lc3NhZ2UgPSBgWyR7bmFtZX1dICR7bXNnIGluc3RhbmNlb2YgRXJyb3IgPyBtc2cubWVzc2FnZSA6IG1zZ31gO1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMuY29kZSA9IGNvZGU7XG4gICAgaWYgKG1zZyBpbnN0YW5jZW9mIEVycm9yKSB0aGlzLnN0YWNrID0gbXNnLnN0YWNrO1xuICB9XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEVycm9yIHRocm93biB3aGVuIHZhbGlkYXRpb24gZmFpbHNcbiAqIEBzdW1tYXJ5IFJlcHJlc2VudHMgYSBmYWlsdXJlIGluIHRoZSBNb2RlbCBkZXRhaWxzLCB0eXBpY2FsbHkgdGhyb3duIHdoZW4gZGF0YSB2YWxpZGF0aW9uIGZhaWxzXG4gKiBAcGFyYW0ge3N0cmluZ3xFcnJvcn0gbXNnIC0gVGhlIGVycm9yIG1lc3NhZ2Ugb3IgRXJyb3Igb2JqZWN0XG4gKiBAcmV0dXJuIHtWYWxpZGF0aW9uRXJyb3J9IEEgbmV3IFZhbGlkYXRpb25FcnJvciBpbnN0YW5jZVxuICogQGNsYXNzIFZhbGlkYXRpb25FcnJvclxuICogQGV4YW1wbGVcbiAqIC8vIFRocm93IGEgdmFsaWRhdGlvbiBlcnJvciB3aGVuIGRhdGEgaXMgaW52YWxpZFxuICogaWYgKCFpc1ZhbGlkKGRhdGEpKSB7XG4gKiAgIHRocm93IG5ldyBWYWxpZGF0aW9uRXJyb3IoJ0ludmFsaWQgZGF0YSBmb3JtYXQnKTtcbiAqIH1cbiAqL1xuZXhwb3J0IGNsYXNzIFZhbGlkYXRpb25FcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihWYWxpZGF0aW9uRXJyb3IubmFtZSwgbXNnLCA0MjIpO1xuICB9XG59XG4vKipcbiAqIEBkZXNjcmlwdGlvbiBFcnJvciB0aHJvd24gZm9yIGludGVybmFsIHN5c3RlbSBmYWlsdXJlc1xuICogQHN1bW1hcnkgUmVwcmVzZW50cyBhbiBpbnRlcm5hbCBmYWlsdXJlIChzaG91bGQgbWVhbiBhbiBlcnJvciBpbiBjb2RlKSB3aXRoIEhUVFAgNTAwIHN0YXR1cyBjb2RlXG4gKiBAcGFyYW0ge3N0cmluZ3xFcnJvcn0gbXNnIC0gVGhlIGVycm9yIG1lc3NhZ2Ugb3IgRXJyb3Igb2JqZWN0XG4gKiBAcmV0dXJuIHtJbnRlcm5hbEVycm9yfSBBIG5ldyBJbnRlcm5hbEVycm9yIGluc3RhbmNlXG4gKiBAY2xhc3MgSW50ZXJuYWxFcnJvclxuICogQGV4YW1wbGVcbiAqIC8vIFRocm93IGFuIGludGVybmFsIGVycm9yIHdoZW4gYW4gdW5leHBlY3RlZCBjb25kaXRpb24gb2NjdXJzXG4gKiB0cnkge1xuICogICAvLyBTb21lIG9wZXJhdGlvblxuICogfSBjYXRjaCAoZXJyb3IpIHtcbiAqICAgdGhyb3cgbmV3IEludGVybmFsRXJyb3IoJ1VuZXhwZWN0ZWQgaW50ZXJuYWwgZXJyb3Igb2NjdXJyZWQnKTtcbiAqIH1cbiAqL1xuZXhwb3J0IGNsYXNzIEludGVybmFsRXJyb3IgZXh0ZW5kcyBCYXNlRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihtc2c6IHN0cmluZyB8IEVycm9yKSB7XG4gICAgc3VwZXIoSW50ZXJuYWxFcnJvci5uYW1lLCBtc2csIDUwMCk7XG4gIH1cbn1cbi8qKlxuICogQGRlc2NyaXB0aW9uIEVycm9yIHRocm93biB3aGVuIHNlcmlhbGl6YXRpb24gb3IgZGVzZXJpYWxpemF0aW9uIGZhaWxzXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIGEgZmFpbHVyZSBpbiB0aGUgTW9kZWwgZGUvc2VyaWFsaXphdGlvbiwgdHlwaWNhbGx5IHdoZW4gY29udmVydGluZyBiZXR3ZWVuIGRhdGEgZm9ybWF0c1xuICogQHBhcmFtIHtzdHJpbmd8RXJyb3J9IG1zZyAtIFRoZSBlcnJvciBtZXNzYWdlIG9yIEVycm9yIG9iamVjdFxuICogQHJldHVybiB7U2VyaWFsaXphdGlvbkVycm9yfSBBIG5ldyBTZXJpYWxpemF0aW9uRXJyb3IgaW5zdGFuY2VcbiAqIEBjbGFzcyBTZXJpYWxpemF0aW9uRXJyb3JcbiAqIEBleGFtcGxlXG4gKiAvLyBUaHJvdyBhIHNlcmlhbGl6YXRpb24gZXJyb3Igd2hlbiBKU09OIHBhcnNpbmcgZmFpbHNcbiAqIHRyeSB7XG4gKiAgIGNvbnN0IGRhdGEgPSBKU09OLnBhcnNlKGludmFsaWRKc29uKTtcbiAqIH0gY2F0Y2ggKGVycm9yKSB7XG4gKiAgIHRocm93IG5ldyBTZXJpYWxpemF0aW9uRXJyb3IoJ0ZhaWxlZCB0byBwYXJzZSBKU09OIGRhdGEnKTtcbiAqIH1cbiAqL1xuZXhwb3J0IGNsYXNzIFNlcmlhbGl6YXRpb25FcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihTZXJpYWxpemF0aW9uRXJyb3IubmFtZSwgbXNnLCA0MjIpO1xuICB9XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEVycm9yIHRocm93biB3aGVuIGEgcmVxdWVzdGVkIHJlc291cmNlIGlzIG5vdCBmb3VuZFxuICogQHN1bW1hcnkgUmVwcmVzZW50cyBhIGZhaWx1cmUgaW4gZmluZGluZyBhIG1vZGVsLCByZXN1bHRpbmcgaW4gYSA0MDQgSFRUUCBzdGF0dXMgY29kZVxuICogQHBhcmFtIHtzdHJpbmd8RXJyb3J9IG1zZyAtIFRoZSBlcnJvciBtZXNzYWdlIG9yIEVycm9yIG9iamVjdFxuICogQHJldHVybiB7Tm90Rm91bmRFcnJvcn0gQSBuZXcgTm90Rm91bmRFcnJvciBpbnN0YW5jZVxuICogQGNsYXNzIE5vdEZvdW5kRXJyb3JcbiAqIEBleGFtcGxlXG4gKiAvLyBUaHJvdyBhIG5vdCBmb3VuZCBlcnJvciB3aGVuIGEgcmVjb3JkIGRvZXNuJ3QgZXhpc3RcbiAqIGNvbnN0IHVzZXIgPSBhd2FpdCByZXBvc2l0b3J5LmZpbmRCeUlkKGlkKTtcbiAqIGlmICghdXNlcikge1xuICogICB0aHJvdyBuZXcgTm90Rm91bmRFcnJvcihgVXNlciB3aXRoIElEICR7aWR9IG5vdCBmb3VuZGApO1xuICogfVxuICovXG5leHBvcnQgY2xhc3MgTm90Rm91bmRFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihOb3RGb3VuZEVycm9yLm5hbWUsIG1zZywgNDA0KTtcbiAgfVxufVxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRXJyb3IgdGhyb3duIHdoZW4gYSBjb25mbGljdCBvY2N1cnMgaW4gdGhlIHN0b3JhZ2VcbiAqIEBzdW1tYXJ5IFJlcHJlc2VudHMgYSBjb25mbGljdCBpbiB0aGUgc3RvcmFnZSwgdHlwaWNhbGx5IHdoZW4gdHJ5aW5nIHRvIGNyZWF0ZSBhIGR1cGxpY2F0ZSByZXNvdXJjZVxuICogQHBhcmFtIHtzdHJpbmd8RXJyb3J9IG1zZyAtIFRoZSBlcnJvciBtZXNzYWdlIG9yIEVycm9yIG9iamVjdFxuICogQHJldHVybiB7Q29uZmxpY3RFcnJvcn0gQSBuZXcgQ29uZmxpY3RFcnJvciBpbnN0YW5jZVxuICogQGNsYXNzIENvbmZsaWN0RXJyb3JcbiAqIEBleGFtcGxlXG4gKiAvLyBUaHJvdyBhIGNvbmZsaWN0IGVycm9yIHdoZW4gdHJ5aW5nIHRvIGNyZWF0ZSBhIGR1cGxpY2F0ZSByZWNvcmRcbiAqIGNvbnN0IGV4aXN0aW5nVXNlciA9IGF3YWl0IHJlcG9zaXRvcnkuZmluZEJ5RW1haWwoZW1haWwpO1xuICogaWYgKGV4aXN0aW5nVXNlcikge1xuICogICB0aHJvdyBuZXcgQ29uZmxpY3RFcnJvcihgVXNlciB3aXRoIGVtYWlsICR7ZW1haWx9IGFscmVhZHkgZXhpc3RzYCk7XG4gKiB9XG4gKi9cbmV4cG9ydCBjbGFzcyBDb25mbGljdEVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcbiAgY29uc3RydWN0b3IobXNnOiBzdHJpbmcgfCBFcnJvcikge1xuICAgIHN1cGVyKENvbmZsaWN0RXJyb3IubmFtZSwgbXNnLCA0MDkpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
export * from "./BaseRepository";
|
|
2
|
-
export * from "./constants";
|
|
3
|
-
export * from "./Context";
|
|
4
|
-
export * from "./errors";
|
|
5
|
-
export * from "./Repository";
|
|
6
|
-
export * from "./types";
|
|
7
|
-
export * from "./utils";
|
|
8
|
-
export * from "./wrappers";
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export * from "./BaseRepository.js";
|
|
2
|
+
export * from "./constants.js";
|
|
3
|
+
export * from "./Context.js";
|
|
4
|
+
export * from "./errors.js";
|
|
5
|
+
export * from "./Repository.js";
|
|
6
|
+
export * from "./types.js";
|
|
7
|
+
export * from "./utils.js";
|
|
8
|
+
export * from "./wrappers.js";
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVwb3NpdG9yeS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxvQ0FBaUM7QUFDakMsK0JBQTRCO0FBQzVCLDZCQUEwQjtBQUMxQiw0QkFBeUI7QUFDekIsZ0NBQTZCO0FBQzdCLDJCQUF3QjtBQUN4QiwyQkFBd0I7QUFDeEIsOEJBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vQmFzZVJlcG9zaXRvcnlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbnN0YW50c1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vQ29udGV4dFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXJyb3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9SZXBvc2l0b3J5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi90eXBlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXRpbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3dyYXBwZXJzXCI7XG4iXX0=
|
|
@@ -1,7 +1,32 @@
|
|
|
1
1
|
import { Context } from "./Context";
|
|
2
2
|
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
|
3
3
|
import { OperationKeys } from "../operations";
|
|
4
|
+
/**
|
|
5
|
+
* @description Type utility for ensuring model extension.
|
|
6
|
+
* @summary A conditional type that ensures a type extends the Model class.
|
|
7
|
+
* If the type extends Model, it returns the type; otherwise, it returns never.
|
|
8
|
+
* @template M - The type to check, defaults to Model
|
|
9
|
+
* @typedef {M extends Model ? M : never} ModelExtension
|
|
10
|
+
* @memberOf module:db-decorators
|
|
11
|
+
*/
|
|
4
12
|
type ModelExtension<M extends Model = Model> = M extends Model ? M : never;
|
|
13
|
+
/**
|
|
14
|
+
* @description Configuration flags for repository operations.
|
|
15
|
+
* @summary Defines the configuration options that control repository behavior during operations.
|
|
16
|
+
* These flags manage context relationships, validation behavior, operation metadata, and error handling.
|
|
17
|
+
* @typedef {Object} RepositoryFlags
|
|
18
|
+
* @property {Context} [parentContext] - The parent context for hierarchical operations
|
|
19
|
+
* @property {Context[]} [childContexts] - Child contexts spawned from this context
|
|
20
|
+
* @property {any[]} [callArgs] - Arguments passed to the operation
|
|
21
|
+
* @property {string[]} ignoredValidationProperties - Properties to exclude from validation
|
|
22
|
+
* @property affectedTables - Tables or models affected by the operation
|
|
23
|
+
* @property {boolean} writeOperation - Whether the operation modifies data
|
|
24
|
+
* @property {Date} timestamp - When the operation was initiated
|
|
25
|
+
* @property {OperationKeys} [operation] - The type of operation being performed
|
|
26
|
+
* @property {boolean} breakOnHandlerError - Whether to stop processing on handler errors
|
|
27
|
+
* @property {boolean} rebuildWithTransient - Whether to include transient properties when rebuilding models
|
|
28
|
+
* @memberOf module:db-decorators
|
|
29
|
+
*/
|
|
5
30
|
export type RepositoryFlags = {
|
|
6
31
|
parentContext?: Context<any>;
|
|
7
32
|
childContexts?: Context<any>[];
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVwb3NpdG9yeS90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29udGV4dCB9IGZyb20gXCIuL0NvbnRleHRcIjtcbmltcG9ydCB7IENvbnN0cnVjdG9yLCBNb2RlbCB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcbmltcG9ydCB7IE9wZXJhdGlvbktleXMgfSBmcm9tIFwiLi4vb3BlcmF0aW9uc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBUeXBlIHV0aWxpdHkgZm9yIGVuc3VyaW5nIG1vZGVsIGV4dGVuc2lvbi5cbiAqIEBzdW1tYXJ5IEEgY29uZGl0aW9uYWwgdHlwZSB0aGF0IGVuc3VyZXMgYSB0eXBlIGV4dGVuZHMgdGhlIE1vZGVsIGNsYXNzLlxuICogSWYgdGhlIHR5cGUgZXh0ZW5kcyBNb2RlbCwgaXQgcmV0dXJucyB0aGUgdHlwZTsgb3RoZXJ3aXNlLCBpdCByZXR1cm5zIG5ldmVyLlxuICogQHRlbXBsYXRlIE0gLSBUaGUgdHlwZSB0byBjaGVjaywgZGVmYXVsdHMgdG8gTW9kZWxcbiAqIEB0eXBlZGVmIHtNIGV4dGVuZHMgTW9kZWwgPyBNIDogbmV2ZXJ9IE1vZGVsRXh0ZW5zaW9uXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnNcbiAqL1xudHlwZSBNb2RlbEV4dGVuc2lvbjxNIGV4dGVuZHMgTW9kZWwgPSBNb2RlbD4gPSBNIGV4dGVuZHMgTW9kZWwgPyBNIDogbmV2ZXI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIENvbmZpZ3VyYXRpb24gZmxhZ3MgZm9yIHJlcG9zaXRvcnkgb3BlcmF0aW9ucy5cbiAqIEBzdW1tYXJ5IERlZmluZXMgdGhlIGNvbmZpZ3VyYXRpb24gb3B0aW9ucyB0aGF0IGNvbnRyb2wgcmVwb3NpdG9yeSBiZWhhdmlvciBkdXJpbmcgb3BlcmF0aW9ucy5cbiAqIFRoZXNlIGZsYWdzIG1hbmFnZSBjb250ZXh0IHJlbGF0aW9uc2hpcHMsIHZhbGlkYXRpb24gYmVoYXZpb3IsIG9wZXJhdGlvbiBtZXRhZGF0YSwgYW5kIGVycm9yIGhhbmRsaW5nLlxuICogQHR5cGVkZWYge09iamVjdH0gUmVwb3NpdG9yeUZsYWdzXG4gKiBAcHJvcGVydHkge0NvbnRleHR9IFtwYXJlbnRDb250ZXh0XSAtIFRoZSBwYXJlbnQgY29udGV4dCBmb3IgaGllcmFyY2hpY2FsIG9wZXJhdGlvbnNcbiAqIEBwcm9wZXJ0eSB7Q29udGV4dFtdfSBbY2hpbGRDb250ZXh0c10gLSBDaGlsZCBjb250ZXh0cyBzcGF3bmVkIGZyb20gdGhpcyBjb250ZXh0XG4gKiBAcHJvcGVydHkge2FueVtdfSBbY2FsbEFyZ3NdIC0gQXJndW1lbnRzIHBhc3NlZCB0byB0aGUgb3BlcmF0aW9uXG4gKiBAcHJvcGVydHkge3N0cmluZ1tdfSBpZ25vcmVkVmFsaWRhdGlvblByb3BlcnRpZXMgLSBQcm9wZXJ0aWVzIHRvIGV4Y2x1ZGUgZnJvbSB2YWxpZGF0aW9uXG4gKiBAcHJvcGVydHkgYWZmZWN0ZWRUYWJsZXMgLSBUYWJsZXMgb3IgbW9kZWxzIGFmZmVjdGVkIGJ5IHRoZSBvcGVyYXRpb25cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gd3JpdGVPcGVyYXRpb24gLSBXaGV0aGVyIHRoZSBvcGVyYXRpb24gbW9kaWZpZXMgZGF0YVxuICogQHByb3BlcnR5IHtEYXRlfSB0aW1lc3RhbXAgLSBXaGVuIHRoZSBvcGVyYXRpb24gd2FzIGluaXRpYXRlZFxuICogQHByb3BlcnR5IHtPcGVyYXRpb25LZXlzfSBbb3BlcmF0aW9uXSAtIFRoZSB0eXBlIG9mIG9wZXJhdGlvbiBiZWluZyBwZXJmb3JtZWRcbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gYnJlYWtPbkhhbmRsZXJFcnJvciAtIFdoZXRoZXIgdG8gc3RvcCBwcm9jZXNzaW5nIG9uIGhhbmRsZXIgZXJyb3JzXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IHJlYnVpbGRXaXRoVHJhbnNpZW50IC0gV2hldGhlciB0byBpbmNsdWRlIHRyYW5zaWVudCBwcm9wZXJ0aWVzIHdoZW4gcmVidWlsZGluZyBtb2RlbHNcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGItZGVjb3JhdG9yc1xuICovXG5leHBvcnQgdHlwZSBSZXBvc2l0b3J5RmxhZ3MgPSB7XG4gIHBhcmVudENvbnRleHQ/OiBDb250ZXh0PGFueT47XG4gIGNoaWxkQ29udGV4dHM/OiBDb250ZXh0PGFueT5bXTtcbiAgY2FsbEFyZ3M/OiBhbnlbXTtcbiAgaWdub3JlZFZhbGlkYXRpb25Qcm9wZXJ0aWVzOiBzdHJpbmdbXTtcbiAgYWZmZWN0ZWRUYWJsZXM6XG4gICAgfCAoc3RyaW5nIHwgQ29uc3RydWN0b3I8TW9kZWxFeHRlbnNpb24+KVtdXG4gICAgfCBzdHJpbmdcbiAgICB8IENvbnN0cnVjdG9yPE1vZGVsRXh0ZW5zaW9uPjtcbiAgd3JpdGVPcGVyYXRpb246IGJvb2xlYW47XG4gIHRpbWVzdGFtcDogRGF0ZTtcbiAgb3BlcmF0aW9uPzogT3BlcmF0aW9uS2V5cztcbiAgYnJlYWtPbkhhbmRsZXJFcnJvcjogYm9vbGVhbjtcbiAgcmVidWlsZFdpdGhUcmFuc2llbnQ6IGJvb2xlYW47XG59O1xuIl19
|
|
@@ -3,6 +3,17 @@ import { DecoratorMetadata } from "@decaf-ts/reflection";
|
|
|
3
3
|
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
|
4
4
|
import { Context } from "./Context";
|
|
5
5
|
import { RepositoryFlags } from "./types";
|
|
6
|
+
/**
|
|
7
|
+
* @description Context arguments for repository operations.
|
|
8
|
+
* @summary Represents the context and arguments for repository operations.
|
|
9
|
+
* This type is used to pass context and arguments between repository methods.
|
|
10
|
+
* @template F - The repository flags type, defaults to RepositoryFlags
|
|
11
|
+
* @template C - The context type, defaults to Context<F>
|
|
12
|
+
* @typedef {Object} ContextArgs
|
|
13
|
+
* @property {C} context - The operation context
|
|
14
|
+
* @property {any[]} args - The operation arguments
|
|
15
|
+
* @memberOf module:db-decorators
|
|
16
|
+
*/
|
|
6
17
|
export type ContextArgs<F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> = {
|
|
7
18
|
context: C;
|
|
8
19
|
args: any[];
|