@decaf-ts/core 0.5.21 → 0.5.23
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/README.md +251 -603
- package/dist/core.cjs +433 -225
- package/dist/core.esm.cjs +434 -226
- package/lib/esm/identity/decorators.js +1 -1
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.js +3 -3
- package/lib/esm/model/types.d.ts +0 -9
- package/lib/esm/model/types.js +1 -1
- package/lib/esm/persistence/Adapter.d.ts +61 -51
- package/lib/esm/persistence/Adapter.js +120 -47
- package/lib/esm/persistence/Dispatch.d.ts +2 -13
- package/lib/esm/persistence/Dispatch.js +7 -15
- package/lib/esm/persistence/errors.d.ts +2 -2
- package/lib/esm/persistence/errors.js +4 -4
- package/lib/esm/persistence/types.d.ts +2 -0
- package/lib/esm/persistence/types.js +1 -1
- package/lib/esm/query/Condition.d.ts +8 -0
- package/lib/esm/query/Condition.js +9 -1
- package/lib/esm/query/Paginator.d.ts +2 -2
- package/lib/esm/query/Paginator.js +1 -1
- package/lib/esm/query/Statement.d.ts +4 -3
- package/lib/esm/query/Statement.js +4 -2
- package/lib/esm/query/errors.d.ts +3 -3
- package/lib/esm/query/errors.js +6 -6
- package/lib/esm/ram/RamAdapter.d.ts +8 -14
- package/lib/esm/ram/RamAdapter.js +44 -33
- package/lib/esm/ram/RamContext.d.ts +14 -6
- package/lib/esm/ram/RamContext.js +15 -7
- package/lib/esm/ram/constants.d.ts +1 -2
- package/lib/esm/ram/constants.js +2 -3
- package/lib/esm/ram/types.d.ts +3 -0
- package/lib/esm/ram/types.js +1 -1
- package/lib/esm/repository/Repository.d.ts +8 -7
- package/lib/esm/repository/Repository.js +8 -8
- package/lib/esm/repository/constants.d.ts +5 -4
- package/lib/esm/repository/constants.js +6 -5
- package/lib/esm/repository/decorators.js +2 -1
- package/lib/esm/repository/errors.d.ts +2 -2
- package/lib/esm/repository/errors.js +4 -4
- package/lib/esm/repository/injectables.d.ts +82 -11
- package/lib/esm/repository/injectables.js +137 -28
- package/lib/esm/repository/utils.d.ts +28 -6
- package/lib/esm/repository/utils.js +29 -7
- package/lib/esm/utils/errors.d.ts +5 -5
- package/lib/esm/utils/errors.js +9 -9
- package/lib/identity/decorators.cjs +1 -1
- package/lib/index.cjs +4 -4
- package/lib/index.d.ts +1 -1
- package/lib/model/types.cjs +1 -1
- package/lib/model/types.d.ts +0 -9
- package/lib/persistence/Adapter.cjs +119 -46
- package/lib/persistence/Adapter.d.ts +61 -51
- package/lib/persistence/Dispatch.cjs +6 -14
- package/lib/persistence/Dispatch.d.ts +2 -13
- package/lib/persistence/errors.cjs +3 -3
- package/lib/persistence/errors.d.ts +2 -2
- package/lib/persistence/types.cjs +1 -1
- package/lib/persistence/types.d.ts +2 -0
- package/lib/query/Condition.cjs +9 -1
- package/lib/query/Condition.d.ts +8 -0
- package/lib/query/Paginator.cjs +1 -1
- package/lib/query/Paginator.d.ts +2 -2
- package/lib/query/Statement.cjs +4 -2
- package/lib/query/Statement.d.ts +4 -3
- package/lib/query/errors.cjs +5 -5
- package/lib/query/errors.d.ts +3 -3
- package/lib/ram/RamAdapter.cjs +43 -32
- package/lib/ram/RamAdapter.d.ts +8 -14
- package/lib/ram/RamContext.cjs +15 -7
- package/lib/ram/RamContext.d.ts +14 -6
- package/lib/ram/constants.cjs +2 -3
- package/lib/ram/constants.d.ts +1 -2
- package/lib/ram/types.cjs +1 -1
- package/lib/ram/types.d.ts +3 -0
- package/lib/repository/Repository.cjs +8 -8
- package/lib/repository/Repository.d.ts +8 -7
- package/lib/repository/constants.cjs +6 -5
- package/lib/repository/constants.d.ts +5 -4
- package/lib/repository/decorators.cjs +2 -1
- package/lib/repository/errors.cjs +3 -3
- package/lib/repository/errors.d.ts +2 -2
- package/lib/repository/injectables.cjs +137 -28
- package/lib/repository/injectables.d.ts +82 -11
- package/lib/repository/utils.cjs +29 -7
- package/lib/repository/utils.d.ts +28 -6
- package/lib/utils/errors.cjs +8 -8
- package/lib/utils/errors.d.ts +5 -5
- package/package.json +1 -1
@@ -105,4 +105,4 @@ export function pk(opts = DefaultSequenceOptions) {
|
|
105
105
|
})
|
106
106
|
.apply();
|
107
107
|
}
|
108
|
-
//# sourceMappingURL=data:application/json;base64,
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/identity/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Decoration,\n  Model,\n  propMetadata,\n  required,\n} from \"@decaf-ts/decorator-validation\";\nimport {\n  DefaultSequenceOptions,\n  SequenceOptions,\n} from \"../interfaces/SequenceOptions\";\nimport {\n  DBKeys,\n  InternalError,\n  onCreate,\n  readonly,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport { Repo, Repository } from \"../repository/Repository\";\nimport { index } from \"../model/decorators\";\nimport { sequenceNameForModel } from \"./utils\";\nimport { Sequence } from \"../persistence/Sequence\";\nimport { Context } from \"@decaf-ts/db-decorators\";\nimport { OrderDirection } from \"../repository\";\nimport { apply } from \"@decaf-ts/reflection\";\n\n/**\n * @description Callback function for primary key creation\n * @summary Handles the creation of primary key values for models using sequences\n * @template M - Type that extends Model\n * @template R - Type that extends Repo<M, F, C>\n * @template V - Type that extends SequenceOptions\n * @template F - Type that extends RepositoryFlags\n * @template C - Type that extends Context<F>\n * @param {Context<F>} context - The execution context\n * @param {V} data - The sequence options\n * @param key - The property key to set as primary key\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the primary key is set\n * @function pkOnCreate\n * @category Property Decorators\n * @mermaid\n * sequenceDiagram\n *   participant Model\n *   participant pkOnCreate\n *   participant Adapter\n *   participant Sequence\n *\n *   Model->>pkOnCreate: Call with model instance\n *   Note over pkOnCreate: Check if key already exists\n *   alt Key exists or no type specified\n *     pkOnCreate-->>Model: Return early\n *   else Key needs to be created\n *     pkOnCreate->>pkOnCreate: Generate sequence name if not provided\n *     pkOnCreate->>Adapter: Request Sequence(data)\n *     Adapter->>Sequence: Create sequence\n *     Sequence-->>pkOnCreate: Return sequence\n *     pkOnCreate->>Sequence: Call next()\n *     Sequence-->>pkOnCreate: Return next value\n *     pkOnCreate->>Model: Set primary key value\n *   end\n */\nexport async function pkOnCreate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends SequenceOptions,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  this: R,\n  context: Context<F>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  if (!data.type || !data.generated || model[key]) {\n    return;\n  }\n\n  const setPrimaryKeyValue = function <M extends Model>(\n    target: M,\n    propertyKey: string,\n    value: string | number | bigint\n  ) {\n    Object.defineProperty(target, propertyKey, {\n      enumerable: true,\n      writable: false,\n      configurable: true,\n      value: value,\n    });\n  };\n\n  if (!data.name) data.name = sequenceNameForModel(model, \"pk\");\n  let sequence: Sequence;\n  try {\n    sequence = await this.adapter.Sequence(data);\n  } catch (e: any) {\n    throw new InternalError(\n      `Failed to instantiate Sequence ${data.name}: ${e}`\n    );\n  }\n\n  const next = await sequence.next();\n  setPrimaryKeyValue(model, key as string, next);\n}\n\n/**\n * @description Primary Key Decorator\n * @summary Marks a property as the model's primary key with automatic sequence generation\n * This decorator combines multiple behaviors: it marks the property as unique, required,\n * and ensures the index is created properly according to the provided sequence options.\n * @param {Omit<SequenceOptions, \"cycle\" | \"startWith\" | \"incrementBy\">} opts - Options for the sequence generation\n * @return {PropertyDecorator} A property decorator that can be applied to model properties\n * @function pk\n * @category Property Decorators\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @pk()\n *   id!: string;\n *\n *   @required()\n *   username!: string;\n * }\n * ```\n */\nexport function pk(\n  opts: Omit<\n    SequenceOptions,\n    \"cycle\" | \"startWith\" | \"incrementBy\"\n  > = DefaultSequenceOptions\n) {\n  opts = Object.assign({}, DefaultSequenceOptions, opts, {\n    generated:\n      opts.type && typeof opts.generated === \"undefined\"\n        ? true\n        : opts.generated || DefaultSequenceOptions.generated,\n  }) as SequenceOptions;\n\n  const key = Repository.key(DBKeys.ID);\n  function pkDec(options: SequenceOptions) {\n    return function pkDec(obj: any, attr: any) {\n      return apply(\n        index([OrderDirection.ASC, OrderDirection.DSC]),\n        required(),\n        readonly(),\n        propMetadata(key, options),\n        onCreate(pkOnCreate, options),\n        propMetadata(DBKeys.ID, attr)\n      )(obj, attr);\n    };\n  }\n  return Decoration.for(key)\n    .define({\n      decorator: pkDec,\n      args: [opts],\n    })\n    .apply();\n}\n"]}
|
package/lib/esm/index.d.ts
CHANGED
package/lib/esm/index.js
CHANGED
@@ -5,7 +5,7 @@
|
|
5
5
|
* model definitions, repository patterns, persistence layer, query building, and utility functions.
|
6
6
|
* It exports functionality from various submodules and sets up the injectable registry for repository decorators.
|
7
7
|
*/
|
8
|
-
import { InjectablesRegistry } from "./repository/
|
8
|
+
import { InjectablesRegistry } from "./repository/injectables.js";
|
9
9
|
import { Injectables } from "@decaf-ts/injectable-decorators";
|
10
10
|
// overrides the previous Injectables registry to enable the @repository decorator
|
11
11
|
Injectables.setRegistry(new InjectablesRegistry());
|
@@ -23,5 +23,5 @@ export * from "./persistence/index.js";
|
|
23
23
|
* @const VERSION
|
24
24
|
* @memberOf module:core
|
25
25
|
*/
|
26
|
-
export const VERSION = "0.5.
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
26
|
+
export const VERSION = "0.5.23";
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFFLG1CQUFtQixFQUFFLG9DQUFpQztBQUMvRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFOUQsa0ZBQWtGO0FBQ2xGLFdBQVcsQ0FBQyxXQUFXLENBQUMsSUFBSSxtQkFBbUIsRUFBRSxDQUFDLENBQUM7QUFFbkQsb0NBQTJCO0FBQzNCLHNDQUE2QjtBQUM3QixpQ0FBd0I7QUFDeEIsaUNBQXdCO0FBQ3hCLHNDQUE2QjtBQUM3QixpQ0FBd0I7QUFDeEIseUJBQXlCO0FBQ3pCLHVDQUE4QjtBQUU5Qjs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBtb2R1bGUgY29yZVxuICogQGRlc2NyaXB0aW9uIENvcmUgbW9kdWxlIGZvciB0aGUgRGVjYWYgVHlwZVNjcmlwdCBmcmFtZXdvcmtcbiAqIEBzdW1tYXJ5IFRoaXMgbW9kdWxlIHByb3ZpZGVzIHRoZSBmb3VuZGF0aW9uYWwgY29tcG9uZW50cyBvZiB0aGUgRGVjYWYgZnJhbWV3b3JrLCBpbmNsdWRpbmcgaWRlbnRpdHkgbWFuYWdlbWVudCxcbiAqIG1vZGVsIGRlZmluaXRpb25zLCByZXBvc2l0b3J5IHBhdHRlcm5zLCBwZXJzaXN0ZW5jZSBsYXllciwgcXVlcnkgYnVpbGRpbmcsIGFuZCB1dGlsaXR5IGZ1bmN0aW9ucy5cbiAqIEl0IGV4cG9ydHMgZnVuY3Rpb25hbGl0eSBmcm9tIHZhcmlvdXMgc3VibW9kdWxlcyBhbmQgc2V0cyB1cCB0aGUgaW5qZWN0YWJsZSByZWdpc3RyeSBmb3IgcmVwb3NpdG9yeSBkZWNvcmF0b3JzLlxuICovXG5cbmltcG9ydCB7IEluamVjdGFibGVzUmVnaXN0cnkgfSBmcm9tIFwiLi9yZXBvc2l0b3J5L2luamVjdGFibGVzXCI7XG5pbXBvcnQgeyBJbmplY3RhYmxlcyB9IGZyb20gXCJAZGVjYWYtdHMvaW5qZWN0YWJsZS1kZWNvcmF0b3JzXCI7XG5cbi8vIG92ZXJyaWRlcyB0aGUgcHJldmlvdXMgSW5qZWN0YWJsZXMgcmVnaXN0cnkgdG8gZW5hYmxlIHRoZSBAcmVwb3NpdG9yeSBkZWNvcmF0b3JcbkluamVjdGFibGVzLnNldFJlZ2lzdHJ5KG5ldyBJbmplY3RhYmxlc1JlZ2lzdHJ5KCkpO1xuXG5leHBvcnQgKiBmcm9tIFwiLi9pZGVudGl0eVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaW50ZXJmYWNlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vbW9kZWxcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3F1ZXJ5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9yZXBvc2l0b3J5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsc1wiO1xuLy9sZWZ0IHRvIGxhc3Qgb24gcHVycG9zZVxuZXhwb3J0ICogZnJvbSBcIi4vcGVyc2lzdGVuY2VcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gU3RvcmVzIHRoZSBjdXJyZW50IHBhY2thZ2UgdmVyc2lvblxuICogQHN1bW1hcnkgQSBjb25zdGFudCByZXByZXNlbnRpbmcgdGhlIHZlcnNpb24gb2YgdGhlIGNvcmUgcGFja2FnZVxuICogQGNvbnN0IFZFUlNJT05cbiAqIEBtZW1iZXJPZiBtb2R1bGU6Y29yZVxuICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiIyNWRVJTSU9OIyNcIjtcbiJdfQ==
|
package/lib/esm/model/types.d.ts
CHANGED
@@ -47,15 +47,6 @@ export type JoinTableMultipleColumnsOptions = {
|
|
47
47
|
*/
|
48
48
|
inverseJoinColumns?: JoinColumnOptions[];
|
49
49
|
};
|
50
|
-
/**
|
51
|
-
* @description Metadata for model relationships
|
52
|
-
* @summary Type definition for storing metadata about relationships between models
|
53
|
-
* @property {string} class - The name of the related model class
|
54
|
-
* @property {CascadeMetadata} cascade - Configuration for cascade operations (create, update, delete)
|
55
|
-
* @property {boolean} populate - Whether to automatically populate the relationship when retrieving the model
|
56
|
-
* @typedef {Object} RelationsMetadata
|
57
|
-
* @memberOf module:model
|
58
|
-
*/
|
59
50
|
export type RelationsMetadata = {
|
60
51
|
class: string | (() => Constructor<any>);
|
61
52
|
cascade: CascadeMetadata;
|
package/lib/esm/model/types.js
CHANGED
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWwvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENhc2NhZGVNZXRhZGF0YSB9IGZyb20gXCIuLi9yZXBvc2l0b3J5XCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3RvciB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcblxuLyoqXG4gKiBEZXNjcmliZXMgam9pbiBjb2x1bW4gb3B0aW9ucy5cbiAqL1xuZXhwb3J0IHR5cGUgSm9pbkNvbHVtbk9wdGlvbnMgPSB7XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSBjb2x1bW4uXG4gICAqL1xuICBuYW1lPzogc3RyaW5nO1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgY29sdW1uIGluIHRoZSBlbnRpdHkgdG8gd2hpY2ggdGhpcyBjb2x1bW4gaXMgcmVmZXJlbmNlZC5cbiAgICovXG4gIHJlZmVyZW5jZWRDb2x1bW5OYW1lPzogc3RyaW5nO1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgZm9yZWlnbiBrZXkgY29uc3RyYWludC5cbiAgICovXG4gIGZvcmVpZ25LZXlDb25zdHJhaW50TmFtZT86IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEpvaW5UYWJsZU9wdGlvbnMgPSB7XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSB0YWJsZSB0aGF0IHdpbGwgYmUgY3JlYXRlZCB0byBzdG9yZSB2YWx1ZXMgb2YgdGhlIGJvdGggdGFibGVzIChqb2luIHRhYmxlKS5cbiAgICogQnkgZGVmYXVsdCBpcyBhdXRvIGdlbmVyYXRlZC5cbiAgICovXG4gIG5hbWU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBGaXJzdCBjb2x1bW4gb2YgdGhlIGpvaW4gdGFibGUuXG4gICAqL1xuICBqb2luQ29sdW1uPzogSm9pbkNvbHVtbk9wdGlvbnM7XG4gIC8qKlxuICAgKiBTZWNvbmQgKGludmVyc2UpIGNvbHVtbiBvZiB0aGUgam9pbiB0YWJsZS5cbiAgICovXG4gIGludmVyc2VKb2luQ29sdW1uPzogSm9pbkNvbHVtbk9wdGlvbnM7XG59O1xuXG5leHBvcnQgdHlwZSBKb2luVGFibGVNdWx0aXBsZUNvbHVtbnNPcHRpb25zID0ge1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgdGFibGUgdGhhdCB3aWxsIGJlIGNyZWF0ZWQgdG8gc3RvcmUgdmFsdWVzIG9mIHRoZSBib3RoIHRhYmxlcyAoam9pbiB0YWJsZSkuXG4gICAqIEJ5IGRlZmF1bHQgaXMgYXV0byBnZW5lcmF0ZWQuXG4gICAqL1xuICBuYW1lPzogc3RyaW5nO1xuICAvKipcbiAgICogRmlyc3QgY29sdW1uIG9mIHRoZSBqb2luIHRhYmxlLlxuICAgKi9cbiAgam9pbkNvbHVtbnM/OiBKb2luQ29sdW1uT3B0aW9uc1tdO1xuICAvKipcbiAgICogU2Vjb25kIChpbnZlcnNlKSBjb2x1bW4gb2YgdGhlIGpvaW4gdGFibGUuXG4gICAqL1xuICBpbnZlcnNlSm9pbkNvbHVtbnM/
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWwvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENhc2NhZGVNZXRhZGF0YSB9IGZyb20gXCIuLi9yZXBvc2l0b3J5XCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3RvciB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcblxuLyoqXG4gKiBEZXNjcmliZXMgam9pbiBjb2x1bW4gb3B0aW9ucy5cbiAqL1xuZXhwb3J0IHR5cGUgSm9pbkNvbHVtbk9wdGlvbnMgPSB7XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSBjb2x1bW4uXG4gICAqL1xuICBuYW1lPzogc3RyaW5nO1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgY29sdW1uIGluIHRoZSBlbnRpdHkgdG8gd2hpY2ggdGhpcyBjb2x1bW4gaXMgcmVmZXJlbmNlZC5cbiAgICovXG4gIHJlZmVyZW5jZWRDb2x1bW5OYW1lPzogc3RyaW5nO1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgZm9yZWlnbiBrZXkgY29uc3RyYWludC5cbiAgICovXG4gIGZvcmVpZ25LZXlDb25zdHJhaW50TmFtZT86IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEpvaW5UYWJsZU9wdGlvbnMgPSB7XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSB0YWJsZSB0aGF0IHdpbGwgYmUgY3JlYXRlZCB0byBzdG9yZSB2YWx1ZXMgb2YgdGhlIGJvdGggdGFibGVzIChqb2luIHRhYmxlKS5cbiAgICogQnkgZGVmYXVsdCBpcyBhdXRvIGdlbmVyYXRlZC5cbiAgICovXG4gIG5hbWU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBGaXJzdCBjb2x1bW4gb2YgdGhlIGpvaW4gdGFibGUuXG4gICAqL1xuICBqb2luQ29sdW1uPzogSm9pbkNvbHVtbk9wdGlvbnM7XG4gIC8qKlxuICAgKiBTZWNvbmQgKGludmVyc2UpIGNvbHVtbiBvZiB0aGUgam9pbiB0YWJsZS5cbiAgICovXG4gIGludmVyc2VKb2luQ29sdW1uPzogSm9pbkNvbHVtbk9wdGlvbnM7XG59O1xuXG5leHBvcnQgdHlwZSBKb2luVGFibGVNdWx0aXBsZUNvbHVtbnNPcHRpb25zID0ge1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgdGFibGUgdGhhdCB3aWxsIGJlIGNyZWF0ZWQgdG8gc3RvcmUgdmFsdWVzIG9mIHRoZSBib3RoIHRhYmxlcyAoam9pbiB0YWJsZSkuXG4gICAqIEJ5IGRlZmF1bHQgaXMgYXV0byBnZW5lcmF0ZWQuXG4gICAqL1xuICBuYW1lPzogc3RyaW5nO1xuICAvKipcbiAgICogRmlyc3QgY29sdW1uIG9mIHRoZSBqb2luIHRhYmxlLlxuICAgKi9cbiAgam9pbkNvbHVtbnM/OiBKb2luQ29sdW1uT3B0aW9uc1tdO1xuICAvKipcbiAgICogU2Vjb25kIChpbnZlcnNlKSBjb2x1bW4gb2YgdGhlIGpvaW4gdGFibGUuXG4gICAqL1xuICBpbnZlcnNlSm9pbkNvbHVtbnM/OiBKb2luQ29sdW1uT3B0aW9uc1tdO1xufTtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25zTWV0YWRhdGEgPSB7XG4gIGNsYXNzOiBzdHJpbmcgfCAoKCkgPT4gQ29uc3RydWN0b3I8YW55Pik7XG4gIGNhc2NhZGU6IENhc2NhZGVNZXRhZGF0YTtcbiAgcG9wdWxhdGU6IGJvb2xlYW47XG4gIG5hbWU/OiBzdHJpbmc7XG4gIGpvaW5UYWJsZT86IEpvaW5UYWJsZU9wdGlvbnM7XG59O1xuIl19
|
@@ -8,29 +8,29 @@ import { Repository } from "../repository/Repository";
|
|
8
8
|
import { Sequence } from "./Sequence";
|
9
9
|
import { ErrorParser } from "../interfaces";
|
10
10
|
import { Statement } from "../query/Statement";
|
11
|
-
import { Logger } from "@decaf-ts/logging";
|
12
11
|
import { Dispatch } from "./Dispatch";
|
13
12
|
import { type EventIds, type ObserverFilter } from "./types";
|
14
13
|
import { ObserverHandler } from "./ObserverHandler";
|
14
|
+
import { LoggedClass } from "@decaf-ts/logging";
|
15
15
|
/**
|
16
|
-
* @description Abstract
|
16
|
+
* @description Abstract Facade class for persistence adapters
|
17
17
|
* @summary Provides the foundation for all database adapters in the persistence layer. This class
|
18
18
|
* implements several interfaces to provide a consistent API for database operations, observer
|
19
19
|
* pattern support, and error handling. It manages adapter registration, CRUD operations, and
|
20
20
|
* observer notifications.
|
21
|
-
* @template
|
22
|
-
* @template
|
23
|
-
* @template
|
24
|
-
* @template
|
25
|
-
* @param {
|
21
|
+
* @template CONFIG - The underlying persistence driver config
|
22
|
+
* @template QUERY - The query object type used by the adapter
|
23
|
+
* @template FLAGS - The repository flags type
|
24
|
+
* @template CONTEXT - The context type
|
25
|
+
* @param {CONFIG} _config - The underlying persistence driver config
|
26
26
|
* @param {string} flavour - The identifier for this adapter type
|
27
27
|
* @param {string} [_alias] - Optional alternative name for this adapter
|
28
28
|
* @class Adapter
|
29
29
|
* @example
|
30
30
|
* ```typescript
|
31
31
|
* // Implementing a concrete adapter
|
32
|
-
* class PostgresAdapter extends Adapter<pg.
|
33
|
-
* constructor(client: pg.
|
32
|
+
* class PostgresAdapter extends Adapter<pg.PoolConfig, pg.Query, PostgresFlags, PostgresContext> {
|
33
|
+
* constructor(client: pg.PoolConfig) {
|
34
34
|
* super(client, 'postgres');
|
35
35
|
* }
|
36
36
|
*
|
@@ -104,27 +104,22 @@ import { ObserverHandler } from "./ObserverHandler";
|
|
104
104
|
* Adapter --|> Observer
|
105
105
|
* Adapter --|> ErrorParser
|
106
106
|
*/
|
107
|
-
export declare abstract class Adapter<
|
108
|
-
private readonly
|
107
|
+
export declare abstract class Adapter<CONF, CONN, QUERY, FLAGS extends RepositoryFlags = RepositoryFlags, CONTEXT extends Context<FLAGS> = Context<FLAGS>> extends LoggedClass implements RawExecutor<QUERY>, Contextual<FLAGS, CONTEXT>, Observable, Observer, ErrorParser {
|
108
|
+
private readonly _config;
|
109
109
|
readonly flavour: string;
|
110
110
|
private readonly _alias?;
|
111
111
|
private static _currentFlavour;
|
112
112
|
private static _cache;
|
113
|
-
|
114
|
-
protected dispatch?: Dispatch<Y>;
|
113
|
+
protected dispatch?: Dispatch<CONF>;
|
115
114
|
protected readonly observerHandler?: ObserverHandler;
|
115
|
+
protected _client?: CONN;
|
116
116
|
/**
|
117
|
-
* @description
|
118
|
-
* @summary
|
119
|
-
* @
|
117
|
+
* @description Gets the native persistence config
|
118
|
+
* @summary Provides access to the underlying persistence driver config
|
119
|
+
* @template CONF
|
120
|
+
* @return {CONF} The native persistence driver config
|
120
121
|
*/
|
121
|
-
|
122
|
-
/**
|
123
|
-
* @description Gets the native database driver
|
124
|
-
* @summary Provides access to the underlying database driver instance
|
125
|
-
* @return {Y} The native database driver
|
126
|
-
*/
|
127
|
-
get native(): Y;
|
122
|
+
get config(): CONF;
|
128
123
|
/**
|
129
124
|
* @description Gets the adapter's alias or flavor name
|
130
125
|
* @summary Returns the alias if set, otherwise returns the flavor name
|
@@ -135,27 +130,35 @@ export declare abstract class Adapter<Y, Q, F extends RepositoryFlags, C extends
|
|
135
130
|
* @description Gets the repository constructor for this adapter
|
136
131
|
* @summary Returns the constructor for creating repositories that work with this adapter
|
137
132
|
* @template M - The model type
|
138
|
-
* @return {Constructor<Repository<M,
|
133
|
+
* @return {Constructor<Repository<M, QUERY, Adapter<CONF, CONN, QUERY, FLAGS, CONTEXT>, FLAGS, CONTEXT>>} The repository constructor
|
134
|
+
*/
|
135
|
+
repository<M extends Model<boolean>>(): Constructor<Repository<M, QUERY, Adapter<CONF, CONN, QUERY, FLAGS, CONTEXT>, FLAGS, CONTEXT>>;
|
136
|
+
protected shutdownProxies(k?: string): Promise<void>;
|
137
|
+
/**
|
138
|
+
* @description Shuts down the adapter
|
139
|
+
* @summary Performs any necessary cleanup tasks, such as closing connections
|
140
|
+
* When overriding this method, ensure to call the base method first
|
141
|
+
* @return {Promise<void>} A promise that resolves when shutdown is complete
|
139
142
|
*/
|
140
|
-
|
143
|
+
shutdown(): Promise<void>;
|
141
144
|
/**
|
142
145
|
* @description Creates a new adapter instance
|
143
146
|
* @summary Initializes the adapter with the native driver and registers it in the adapter cache
|
144
147
|
*/
|
145
|
-
protected constructor(
|
148
|
+
protected constructor(_config: CONF, flavour: string, _alias?: string | undefined);
|
146
149
|
/**
|
147
150
|
* @description Creates a new statement builder for a model
|
148
151
|
* @summary Returns a statement builder that can be used to construct queries for a specific model
|
149
152
|
* @template M - The model type
|
150
153
|
* @return {Statement} A statement builder for the model
|
151
154
|
*/
|
152
|
-
abstract Statement<M extends Model>(): Statement<
|
155
|
+
abstract Statement<M extends Model>(): Statement<QUERY, M, any>;
|
153
156
|
/**
|
154
157
|
* @description Creates a new dispatch instance
|
155
158
|
* @summary Factory method that creates a dispatch instance for this adapter
|
156
159
|
* @return {Dispatch<Y>} A new dispatch instance
|
157
160
|
*/
|
158
|
-
protected Dispatch(): Dispatch<
|
161
|
+
protected Dispatch(): Dispatch<CONF>;
|
159
162
|
/**
|
160
163
|
* @description Creates a new observer handler
|
161
164
|
* @summary Factory method that creates an observer handler for this adapter
|
@@ -182,7 +185,7 @@ export declare abstract class Adapter<Y, Q, F extends RepositoryFlags, C extends
|
|
182
185
|
* @param {...any[]} args - Initialization arguments
|
183
186
|
* @return {Promise<void>} A promise that resolves when initialization is complete
|
184
187
|
*/
|
185
|
-
|
188
|
+
initialize(...args: any[]): Promise<void>;
|
186
189
|
/**
|
187
190
|
* @description Creates a sequence generator
|
188
191
|
* @summary Factory method that creates a sequence generator for generating sequential values
|
@@ -201,17 +204,17 @@ export declare abstract class Adapter<Y, Q, F extends RepositoryFlags, C extends
|
|
201
204
|
* @param {...any[]} args - Additional arguments
|
202
205
|
* @return {Promise<F>} The complete set of flags
|
203
206
|
*/
|
204
|
-
protected flags<M extends Model>(operation: OperationKeys, model: Constructor<M>, flags: Partial<
|
207
|
+
protected flags<M extends Model>(operation: OperationKeys, model: Constructor<M>, flags: Partial<FLAGS>, ...args: any[]): Promise<FLAGS>;
|
205
208
|
/**
|
206
209
|
* @description The context constructor for this adapter
|
207
210
|
* @summary Reference to the context class constructor used by this adapter
|
208
211
|
*/
|
209
212
|
protected Context: {
|
210
|
-
new (): Context<
|
213
|
+
new (): Context<FLAGS>;
|
211
214
|
factory: import("@decaf-ts/db-decorators").ContextFactory<any>;
|
212
|
-
childFrom<
|
213
|
-
from<M extends Model,
|
214
|
-
args<M extends Model<any>,
|
215
|
+
childFrom<F extends RepositoryFlags, C extends Context<F>>(context: C, overrides?: Partial<F>): C;
|
216
|
+
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>;
|
217
|
+
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<import("@decaf-ts/db-decorators").ContextArgs<F, C>>;
|
215
218
|
};
|
216
219
|
/**
|
217
220
|
* @description Creates a context for a database operation
|
@@ -224,7 +227,7 @@ export declare abstract class Adapter<Y, Q, F extends RepositoryFlags, C extends
|
|
224
227
|
* @param {...any[]} args - Additional arguments
|
225
228
|
* @return {Promise<C>} A promise that resolves to the context object
|
226
229
|
*/
|
227
|
-
context<M extends Model>(operation: OperationKeys.CREATE | OperationKeys.READ | OperationKeys.UPDATE | OperationKeys.DELETE, overrides: Partial<
|
230
|
+
context<M extends Model>(operation: OperationKeys.CREATE | OperationKeys.READ | OperationKeys.UPDATE | OperationKeys.DELETE, overrides: Partial<FLAGS>, model: Constructor<M>, ...args: any[]): Promise<CONTEXT>;
|
228
231
|
/**
|
229
232
|
* @description Prepares a model for persistence
|
230
233
|
* @summary Converts a model instance into a format suitable for database storage,
|
@@ -337,7 +340,7 @@ export declare abstract class Adapter<Y, Q, F extends RepositoryFlags, C extends
|
|
337
340
|
* @param {...any[]} args - Additional arguments specific to the adapter implementation
|
338
341
|
* @return {Promise<R>} A promise that resolves to the query result
|
339
342
|
*/
|
340
|
-
abstract raw<R>(rawInput:
|
343
|
+
abstract raw<R>(rawInput: QUERY, ...args: any[]): Promise<R>;
|
341
344
|
/**
|
342
345
|
* @description Registers an observer for database events
|
343
346
|
* @summary Adds an observer to be notified about database changes. The observer can optionally
|
@@ -399,14 +402,15 @@ export declare abstract class Adapter<Y, Q, F extends RepositoryFlags, C extends
|
|
399
402
|
/**
|
400
403
|
* @description Gets an adapter by flavor
|
401
404
|
* @summary Retrieves a registered adapter by its flavor name
|
402
|
-
* @template
|
403
|
-
* @template
|
404
|
-
* @template
|
405
|
-
* @template
|
405
|
+
* @template CONF - The database driver config
|
406
|
+
* @template CONN - The database driver instance
|
407
|
+
* @template QUERY - The query type
|
408
|
+
* @template CCONTEXT - The context type
|
409
|
+
* @template FLAGS - The repository flags type
|
406
410
|
* @param {string} flavour - The flavor name of the adapter to retrieve
|
407
|
-
* @return {Adapter<
|
411
|
+
* @return {Adapter<CONF, CONN, QUERY, CONTEXT, FLAGS> | undefined} The adapter instance or undefined if not found
|
408
412
|
*/
|
409
|
-
static get<
|
413
|
+
static get<CONF, CONN, QUERY, CONTEXT extends Context<FLAGS>, FLAGS extends RepositoryFlags>(flavour?: any): Adapter<CONF, CONN, QUERY, FLAGS, CONTEXT> | undefined;
|
410
414
|
/**
|
411
415
|
* @description Sets the current default adapter
|
412
416
|
* @summary Changes which adapter is used as the default for operations
|
@@ -430,13 +434,19 @@ export declare abstract class Adapter<Y, Q, F extends RepositoryFlags, C extends
|
|
430
434
|
*/
|
431
435
|
static models<M extends Model>(flavour: string): ModelConstructor<any>[];
|
432
436
|
static decoration(): void;
|
433
|
-
|
434
|
-
|
435
|
-
* @
|
436
|
-
* @
|
437
|
-
* @
|
438
|
-
* @
|
439
|
-
* @
|
440
|
-
|
441
|
-
|
437
|
+
protected proxies?: Record<string, typeof this>;
|
438
|
+
/**
|
439
|
+
* @description Returns the client instance for the adapter
|
440
|
+
* @summary This method should be overridden by subclasses to return the client instance for the adapter.
|
441
|
+
* @template CON - The type of the client instance
|
442
|
+
* @return {CON} The client instance for the adapter
|
443
|
+
* @abstract
|
444
|
+
* @function getClient
|
445
|
+
* @memberOf module:core
|
446
|
+
* @instance
|
447
|
+
* @protected
|
448
|
+
*/
|
449
|
+
protected abstract getClient(): CONN;
|
450
|
+
get client(): CONN;
|
451
|
+
for(config: Partial<CONF>, ...args: any[]): typeof this;
|
442
452
|
}
|