@decaf-ts/core 0.5.39 → 0.5.41
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/core.cjs +52 -14
- package/dist/core.esm.cjs +46 -11
- package/lib/esm/index.d.ts +2 -1
- package/lib/esm/index.js +3 -2
- package/lib/esm/model/decorators.d.ts +5 -1
- package/lib/esm/model/decorators.js +19 -2
- package/lib/esm/overrides/Metadata.d.ts +8 -0
- package/lib/esm/overrides/Metadata.js +2 -0
- package/lib/esm/overrides/index.d.ts +2 -0
- package/lib/esm/overrides/index.js +3 -0
- package/lib/esm/overrides/overrides.d.ts +1 -0
- package/lib/esm/overrides/overrides.js +11 -0
- package/lib/esm/persistence/Adapter.js +3 -1
- package/lib/esm/persistence/constants.d.ts +3 -1
- package/lib/esm/persistence/constants.js +3 -1
- package/lib/esm/ram/RamAdapter.js +1 -2
- package/lib/esm/repository/Repository.js +15 -8
- package/lib/index.cjs +3 -2
- package/lib/index.d.ts +2 -1
- package/lib/model/decorators.cjs +22 -1
- package/lib/model/decorators.d.ts +5 -1
- package/lib/overrides/Metadata.cjs +4 -0
- package/lib/overrides/Metadata.d.ts +8 -0
- package/lib/overrides/index.cjs +19 -0
- package/lib/overrides/index.d.ts +2 -0
- package/lib/overrides/overrides.cjs +13 -0
- package/lib/overrides/overrides.d.ts +1 -0
- package/lib/persistence/Adapter.cjs +3 -1
- package/lib/persistence/constants.cjs +3 -1
- package/lib/persistence/constants.d.ts +3 -1
- package/lib/ram/RamAdapter.cjs +1 -2
- package/lib/repository/Repository.cjs +15 -8
- package/package.json +2 -1
package/dist/core.esm.cjs
CHANGED
|
@@ -3,6 +3,7 @@ import { __decorate, __metadata } from 'tslib';
|
|
|
3
3
|
import { BadRequestError, InternalError, Repository as Repository$1, Context, DefaultRepositoryFlags, OperationKeys, modelToTransient, DBKeys, wrapMethodWithContext, enforceDBDecorators, ValidationError, findPrimaryKey, DefaultSeparator, BulkCrudOperationKeys, NotFoundError, timestamp, ConflictError, onCreateUpdate, onCreate, onUpdate, onDelete, afterAny, readonly, BaseError } from '@decaf-ts/db-decorators';
|
|
4
4
|
import { Model, ModelKeys, Decoration, DefaultFlavour, hashObj, required, sf, Validation, ValidationKeys, propMetadata, prop, type, list, model } from '@decaf-ts/decorator-validation';
|
|
5
5
|
import { LoggedClass, Logging } from '@decaf-ts/logging';
|
|
6
|
+
import { Metadata, apply as apply$1, metadata as metadata$1 } from '@decaf-ts/decoration';
|
|
6
7
|
import { apply, metadata, Reflection } from '@decaf-ts/reflection';
|
|
7
8
|
import { Lock } from '@decaf-ts/transactional-decorators';
|
|
8
9
|
|
|
@@ -51,6 +52,8 @@ var PersistenceKeys;
|
|
|
51
52
|
PersistenceKeys["MANY_TO_MANY"] = "relation.many-to-many";
|
|
52
53
|
/** @description Key for populate metadata */
|
|
53
54
|
PersistenceKeys["POPULATE"] = "populate";
|
|
55
|
+
/** @description Key for populate metadata */
|
|
56
|
+
PersistenceKeys["NO_VALIDATE"] = "no-validate";
|
|
54
57
|
})(PersistenceKeys || (PersistenceKeys = {}));
|
|
55
58
|
|
|
56
59
|
/**
|
|
@@ -563,6 +566,7 @@ class Adapter extends LoggedClass {
|
|
|
563
566
|
writeOperation: operation !== OperationKeys.READ,
|
|
564
567
|
timestamp: new Date(),
|
|
565
568
|
operation: operation,
|
|
569
|
+
ignoredValidationProperties: Metadata.validationExceptions(model, operation),
|
|
566
570
|
});
|
|
567
571
|
}
|
|
568
572
|
/**
|
|
@@ -1794,9 +1798,11 @@ class Repository extends Repository$1 {
|
|
|
1794
1798
|
models = await Promise.all(models.map(async (m, i) => {
|
|
1795
1799
|
m = new this.class(m);
|
|
1796
1800
|
if (opts.type) {
|
|
1797
|
-
m[this.pk] = (opts.type !==
|
|
1798
|
-
ids[i]
|
|
1799
|
-
|
|
1801
|
+
m[this.pk] = (opts.type !== "String"
|
|
1802
|
+
? ids[i]
|
|
1803
|
+
: opts.generated
|
|
1804
|
+
? ids[i]
|
|
1805
|
+
: `${m[this.pk]}`.toString());
|
|
1800
1806
|
}
|
|
1801
1807
|
await enforceDBDecorators(this, contextArgs.context, m, OperationKeys.CREATE, OperationKeys.ON);
|
|
1802
1808
|
return m;
|
|
@@ -2172,10 +2178,13 @@ class Repository extends Repository$1 {
|
|
|
2172
2178
|
* @throws {InternalError} If no repository is registered for the model.
|
|
2173
2179
|
*/
|
|
2174
2180
|
static get(model, alias) {
|
|
2175
|
-
|
|
2181
|
+
const name = Repository.table(model);
|
|
2182
|
+
let registryName = name;
|
|
2176
2183
|
if (alias) {
|
|
2177
|
-
|
|
2184
|
+
registryName = [name, alias].join(DefaultSeparator);
|
|
2178
2185
|
}
|
|
2186
|
+
if (registryName in this._cache)
|
|
2187
|
+
return this._cache[registryName];
|
|
2179
2188
|
if (name in this._cache)
|
|
2180
2189
|
return this._cache[name];
|
|
2181
2190
|
throw new InternalError(`Could not find repository registered under ${name}`);
|
|
@@ -2194,8 +2203,10 @@ class Repository extends Repository$1 {
|
|
|
2194
2203
|
if (alias) {
|
|
2195
2204
|
name = [name, alias].join(DefaultSeparator);
|
|
2196
2205
|
}
|
|
2197
|
-
if (name in this._cache)
|
|
2198
|
-
|
|
2206
|
+
if (name in this._cache) {
|
|
2207
|
+
if (this._cache[name] instanceof Repository)
|
|
2208
|
+
throw new InternalError(`${name} already has a registered instance`);
|
|
2209
|
+
}
|
|
2199
2210
|
this._cache[name] = repo;
|
|
2200
2211
|
}
|
|
2201
2212
|
/**
|
|
@@ -2713,6 +2724,15 @@ class Dispatch extends LoggedClass {
|
|
|
2713
2724
|
if (Adapter)
|
|
2714
2725
|
Adapter["_baseDispatch"] = Dispatch;
|
|
2715
2726
|
|
|
2727
|
+
Metadata.validationExceptions = function (model, op) {
|
|
2728
|
+
const noValidation = Metadata.get(model, PersistenceKeys.NO_VALIDATE);
|
|
2729
|
+
if (!noValidation)
|
|
2730
|
+
return [];
|
|
2731
|
+
return Object.entries(noValidation)
|
|
2732
|
+
.filter(([, val]) => val.includes(op))
|
|
2733
|
+
.map(([key]) => key);
|
|
2734
|
+
}.bind(Metadata);
|
|
2735
|
+
|
|
2716
2736
|
/**
|
|
2717
2737
|
* @description Repository decorator for model classes.
|
|
2718
2738
|
* @summary Creates and registers a repository for a model class. Can be used as both a property decorator and a class decorator.
|
|
@@ -3885,6 +3905,22 @@ function manyToMany(clazz, cascadeOptions = DefaultCascade, populate = true, joi
|
|
|
3885
3905
|
})
|
|
3886
3906
|
.apply();
|
|
3887
3907
|
}
|
|
3908
|
+
function noValidateOn(...ops) {
|
|
3909
|
+
return function noValidateOn(target, propertyKey) {
|
|
3910
|
+
const currentMeta = Metadata.get(target, Metadata.key(PersistenceKeys.NO_VALIDATE, propertyKey)) || [];
|
|
3911
|
+
const newMeta = [...new Set([...currentMeta, ...ops])];
|
|
3912
|
+
return apply$1(metadata$1(Metadata.key(PersistenceKeys.NO_VALIDATE, propertyKey), newMeta))(target, propertyKey);
|
|
3913
|
+
};
|
|
3914
|
+
}
|
|
3915
|
+
function noValidateOnCreate() {
|
|
3916
|
+
return noValidateOn(OperationKeys.CREATE);
|
|
3917
|
+
}
|
|
3918
|
+
function noValidateOnUpdate() {
|
|
3919
|
+
return noValidateOn(OperationKeys.UPDATE);
|
|
3920
|
+
}
|
|
3921
|
+
function noValidateOnCreateUpdate() {
|
|
3922
|
+
return noValidateOn(OperationKeys.UPDATE, OperationKeys.CREATE);
|
|
3923
|
+
}
|
|
3888
3924
|
|
|
3889
3925
|
const defaultPkPriority = 60; // Default priority for primary key to run latter than other properties
|
|
3890
3926
|
/**
|
|
@@ -5196,7 +5232,6 @@ async function createdByOnRamCreateUpdate(context, data, key, model) {
|
|
|
5196
5232
|
*/
|
|
5197
5233
|
const RamFlavour = "ram";
|
|
5198
5234
|
|
|
5199
|
-
Adapter.setCurrent(RamFlavour);
|
|
5200
5235
|
/**
|
|
5201
5236
|
* @description In-memory adapter for data persistence
|
|
5202
5237
|
* @summary The RamAdapter provides an in-memory implementation of the persistence layer.
|
|
@@ -5663,7 +5698,7 @@ Injectables.setRegistry(new InjectablesRegistry());
|
|
|
5663
5698
|
* @const VERSION
|
|
5664
5699
|
* @memberOf module:core
|
|
5665
5700
|
*/
|
|
5666
|
-
const VERSION = "0.5.
|
|
5701
|
+
const VERSION = "0.5.40";
|
|
5667
5702
|
|
|
5668
|
-
export { Adapter, AuthorizationError, BaseModel, BigIntSequence, Cascade, Condition, ConnectionError, DefaultCascade, DefaultSequenceOptions, Dispatch, ForbiddenError, GroupOperator, InjectablesRegistry, MethodQueryBuilder, NoneSequenceOptions, NumericSequence, ObserverError, ObserverHandler, Operator, OperatorsMap, OrderDirection, Paginator, PagingError, PersistenceKeys, QueryClause, QueryError, RamAdapter, Repository, Sequence, Statement, UnsupportedError, VERSION, cacheModelForPopulate, column, createOrUpdate, createdAt, createdBy, createdByOnCreateUpdate, final, generateInjectableNameForRepository, getColumnName, getPopulateKey, getTableName, index, manyToMany, manyToOne, oneToMany, oneToManyOnCreate, oneToManyOnDelete, oneToManyOnUpdate, oneToOne, oneToOneOnCreate, oneToOneOnDelete, oneToOneOnUpdate, pk, pkOnCreate, populate, query, repository, repositoryFromTypeMetadata, sequenceNameForModel, table, unique, uniqueOnCreateUpdate, updatedAt, updatedBy, uses };
|
|
5669
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"core.esm.cjs","sources":["../src/persistence/constants.ts","../src/utils/decorators.ts","../src/utils/errors.ts","../src/persistence/ObserverHandler.ts","../src/identity/utils.ts","../src/persistence/Adapter.ts","../src/repository/constants.ts","../src/persistence/errors.ts","../src/persistence/Sequence.ts","../src/query/constants.ts","../src/query/errors.ts","../src/query/Condition.ts","../src/persistence/decorators.ts","../src/repository/Repository.ts","../src/repository/utils.ts","../src/repository/injectables.ts","../src/persistence/Dispatch.ts","../src/repository/decorators.ts","../src/repository/errors.ts","../src/interfaces/SequenceOptions.ts","../src/model/construction.ts","../src/model/decorators.ts","../src/identity/decorators.ts","../src/model/BaseModel.ts","../src/query/Paginator.ts","../src/query/Statement.ts","../src/query/types.ts","../src/query/utils.ts","../src/query/MethodQueryBuilder.ts","../src/query/decorators.ts","../src/ram/RamPaginator.ts","../src/ram/RamStatement.ts","../src/ram/RamContext.ts","../src/ram/model/RamSequenceModel.ts","../src/ram/RamSequence.ts","../src/ram/handlers.ts","../src/ram/constants.ts","../src/ram/RamAdapter.ts","../src/index.ts"],"sourcesContent":["/**\n * @description Persistence-related constant keys\n * @summary Enum containing string constants used throughout the persistence layer for metadata, relations, and other persistence-related operations\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum PersistenceKeys {\n  /** @description Key for index metadata */\n  INDEX = \"index\",\n\n  /** @description Key for unique constraint metadata */\n  UNIQUE = \"unique\",\n\n  /** @description Key for adapter metadata */\n  ADAPTER = \"adapter\",\n\n  /** @description Template for injectable adapter names */\n  INJECTABLE = \"decaf_{0}_adapter_for_{1}\",\n\n  /** @description Key for table name metadata */\n  TABLE = \"table\",\n\n  /** @description Key for column name metadata */\n  COLUMN = \"column\",\n\n  /** @description Key for general metadata storage */\n  METADATA = \"__metadata\",\n\n  // Ownership\n  /** @description Key for created-by ownership metadata */\n  OWNERSHIP = \"ownership\",\n\n  /** @description Key for created-by ownership metadata */\n  CREATED_BY = `${OWNERSHIP}.created-by`,\n\n  /** @description Key for updated-by ownership metadata */\n  UPDATED_BY = `${OWNERSHIP}.updated-by`,\n\n  // Relations\n\n  /** @description Key for relations metadata storage */\n  RELATIONS = \"__relations\",\n\n  /** @description Key for relations metadata storage */\n  RELATION = \"relation\",\n\n  /** @description Key for one-to-one relation metadata */\n  ONE_TO_ONE = `${RELATION}.one-to-one`,\n\n  /** @description Key for one-to-many relation metadata */\n  ONE_TO_MANY = `${RELATION}.one-to-many`,\n\n  /** @description Key for many-to-one relation metadata */\n  MANY_TO_ONE = `${RELATION}.many-to-one`,\n  /** @description Key for many-to-one relation metadata */\n  MANY_TO_MANY = `${RELATION}.many-to-many`,\n\n  /** @description Key for populate metadata */\n  POPULATE = \"populate\",\n}\n","/**\n * @description Creates a decorator that makes a method non-configurable\n * @summary This decorator prevents a method from being overridden by making it non-configurable.\n * It throws an error if used on anything other than a method.\n * @return {Function} A decorator function that can be applied to methods\n * @function final\n * @category Method Decorators\n */\nexport function final() {\n  return (\n    target: object,\n    propertyKey?: any,\n    descriptor?: PropertyDescriptor\n  ) => {\n    if (!descriptor)\n      throw new Error(\"final decorator can only be used on methods\");\n    if (descriptor?.configurable) {\n      descriptor.configurable = false;\n    }\n    return descriptor;\n  };\n}\n","import { BadRequestError, InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Error thrown when a user is not authorized to perform an action\n * @summary This error is thrown when a user attempts to access a resource or perform an action without proper authentication\n * @param {string|Error} msg - The error message or Error object\n * @class AuthorizationError\n * @category Errors\n * @example\n * ```typescript\n * // Example of throwing an AuthorizationError\n * if (!user.isAuthenticated()) {\n *   throw new AuthorizationError('User not authenticated');\n * }\n * ```\n */\nexport class AuthorizationError extends BadRequestError {\n  constructor(msg: string | Error, name = AuthorizationError.name, code = 401) {\n    super(msg, name, code);\n  }\n}\n\n/**\n * @description Error thrown when a user is forbidden from accessing a resource\n * @summary This error is thrown when an authenticated user attempts to access a resource or perform an action they don't have permission for\n * @param {string|Error} msg - The error message or Error object\n * @return {void}\n * @class ForbiddenError\n * @category Errors\n * @example\n * ```typescript\n * // Example of throwing a ForbiddenError\n * if (!user.hasPermission('admin')) {\n *   throw new ForbiddenError('User does not have admin permissions');\n * }\n * ```\n */\nexport class ForbiddenError extends AuthorizationError {\n  constructor(msg: string | Error, name = ForbiddenError.name) {\n    super(msg, name, 403);\n  }\n}\n\n/**\n * @description Error thrown when a connection to a service fails\n * @summary This error is thrown when the application fails to establish a connection to a required service or resource\n * @param {string|Error} msg - The error message or Error object\n * @return {void}\n * @class ConnectionError\n * @category Errors\n * @example\n * ```typescript\n * // Example of throwing a ConnectionError\n * try {\n *   await database.connect();\n * } catch (error) {\n *   throw new ConnectionError('Failed to connect to database');\n * }\n * ```\n */\nexport class ConnectionError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, ConnectionError.name, 503);\n  }\n}\n","import { Observable, Observer } from \"../interfaces\";\nimport { EventIds, ObserverFilter } from \"./types\";\nimport {\n  BulkCrudOperationKeys,\n  InternalError,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { Logger } from \"@decaf-ts/logging\";\n\n/**\n * @description Manages a collection of observers for database events\n * @summary The ObserverHandler class implements the Observable interface and provides a centralized\n * way to manage multiple observers. It allows registering observers with optional filters to control\n * which events they receive notifications for, and handles the process of notifying all relevant\n * observers when database events occur.\n * @class ObserverHandler\n * @example\n * ```typescript\n * // Create an observer handler\n * const handler = new ObserverHandler();\n *\n * // Register an observer\n * const myObserver = {\n *   refresh: async (table, event, id) => {\n *     console.log(`Change in ${table}: ${event} for ID ${id}`);\n *   }\n * };\n *\n * // Add observer with a filter for only user table events\n * handler.observe(myObserver, (table, event, id) => table === 'users');\n *\n * // Notify observers about an event\n * await handler.updateObservers(logger, 'users', 'CREATE', 123);\n *\n * // Remove an observer when no longer needed\n * handler.unObserve(myObserver);\n * ```\n */\nexport class ObserverHandler implements Observable {\n  /**\n   * @description Collection of registered observers\n   * @summary Array of observer objects along with their optional filters\n   */\n  protected readonly observers: {\n    observer: Observer;\n    filter?: ObserverFilter;\n  }[] = [];\n\n  /**\n   * @description Gets the number of registered observers\n   * @summary Returns the count of observers currently registered with this handler\n   * @return {number} The number of registered observers\n   */\n  count() {\n    return this.observers.length;\n  }\n\n  /**\n   * @description Registers a new observer\n   * @summary Adds an observer to the collection with an optional filter function\n   * @param {Observer} observer - The observer to register\n   * @param {ObserverFilter} [filter] - Optional filter function to determine which events the observer receives\n   * @return {void}\n   */\n  observe(observer: Observer, filter?: ObserverFilter): void {\n    const index = this.observers.map((o) => o.observer).indexOf(observer);\n    if (index !== -1) throw new InternalError(\"Observer already registered\");\n    this.observers.push({ observer: observer, filter: filter });\n  }\n\n  /**\n   * @description Unregisters an observer\n   * @summary Removes an observer from the collection\n   * @param {Observer} observer - The observer to unregister\n   * @return {void}\n   */\n  unObserve(observer: Observer): void {\n    const index = this.observers.map((o) => o.observer).indexOf(observer);\n    if (index === -1) throw new InternalError(\"Failed to find Observer\");\n    this.observers.splice(index, 1);\n  }\n\n  /**\n   * @description Notifies all relevant observers about a database event\n   * @summary Filters observers based on their filter functions and calls refresh on each matching observer\n   * @param {Logger} log - Logger for recording notification activities\n   * @param {string} table - The name of the table where the event occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {EventIds} id - The identifier(s) of the affected record(s)\n   * @param {...any[]} args - Additional arguments to pass to the observers\n   * @return {Promise<void>} A promise that resolves when all observers have been notified\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant ObserverHandler\n   *   participant Observer\n   *\n   *   Client->>ObserverHandler: updateObservers(log, table, event, id, ...args)\n   *\n   *   ObserverHandler->>ObserverHandler: Filter observers\n   *\n   *   loop For each observer with matching filter\n   *     alt Observer has filter\n   *       ObserverHandler->>Observer: Apply filter(table, event, id)\n   *       alt Filter throws error\n   *         ObserverHandler->>Logger: Log error\n   *         ObserverHandler-->>ObserverHandler: Skip observer\n   *       else Filter returns true\n   *         ObserverHandler->>Observer: refresh(table, event, id, ...args)\n   *       else Filter returns false\n   *         ObserverHandler-->>ObserverHandler: Skip observer\n   *       end\n   *     else No filter\n   *       ObserverHandler->>Observer: refresh(table, event, id, ...args)\n   *     end\n   *   end\n   *\n   *   ObserverHandler->>ObserverHandler: Process results\n   *   loop For each result\n   *     alt Result is rejected\n   *       ObserverHandler->>Logger: Log error\n   *     end\n   *   end\n   *\n   *   ObserverHandler-->>Client: Return\n   */\n  async updateObservers(\n    log: Logger,\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ): Promise<void> {\n    const results = await Promise.allSettled(\n      this.observers\n        .filter((o) => {\n          const { filter } = o;\n          if (!filter) return true;\n          try {\n            return filter(table, event, id);\n          } catch (e: unknown) {\n            log.error(\n              `Failed to filter observer ${o.observer.toString()}: ${e}`\n            );\n            return false;\n          }\n        })\n        .map((o) => {\n          o.observer.refresh(table, event, id, ...args);\n        })\n    );\n    results.forEach((result, i) => {\n      if (result.status === \"rejected\")\n        log.error(\n          `Failed to update observable ${this.observers[i].toString()}: ${result.reason}`\n        );\n    });\n  }\n}\n","import { Constructor, Model, ModelKeys } from \"@decaf-ts/decorator-validation\";\nimport { Repository } from \"@decaf-ts/db-decorators\";\nimport { PersistenceKeys } from \"../persistence/constants\";\n\n/**\n * @description Gets the table name for a model\n * @summary Retrieves the table name associated with a model by checking metadata or falling back to the constructor name\n * @template M - Type that extends Model\n * @param {M | Constructor<M>} model - The model instance or constructor to get the table name for\n * @return {string} The table name for the model\n * @function getTableName\n * @memberOf module:core\n */\nexport function getTableName<M extends Model>(\n  model: M | Constructor<M>\n): string {\n  const obj = model instanceof Model ? model.constructor : model;\n\n  const metadata = Reflect.getOwnMetadata(\n    Repository.key(PersistenceKeys.TABLE),\n    obj[ModelKeys.ANCHOR as unknown as keyof typeof obj] || obj\n  );\n  if (metadata) {\n    return metadata;\n  }\n  if (model instanceof Model) {\n    return model.constructor.name;\n  }\n  return model.name;\n}\n\nexport function getColumnName<M extends Model>(\n  model: M,\n  attribute: string\n): string {\n  const metadata = Reflect.getMetadata(\n    Repository.key(PersistenceKeys.COLUMN),\n    model,\n    attribute\n  );\n  return metadata ? metadata : attribute;\n}\n\n/**\n * @description Generates a sequence name for a model\n * @summary Creates a standardized sequence name by combining the table name with additional arguments\n * @template M - Type that extends Model\n * @param {M | Constructor<M>} model - The model instance or constructor to generate the sequence name for\n * @param {...string} args - Additional string arguments to append to the sequence name\n * @return {string} The generated sequence name\n * @function sequenceNameForModel\n * @memberOf module:core\n */\nexport function sequenceNameForModel<M extends Model>(\n  model: M | Constructor<M>,\n  ...args: string[]\n) {\n  return [getTableName(model), ...args].join(\"_\");\n}\n","import {\n  BaseError,\n  DBKeys,\n  InternalError,\n  Context,\n  OperationKeys,\n  RepositoryFlags,\n  DefaultRepositoryFlags,\n  Contextual,\n  BulkCrudOperationKeys,\n  modelToTransient,\n} from \"@decaf-ts/db-decorators\";\nimport { type Observer } from \"../interfaces/Observer\";\nimport {\n  type Constructor,\n  Decoration,\n  DefaultFlavour,\n  hashObj,\n  Model,\n  ModelConstructor,\n  ModelRegistry,\n} from \"@decaf-ts/decorator-validation\";\nimport { SequenceOptions } from \"../interfaces/SequenceOptions\";\nimport { RawExecutor } from \"../interfaces/RawExecutor\";\nimport { Observable } from \"../interfaces/Observable\";\nimport { PersistenceKeys } from \"./constants\";\nimport type { Repository } from \"../repository/Repository\";\nimport { Sequence } from \"./Sequence\";\nimport { ErrorParser } from \"../interfaces\";\nimport { Statement } from \"../query/Statement\";\nimport { final } from \"../utils\";\nimport type { Dispatch } from \"./Dispatch\";\nimport { type EventIds, type ObserverFilter } from \"./types\";\nimport { ObserverHandler } from \"./ObserverHandler\";\nimport { LoggedClass } from \"@decaf-ts/logging\";\nimport { getColumnName, getTableName } from \"../identity/utils\";\nimport { Repository as Repo } from \"@decaf-ts/db-decorators\";\nimport { AdapterDispatch } from \"./types\";\n\nDecoration.setFlavourResolver((obj: object) => {\n  try {\n    return (\n      Adapter.flavourOf(Model.isModel(obj) ? obj.constructor : (obj as any)) ||\n      Adapter.currentFlavour ||\n      DefaultFlavour\n    );\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    // return DefaultFlavour;\n  }\n  try {\n    return Adapter.currentFlavour || DefaultFlavour;\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    return DefaultFlavour;\n  }\n});\n\n/**\n * @description Abstract Facade class for persistence adapters\n * @summary Provides the foundation for all database adapters in the persistence layer. This class\n * implements several interfaces to provide a consistent API for database operations, observer\n * pattern support, and error handling. It manages adapter registration, CRUD operations, and\n * observer notifications.\n * @template CONFIG - The underlying persistence driver config\n * @template QUERY - The query object type used by the adapter\n * @template FLAGS - The repository flags type\n * @template CONTEXT - The context type\n * @param {CONFIG} _config - The underlying persistence driver config\n * @param {string} flavour - The identifier for this adapter type\n * @param {string} [_alias] - Optional alternative name for this adapter\n * @class Adapter\n * @example\n * ```typescript\n * // Implementing a concrete adapter\n * class PostgresAdapter extends Adapter<pg.PoolConfig, pg.Query, PostgresFlags, PostgresContext> {\n *   constructor(client: pg.PoolConfig) {\n *     super(client, 'postgres');\n *   }\n *\n *   async initialize() {\n *     // Set up the adapter\n *     await this.native.connect();\n *   }\n *\n *   async create(tableName, id, model) {\n *     // Implementation for creating records\n *     const columns = Object.keys(model).join(', ');\n *     const values = Object.values(model);\n *     const placeholders = values.map((_, i) => `$${i+1}`).join(', ');\n *\n *     const query = `INSERT INTO ${tableName} (${columns}) VALUES (${placeholders}) RETURNING *`;\n *     const result = await this.native.query(query, values);\n *     return result.rows[0];\n *   }\n *\n *   // Other required method implementations...\n * }\n *\n * // Using the adapter\n * const pgClient = new pg.Client(connectionString);\n * const adapter = new PostgresAdapter(pgClient);\n * await adapter.initialize();\n *\n * // Set as the default adapter\n * Adapter.setCurrent('postgres');\n *\n * // Perform operations\n * const user = await adapter.create('users', 1, { name: 'John', email: 'john@example.com' });\n * ```\n * @mermaid\n * classDiagram\n *   class Adapter {\n *     +Y native\n *     +string flavour\n *     +string alias\n *     +create(tableName, id, model)\n *     +read(tableName, id)\n *     +update(tableName, id, model)\n *     +delete(tableName, id)\n *     +observe(observer, filter)\n *     +unObserve(observer)\n *     +static current\n *     +static get(flavour)\n *     +static setCurrent(flavour)\n *   }\n *\n *   class RawExecutor {\n *     +raw(query)\n *   }\n *\n *   class Observable {\n *     +observe(observer, filter)\n *     +unObserve(observer)\n *     +updateObservers(table, event, id)\n *   }\n *\n *   class Observer {\n *     +refresh(table, event, id)\n *   }\n *\n *   class ErrorParser {\n *     +parseError(err)\n *   }\n *\n *   Adapter --|> RawExecutor\n *   Adapter --|> Observable\n *   Adapter --|> Observer\n *   Adapter --|> ErrorParser\n */\nexport abstract class Adapter<\n    CONF,\n    CONN,\n    QUERY,\n    FLAGS extends RepositoryFlags = RepositoryFlags,\n    CONTEXT extends Context<FLAGS> = Context<FLAGS>,\n  >\n  extends LoggedClass\n  implements\n    RawExecutor<QUERY>,\n    Contextual<FLAGS, CONTEXT>,\n    Observable,\n    Observer,\n    ErrorParser\n{\n  private static _currentFlavour: string;\n  private static _cache: Record<string, Adapter<any, any, any, any, any>> = {};\n  private static _baseRepository: Constructor<\n    Repository<any, any, any, any, any>\n  >;\n  private static _baseDispatch: Constructor<Dispatch>;\n\n  protected dispatch?: AdapterDispatch;\n\n  protected readonly observerHandler?: ObserverHandler;\n\n  protected _client?: CONN;\n\n  /**\n   * @description Gets the native persistence config\n   * @summary Provides access to the underlying persistence driver config\n   * @template CONF\n   * @return {CONF} The native persistence driver config\n   */\n  get config(): CONF {\n    return this._config;\n  }\n\n  /**\n   * @description Gets the adapter's alias or flavor name\n   * @summary Returns the alias if set, otherwise returns the flavor name\n   * @return {string} The adapter's identifier\n   */\n  get alias(): string {\n    return this._alias || this.flavour;\n  }\n\n  /**\n   * @description Gets the repository constructor for this adapter\n   * @summary Returns the constructor for creating repositories that work with this adapter\n   * @template M - The model type\n   * @return {Constructor<Repository<M, QUERY, Adapter<CONF, CONN, QUERY, FLAGS, CONTEXT>, FLAGS, CONTEXT>>} The repository constructor\n   */\n  repository<M extends Model<boolean>>(): Constructor<\n    Repository<\n      M,\n      QUERY,\n      Adapter<CONF, CONN, QUERY, FLAGS, CONTEXT>,\n      FLAGS,\n      CONTEXT\n    >\n  > {\n    if (!Adapter._baseRepository)\n      throw new InternalError(\n        `This should be overridden when necessary. Otherwise it will be replaced lazily`\n      );\n    return Adapter._baseRepository;\n  }\n\n  @final()\n  protected async shutdownProxies(k?: string) {\n    if (!this.proxies) return;\n    if (k && !(k in this.proxies))\n      throw new InternalError(`No proxy found for ${k}`);\n    if (!k) {\n      for (const key in this.proxies) {\n        try {\n          await this.proxies[key].shutdown();\n        } catch (e: unknown) {\n          this.log.error(`Failed to shutdown proxied adapter ${key}: ${e}`);\n          continue;\n        }\n        delete this.proxies[key];\n      }\n    } else {\n      try {\n        await this.proxies[k].shutdown();\n        delete this.proxies[k];\n      } catch (e: unknown) {\n        this.log.error(`Failed to shutdown proxied adapter ${k}: ${e}`);\n      }\n    }\n  }\n\n  /**\n   * @description Shuts down the adapter\n   * @summary Performs any necessary cleanup tasks, such as closing connections\n   * When overriding this method, ensure to call the base method first\n   * @return {Promise<void>} A promise that resolves when shutdown is complete\n   */\n  async shutdown(): Promise<void> {\n    await this.shutdownProxies();\n    if (this.dispatch) await this.dispatch.close();\n  }\n\n  /**\n   * @description Creates a new adapter instance\n   * @summary Initializes the adapter with the native driver and registers it in the adapter cache\n   */\n  protected constructor(\n    private readonly _config: CONF,\n    readonly flavour: string,\n    private readonly _alias?: string\n  ) {\n    super();\n    if (this.alias in Adapter._cache)\n      throw new InternalError(\n        `${this.alias} persistence adapter ${this._alias ? `(${this.flavour}) ` : \"\"} already registered`\n      );\n    Adapter._cache[this.alias] = this;\n    this.log.info(\n      `Created ${this.alias} persistence adapter ${this._alias ? `(${this.flavour}) ` : \"\"} persistence adapter`\n    );\n    if (!Adapter._currentFlavour) {\n      this.log.verbose(`Defined ${this.alias} persistence adapter as current`);\n      Adapter._currentFlavour = this.alias;\n    }\n  }\n\n  /**\n   * @description Creates a new statement builder for a model\n   * @summary Returns a statement builder that can be used to construct queries for a specific model\n   * @template M - The model type\n   * @return {Statement} A statement builder for the model\n   */\n  abstract Statement<M extends Model>(): Statement<QUERY, M, any>;\n\n  /**\n   * @description Creates a new dispatch instance\n   * @summary Factory method that creates a dispatch instance for this adapter\n   * @return {Dispatch} A new dispatch instance\n   */\n  protected Dispatch(): Dispatch {\n    return new Adapter._baseDispatch();\n  }\n\n  /**\n   * @description Creates a new observer handler\n   * @summary Factory method that creates an observer handler for this adapter\n   * @return {ObserverHandler} A new observer handler instance\n   */\n  protected ObserverHandler(): ObserverHandler {\n    return new ObserverHandler();\n  }\n\n  /**\n   * @description Checks if an attribute name is reserved\n   * @summary Determines if a given attribute name is reserved and cannot be used as a column name\n   * @param {string} attr - The attribute name to check\n   * @return {boolean} True if the attribute is reserved, false otherwise\n   */\n  protected isReserved(attr: string): boolean {\n    return !attr;\n  }\n\n  /**\n   * @description Parses a database error into a standardized error\n   * @summary Converts database-specific errors into standardized application errors\n   * @param {Error} err - The original database error\n   * @return {BaseError} A standardized error\n   */\n  abstract parseError(err: Error): BaseError;\n\n  /**\n   * @description Initializes the adapter\n   * @summary Performs any necessary setup for the adapter, such as establishing connections\n   * @param {...any[]} args - Initialization arguments\n   * @return {Promise<void>} A promise that resolves when initialization is complete\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async initialize(...args: any[]): Promise<void> {}\n\n  /**\n   * @description Creates a sequence generator\n   * @summary Factory method that creates a sequence generator for generating sequential values\n   * @param {SequenceOptions} options - Configuration options for the sequence\n   * @return {Promise<Sequence>} A promise that resolves to a new sequence instance\n   */\n  abstract Sequence(options: SequenceOptions): Promise<Sequence>;\n\n  /**\n   * @description Creates repository flags for an operation\n   * @summary Generates a set of flags that describe a database operation, combining default flags with overrides\n   * @template F - The Repository Flags type\n   * @template M - The model type\n   * @param {OperationKeys} operation - The type of operation being performed\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<F>} flags - Custom flag overrides\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<F>} The complete set of flags\n   */\n  protected async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<FLAGS>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<FLAGS> {\n    return Object.assign({}, DefaultRepositoryFlags, flags, {\n      affectedTables: getTableName(model),\n      writeOperation: operation !== OperationKeys.READ,\n      timestamp: new Date(),\n      operation: operation,\n    }) as FLAGS;\n  }\n\n  /**\n   * @description The context constructor for this adapter\n   * @summary Reference to the context class constructor used by this adapter\n   */\n  protected Context = Context<FLAGS>;\n\n  /**\n   * @description Creates a context for a database operation\n   * @summary Generates a context object that describes a database operation, used for tracking and auditing\n   * @template F - The Repository flags type\n   * @template M - The model type\n   * @param {OperationKeys.CREATE|OperationKeys.READ|OperationKeys.UPDATE|OperationKeys.DELETE} operation - The type of operation\n   * @param {Partial<F>} overrides - Custom flag overrides\n   * @param {Constructor<M>} model - The model constructor\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<C>} A promise that resolves to the context object\n   */\n  @final()\n  async context<M extends Model>(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    overrides: Partial<FLAGS>,\n    model: Constructor<M>,\n    ...args: any[]\n  ): Promise<CONTEXT> {\n    const log = this.log.for(this.context);\n    log.debug(\n      `Creating new context for ${operation} operation on ${model.name} model with flag overrides: ${JSON.stringify(overrides)}`\n    );\n    const flags = await this.flags(operation, model, overrides, ...args);\n    return new this.Context().accumulate(flags) as unknown as CONTEXT;\n  }\n\n  /**\n   * @description Prepares a model for persistence\n   * @summary Converts a model instance into a format suitable for database storage,\n   * handling column mapping and separating transient properties\n   * @template M - The model type\n   * @param {M} model - The model instance to prepare\n   * @param pk - The primary key property name\n   * @return The prepared data\n   */\n  prepare<M extends Model>(\n    model: M,\n    pk: keyof M\n  ): {\n    record: Record<string, any>;\n    id: string;\n    transient?: Record<string, any>;\n  } {\n    const log = this.log.for(this.prepare);\n    const split = modelToTransient(model);\n    const result = Object.entries(split.model).reduce(\n      (accum: Record<string, any>, [key, val]) => {\n        if (typeof val === \"undefined\") return accum;\n        const mappedProp = getColumnName(model, key);\n        if (this.isReserved(mappedProp))\n          throw new InternalError(`Property name ${mappedProp} is reserved`);\n        accum[mappedProp] = val;\n        return accum;\n      },\n      {}\n    );\n    if ((model as any)[PersistenceKeys.METADATA]) {\n      log.silly(\n        `Passing along persistence metadata for ${(model as any)[PersistenceKeys.METADATA]}`\n      );\n      Object.defineProperty(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        configurable: true,\n        value: (model as any)[PersistenceKeys.METADATA],\n      });\n    }\n\n    return {\n      record: result,\n      id: model[pk] as string,\n      transient: split.transient,\n    };\n  }\n\n  /**\n   * @description Converts database data back into a model instance\n   * @summary Reconstructs a model instance from database data, handling column mapping\n   * and reattaching transient properties\n   * @template M - The model type\n   * @param obj - The database record\n   * @param {string|Constructor<M>} clazz - The model class or name\n   * @param pk - The primary key property name\n   * @param {string|number|bigint} id - The primary key value\n   * @param [transient] - Transient properties to reattach\n   * @return {M} The reconstructed model instance\n   */\n  revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: string | Constructor<M>,\n    pk: keyof M,\n    id: string | number | bigint,\n    transient?: Record<string, any>\n  ): M {\n    const log = this.log.for(this.revert);\n    const ob: Record<string, any> = {};\n    ob[pk as string] = id;\n    const m = (\n      typeof clazz === \"string\" ? Model.build(ob, clazz) : new clazz(ob)\n    ) as M;\n    log.silly(`Rebuilding model ${m.constructor.name} id ${id}`);\n    const metadata = obj[PersistenceKeys.METADATA];\n    const result = Object.keys(m).reduce((accum: M, key) => {\n      if (key === pk) return accum;\n      (accum as Record<string, any>)[key] = obj[getColumnName(accum, key)];\n      return accum;\n    }, m);\n\n    if (transient) {\n      log.verbose(\n        `re-adding transient properties: ${Object.keys(transient).join(\", \")}`\n      );\n      Object.entries(transient).forEach(([key, val]) => {\n        if (key in result)\n          throw new InternalError(\n            `Transient property ${key} already exists on model ${m.constructor.name}. should be impossible`\n          );\n        result[key as keyof M] = val;\n      });\n    }\n\n    if (metadata) {\n      log.silly(\n        `Passing along ${this.flavour} persistence metadata for ${m.constructor.name} id ${id}: ${metadata}`\n      );\n      Object.defineProperty(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        configurable: false,\n        writable: false,\n        value: metadata,\n      });\n    }\n\n    return result;\n  }\n\n  /**\n   * @description Creates a new record in the database\n   * @summary Inserts a new record with the given ID and data into the specified table\n   * @param {string} tableName - The name of the table to insert into\n   * @param {string|number} id - The identifier for the new record\n   * @param model - The data to insert\n   * @param {any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to the created record\n   */\n  abstract create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Creates multiple records in the database\n   * @summary Inserts multiple records with the given IDs and data into the specified table\n   * @param {string} tableName - The name of the table to insert into\n   * @param id - The identifiers for the new records\n   * @param model - The data to insert for each record\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to an array of created records\n   */\n  async createAll(\n    tableName: string,\n    id: (string | number)[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const log = this.log.for(this.createAll);\n    log.verbose(`Creating ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(\n      id.map((i, count) => this.create(tableName, i, model[count], ...args))\n    );\n  }\n\n  /**\n   * @description Retrieves a record from the database\n   * @summary Fetches a record with the given ID from the specified table\n   * @param {string} tableName - The name of the table to read from\n   * @param {string|number|bigint} id - The identifier of the record to retrieve\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to the retrieved record\n   */\n  abstract read(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Retrieves multiple records from the database\n   * @summary Fetches multiple records with the given IDs from the specified table\n   * @param {string} tableName - The name of the table to read from\n   * @param id - The identifiers of the records to retrieve\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to an array of retrieved records\n   */\n  async readAll(\n    tableName: string,\n    id: (string | number | bigint)[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.readAll);\n    log.verbose(`Reading ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(id.map((i) => this.read(tableName, i, ...args)));\n  }\n\n  /**\n   * @description Updates a record in the database\n   * @summary Modifies an existing record with the given ID in the specified table\n   * @param {string} tableName - The name of the table to update\n   * @param {string|number} id - The identifier of the record to update\n   * @param  model - The new data for the record\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to the updated record\n   */\n  abstract update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Updates multiple records in the database\n   * @summary Modifies multiple existing records with the given IDs in the specified table\n   * @param {string} tableName - The name of the table to update\n   * @param {string[]|number[]} id - The identifiers of the records to update\n   * @param model - The new data for each record\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to an array of updated records\n   */\n  async updateAll(\n    tableName: string,\n    id: string[] | number[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const log = this.log.for(this.updateAll);\n    log.verbose(`Updating ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(\n      id.map((i, count) => this.update(tableName, i, model[count], ...args))\n    );\n  }\n\n  /**\n   * @description Deletes a record from the database\n   * @summary Removes a record with the given ID from the specified table\n   * @param {string} tableName - The name of the table to delete from\n   * @param {string|number|bigint} id - The identifier of the record to delete\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to the deleted record\n   */\n  abstract delete(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Deletes multiple records from the database\n   * @summary Removes multiple records with the given IDs from the specified table\n   * @param {string} tableName - The name of the table to delete from\n   * @param id - The identifiers of the records to delete\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to an array of deleted records\n   */\n  async deleteAll(\n    tableName: string,\n    id: (string | number | bigint)[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.createAll);\n    log.verbose(`Deleting ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(id.map((i) => this.delete(tableName, i, ...args)));\n  }\n\n  /**\n   * @description Executes a raw query against the database\n   * @summary Allows executing database-specific queries directly\n   * @template Q - The raw query type\n   * @template R - The return type of the query\n   * @param {Q} rawInput - The query to execute\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return {Promise<R>} A promise that resolves to the query result\n   */\n  abstract raw<R>(rawInput: QUERY, ...args: any[]): Promise<R>;\n\n  /**\n   * @description Registers an observer for database events\n   * @summary Adds an observer to be notified about database changes. The observer can optionally\n   * provide a filter function to receive only specific events.\n   * @param {Observer} observer - The observer to register\n   * @param {ObserverFilter} [filter] - Optional filter function to determine which events the observer receives\n   * @return {void}\n   */\n  @final()\n  observe(observer: Observer, filter?: ObserverFilter): void {\n    if (!this.observerHandler)\n      Object.defineProperty(this, \"observerHandler\", {\n        value: this.ObserverHandler(),\n        writable: false,\n      });\n    this.observerHandler!.observe(observer, filter);\n    this.log\n      .for(this.observe)\n      .verbose(`Registering new observer ${observer.toString()}`);\n    if (!this.dispatch) {\n      this.log.for(this.observe).info(`Creating dispatch for ${this.alias}`);\n      this.dispatch = this.Dispatch();\n      this.dispatch.observe(this);\n    }\n  }\n\n  /**\n   * @description Unregisters an observer\n   * @summary Removes a previously registered observer so it no longer receives database event notifications\n   * @param {Observer} observer - The observer to unregister\n   * @return {void}\n   */\n  @final()\n  unObserve(observer: Observer): void {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    this.observerHandler.unObserve(observer);\n    this.log\n      .for(this.unObserve)\n      .verbose(`Observer ${observer.toString()} removed`);\n  }\n\n  /**\n   * @description Notifies all observers about a database event\n   * @summary Sends notifications to all registered observers about a change in the database,\n   * filtering based on each observer's filter function\n   * @param {string} table - The name of the table where the change occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {EventIds} id - The identifier(s) of the affected record(s)\n   * @param {...any[]} args - Additional arguments to pass to the observers\n   * @return {Promise<void>} A promise that resolves when all observers have been notified\n   */\n  async updateObservers(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ): Promise<void> {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    const log = this.log.for(this.updateObservers);\n    log.verbose(\n      `Updating ${this.observerHandler.count()} observers for adapter ${this.alias}`\n    );\n    await this.observerHandler.updateObservers(\n      this.log,\n      table,\n      event,\n      id,\n      ...args\n    );\n  }\n\n  /**\n   * @description Refreshes data based on a database event\n   * @summary Implementation of the Observer interface method that delegates to updateObservers\n   * @param {string} table - The name of the table where the change occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {EventIds} id - The identifier(s) of the affected record(s)\n   * @param {...any[]} args - Additional arguments related to the event\n   * @return {Promise<void>} A promise that resolves when the refresh is complete\n   */\n  async refresh(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ) {\n    return this.updateObservers(table, event, id, ...args);\n  }\n\n  /**\n   * @description Gets a string representation of the adapter\n   * @summary Returns a human-readable string identifying this adapter\n   * @return {string} A string representation of the adapter\n   */\n  override toString() {\n    return `${this.flavour} persistence Adapter`;\n  }\n\n  /**\n   * @description Gets the adapter flavor associated with a model\n   * @summary Retrieves the adapter flavor that should be used for a specific model class\n   * @template M - The model type\n   * @param {Constructor<M>} model - The model constructor\n   * @return {string} The adapter flavor name\n   */\n  static flavourOf<M extends Model>(model: Constructor<M>): string {\n    return (\n      Reflect.getMetadata(this.key(PersistenceKeys.ADAPTER), model) ||\n      this.current?.flavour\n    );\n  }\n\n  static get currentFlavour() {\n    if (!Adapter._currentFlavour)\n      throw new InternalError(\n        `No persistence flavour set. Please initialize your adapter`\n      );\n    return Adapter._currentFlavour;\n  }\n\n  /**\n   * @description Gets the current default adapter\n   * @summary Retrieves the adapter that is currently set as the default for operations\n   * @return {Adapter<any, any, any, any>} The current adapter\n   */\n  static get current(): Adapter<any, any, any, any> | undefined {\n    return Adapter.get(this.currentFlavour);\n  }\n\n  /**\n   * @description Gets an adapter by flavor\n   * @summary Retrieves a registered adapter by its flavor name\n   * @template CONF - The database driver config\n   * @template CONN - The database driver instance\n   * @template QUERY - The query type\n   * @template CCONTEXT - The context type\n   * @template FLAGS - The repository flags type\n   * @param {string} flavour - The flavor name of the adapter to retrieve\n   * @return {Adapter<CONF, CONN, QUERY, CONTEXT, FLAGS> | undefined} The adapter instance or undefined if not found\n   */\n  static get<\n    CONF,\n    CONN,\n    QUERY,\n    CONTEXT extends Context<FLAGS>,\n    FLAGS extends RepositoryFlags,\n  >(flavour?: any): Adapter<CONF, CONN, QUERY, FLAGS, CONTEXT> | undefined {\n    if (!flavour) return Adapter.get(this._currentFlavour);\n    if (flavour in this._cache) return this._cache[flavour];\n    throw new InternalError(`No Adapter registered under ${flavour}.`);\n  }\n\n  /**\n   * @description Sets the current default adapter\n   * @summary Changes which adapter is used as the default for operations\n   * @param {string} flavour - The flavor name of the adapter to set as current\n   * @return {void}\n   */\n  static setCurrent(flavour: string): void {\n    this._currentFlavour = flavour;\n  }\n\n  /**\n   * @description Creates a metadata key\n   * @summary Generates a standardized metadata key for persistence-related metadata\n   * @param {string} key - The base key name\n   * @return {string} The formatted metadata key\n   */\n  static key(key: string) {\n    return Repo.key(key);\n  }\n\n  /**\n   * @description Gets all models associated with an adapter flavor\n   * @summary Retrieves all model constructors that are configured to use a specific adapter flavor\n   * @template M - The model type\n   * @param {string} flavour - The adapter flavor to find models for\n   * @return An array of model constructors\n   */\n  static models<M extends Model>(flavour: string) {\n    try {\n      const registry = (Model as any).getRegistry() as ModelRegistry<any>;\n      const cache = (\n        registry as unknown as { cache: Record<string, ModelConstructor<any>> }\n      ).cache;\n      const managedModels: ModelConstructor<any>[] = Object.values(cache)\n        .map((m: ModelConstructor<M>) => {\n          let f = Reflect.getMetadata(\n            Adapter.key(PersistenceKeys.ADAPTER),\n            m as ModelConstructor<any>\n          );\n          if (f && f === flavour) return m;\n          if (!f) {\n            const repo = Reflect.getMetadata(\n              Repo.key(DBKeys.REPOSITORY),\n              m as ModelConstructor<any>\n            );\n            if (!repo) return;\n            const repository = (this._baseRepository as any).forModel(m);\n\n            f = Reflect.getMetadata(\n              Adapter.key(PersistenceKeys.ADAPTER),\n              repository\n            );\n            return f;\n          }\n        })\n        .filter((m) => !!m);\n      return managedModels;\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n\n  static decoration(): void {}\n\n  protected proxies?: Record<string, typeof this>;\n\n  /**\n   * @description Returns the client instance for the adapter\n   * @summary This method should be overridden by subclasses to return the client instance for the adapter.\n   * @template CON - The type of the client instance\n   * @return {CON} The client instance for the adapter\n   * @abstract\n   * @function getClient\n   * @memberOf module:core\n   * @instance\n   * @protected\n   */\n  protected abstract getClient(): CONN;\n\n  @final()\n  get client(): CONN {\n    if (!this._client) {\n      this._client = this.getClient();\n    }\n    return this._client;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  for(config: Partial<CONF>, ...args: any[]): typeof this {\n    if (!this.proxies) this.proxies = {};\n    const key = `${this.alias} - ${hashObj(config)}`;\n    if (key in this.proxies) return this.proxies[key] as typeof this;\n\n    let client: any;\n    const proxy = new Proxy(this, {\n      get: (target: typeof this, p: string | symbol, receiver: any) => {\n        if (p === \"_config\") {\n          const originalConf: CONF = Reflect.get(target, p, receiver);\n          return Object.assign({}, originalConf, config);\n        }\n        if (p === \"_client\") {\n          return client;\n        }\n        return Reflect.get(target, p, receiver);\n      },\n      set: (target: any, p: string | symbol, value: any, receiver: any) => {\n        if (p === \"_client\") {\n          client = value;\n          return true;\n        }\n        return Reflect.set(target, p, value, receiver);\n      },\n    });\n    this.proxies[key] = proxy;\n    return proxy;\n  }\n}\n","import { CascadeMetadata } from \"./types\";\n\n/**\n * @description Enumeration of possible sort directions.\n * @summary Defines the available sort directions for ordering query results.\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum OrderDirection {\n  /** Ascending order (A to Z, 0 to 9) */\n  ASC = \"asc\",\n\n  /** Descending order (Z to A, 9 to 0) */\n  DSC = \"desc\",\n}\n\n/**\n * @description Enumeration of cascade operation types.\n * @summary Defines the available cascade behaviors for entity relationships.\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum Cascade {\n  /** Perform cascade operation on related entities */\n  CASCADE = \"cascade\",\n  /** Do not perform cascade operation on related entities */\n  NONE = \"none\",\n}\n\n/**\n * @description Shape of the default cascade configuration object used in repositories.\n * @summary Documents the structure of the cascade configuration with explicit update and delete behaviors.\n * @property {'cascade'|'none'} update - Determines whether updates cascade to related entities.\n * @property {'cascade'|'none'} delete - Determines whether deletes cascade to related entities.\n * @typeDef DefaultCascadeConfig\n * @memberOf module:core\n */\nexport const DefaultCascade: CascadeMetadata = {\n  update: Cascade.CASCADE,\n  delete: Cascade.NONE,\n};\n","import { InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Error thrown when an unsupported operation is attempted\n * @summary This error is thrown when an operation is requested that is not supported by the current\n * persistence adapter or configuration. It extends the BaseError class and sets a 500 status code.\n * @param {string|Error} msg - The error message or an Error object to wrap\n * @class UnsupportedError\n * @example\n * ```typescript\n * // Throwing an UnsupportedError\n * if (!adapter.supportsTransactions()) {\n *   throw new UnsupportedError('Transactions are not supported by this adapter');\n * }\n *\n * // Catching an UnsupportedError\n * try {\n *   await adapter.beginTransaction();\n * } catch (error) {\n *   if (error instanceof UnsupportedError) {\n *     console.error('Operation not supported:', error.message);\n *   }\n * }\n * ```\n */\nexport class UnsupportedError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, UnsupportedError.name, 500);\n  }\n}\n","import { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { sequenceNameForModel } from \"../identity/utils\";\nimport { SequenceOptions } from \"../interfaces/SequenceOptions\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\nimport { UnsupportedError } from \"./errors\";\n\n/**\n * @description Abstract base class for sequence generation\n * @summary Provides a framework for generating sequential values (like primary keys) in the persistence layer.\n * Implementations of this class handle the specifics of how sequences are stored and incremented in different\n * database systems.\n * @param {SequenceOptions} options - Configuration options for the sequence generator\n * @class Sequence\n * @example\n * ```typescript\n * // Example implementation for a specific database\n * class PostgresSequence extends Sequence {\n *   constructor(options: SequenceOptions) {\n *     super(options);\n *   }\n *\n *   async next(): Promise<number> {\n *     // Implementation to get next value from PostgreSQL sequence\n *     const result = await this.options.executor.raw(`SELECT nextval('${this.options.name}')`);\n *     return parseInt(result.rows[0].nextval);\n *   }\n *\n *   async current(): Promise<number> {\n *     // Implementation to get current value from PostgreSQL sequence\n *     const result = await this.options.executor.raw(`SELECT currval('${this.options.name}')`);\n *     return parseInt(result.rows[0].currval);\n *   }\n *\n *   async range(count: number): Promise<number[]> {\n *     // Implementation to get a range of values\n *     const values: number[] = [];\n *     for (let i = 0; i < count; i++) {\n *       values.push(await this.next());\n *     }\n *     return values;\n *   }\n * }\n *\n * // Usage\n * const sequence = new PostgresSequence({\n *   name: 'user_id_seq',\n *   executor: dbExecutor\n * });\n *\n * const nextId = await sequence.next();\n * ```\n */\nexport abstract class Sequence {\n  /**\n   * @description Logger instance for this sequence\n   * @summary Lazily initialized logger for the sequence instance\n   */\n  private logger!: Logger;\n\n  /**\n   * @description Accessor for the logger instance\n   * @summary Gets or initializes the logger for this sequence\n   * @return {Logger} The logger instance\n   */\n  protected get log(): Logger {\n    if (!this.logger) this.logger = Logging.for(this as any);\n    return this.logger;\n  }\n\n  /**\n   * @description Creates a new sequence instance\n   * @summary Protected constructor that initializes the sequence with the provided options\n   */\n  protected constructor(protected readonly options: SequenceOptions) {}\n\n  /**\n   * @description Gets the next value in the sequence\n   * @summary Retrieves the next value from the sequence, incrementing it in the process\n   * @return A promise that resolves to the next value in the sequence\n   */\n  abstract next(): Promise<string | number | bigint>;\n\n  /**\n   * @description Gets the current value of the sequence\n   * @summary Retrieves the current value of the sequence without incrementing it\n   * @return A promise that resolves to the current value in the sequence\n   */\n  abstract current(): Promise<string | number | bigint>;\n\n  /**\n   * @description Gets a range of sequential values\n   * @summary Retrieves multiple sequential values at once, which can be more efficient than calling next() multiple times\n   * @param {number} count - The number of sequential values to retrieve\n   * @return A promise that resolves to an array of sequential values\n   */\n  abstract range(count: number): Promise<(number | string | bigint)[]>;\n\n  /**\n   * @description Gets the primary key sequence name for a model\n   * @summary Utility method that returns the standardized sequence name for a model's primary key\n   * @template M - The model type\n   * @param {M|Constructor<M>} model - The model instance or constructor\n   * @return {string} The sequence name for the model's primary key\n   */\n  static pk<M extends Model>(model: M | Constructor<M>) {\n    return sequenceNameForModel(model, \"pk\");\n  }\n\n  /**\n   * @description Parses a sequence value to the appropriate type\n   * @summary Converts a sequence value to the specified type (Number or BigInt)\n   * @param {\"Number\"|\"BigInt\"|undefined} type - The target type to convert to\n   * @param {string|number|bigint} value - The value to convert\n   * @return {string|number|bigint} The converted value\n   */\n  static parseValue(\n    type: \"Number\" | \"BigInt\" | string | undefined,\n    value: string | number | bigint\n  ): string | number | bigint {\n    switch (type) {\n      case \"Number\":\n        return typeof value === \"string\"\n          ? parseInt(value)\n          : typeof value === \"number\"\n            ? value\n            : BigInt(value);\n      case \"BigInt\":\n        return BigInt(value);\n      case undefined:\n      case \"String\":\n        return value;\n      default:\n        throw new UnsupportedError(\n          `Unsupported sequence type: ${type} for adapter ${this}`\n        );\n    }\n  }\n}\n","/**\n * @description Comparison operators for query conditions\n * @summary Enum defining the available operators for comparing values in database queries\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum Operator {\n  /** Equal comparison (=) */\n  EQUAL = \"EQUAL\",\n  /** Not equal comparison (!=) */\n  DIFFERENT = \"DIFFERENT\",\n  /** Greater than comparison (>) */\n  BIGGER = \"BIGGER\",\n  /** Greater than or equal comparison (>=) */\n  BIGGER_EQ = \"BIGGER_EQ\",\n  /** Less than comparison (<) */\n  SMALLER = \"SMALLER\",\n  /** Less than or equal comparison (<=) */\n  SMALLER_EQ = \"SMALLER_EQ\",\n  // BETWEEN = \"BETWEEN\",\n  /** Negation operator (NOT) */\n  NOT = \"NOT\",\n  /** Inclusion operator (IN) */\n  IN = \"IN\",\n  // IS = \"IS\",\n  /** Regular expression matching */\n  REGEXP = \"REGEXP\",\n}\n\n/**\n * @description Logical operators for combining query conditions\n * @summary Enum defining the available operators for grouping multiple conditions in database queries\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum GroupOperator {\n  /** Logical AND operator - all conditions must be true */\n  AND = \"AND\",\n  /** Logical OR operator - at least one condition must be true */\n  OR = \"OR\",\n}\n","import { InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Error thrown during query operations\n * @summary Represents errors that occur during query building or execution\n * @param {string | Error} msg - The error message or Error object\n * @class QueryError\n * @category Errors\n */\nexport class QueryError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, QueryError.name, 500);\n  }\n}\n\n/**\n * @description Error thrown during pagination operations\n * @summary Represents errors that occur during pagination setup or execution\n * @param {string | Error} msg - The error message or Error object\n * @class PagingError\n * @category Errors\n */\nexport class PagingError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, PagingError.name, 500);\n  }\n}\n","import { AttributeOption, ConditionBuilderOption } from \"./options\";\nimport {\n  ConditionalAsync,\n  Model,\n  ModelErrorDefinition,\n  required,\n} from \"@decaf-ts/decorator-validation\";\nimport { GroupOperator, Operator } from \"./constants\";\nimport { QueryError } from \"./errors\";\n\ntype InferAsync<M> = M extends Model<infer A> ? A : false;\n\n/**\n * @description Represents a logical condition for database queries\n * @summary A class that encapsulates query conditions with support for complex logical operations.\n * This class allows for building and combining query conditions using logical operators (AND, OR, NOT)\n * and comparison operators (equals, not equals, greater than, etc.).\n * @template M - The model type this condition operates on\n * @param {string | Condition<M>} attr1 - The attribute name or a nested condition\n * @param {Operator | GroupOperator} operator - The operator to use for the condition\n * @param {any} comparison - The value to compare against or another condition\n * @class Condition\n * @example\n * // Create a simple condition\n * const nameCondition = Condition.attribute(\"name\").eq(\"John\");\n *\n * // Create a complex condition\n * const complexCondition = Condition.attribute(\"age\").gt(18)\n *   .and(Condition.attribute(\"status\").eq(\"active\"));\n *\n * // Use the builder pattern\n * const userQuery = Condition.builder()\n *   .attribute(\"email\").regexp(\".*@example.com\")\n *   .and(Condition.attribute(\"lastLogin\").gt(new Date(\"2023-01-01\")));\n * @mermaid\n * sequenceDiagram\n *   participant Dev\n *   participant Condition\n *   Dev->>Condition: builder().attribute(\"age\").gt(18)\n *   Condition-->>Dev: Condition(age > 18)\n *   Dev->>Condition: .and(attribute(\"status\").eq(\"active\"))\n *   Condition-->>Dev: Condition((age > 18) AND (status = \"active\"))\n */\nexport class Condition<M extends Model<any>> extends Model<InferAsync<M>> {\n  @required()\n  protected attr1?: string | Condition<M> = undefined;\n  @required()\n  protected operator?: Operator | GroupOperator = undefined;\n  @required()\n  protected comparison?: any = undefined;\n\n  private constructor(\n    attr1: string | Condition<M>,\n    operator: Operator | GroupOperator,\n    comparison: any\n  ) {\n    super();\n    this.attr1 = attr1;\n    this.operator = operator;\n    this.comparison = comparison;\n  }\n\n  /**\n   * @description Combines this condition with another using logical AND\n   * @summary Joins two conditions with an AND operator, requiring both to be true\n   * @param {Condition<M>} condition - The condition to combine with this one\n   * @return {Condition<M>} A new condition representing the AND operation\n   */\n  and(condition: Condition<M>): Condition<M> {\n    return Condition.and(this, condition);\n  }\n\n  /**\n   * @description Combines this condition with another using logical OR\n   * @summary Joins two conditions with an OR operator, requiring at least one to be true\n   * @param {Condition<M>} condition - The condition to combine with this one\n   * @return {Condition<M>} A new condition representing the OR operation\n   */\n  or(condition: Condition<M>): Condition<M> {\n    return Condition.or(this, condition);\n  }\n\n  /**\n   * @description Creates a negation condition\n   * @summary Excludes a value from the result by applying a NOT operator\n   * @param {any} val - The value to negate\n   * @return {Condition<M>} A new condition representing the NOT operation\n   */\n  not(val: any): Condition<M> {\n    return new Condition(this, Operator.NOT, val);\n  }\n\n  /**\n   * @description Validates the condition and checks for errors\n   * @summary Extends the base validation to ensure the condition is properly formed\n   * @param {...string[]} exceptions - Fields to exclude from validation\n   * @return {ModelErrorDefinition | undefined} Error definition if validation fails, undefined otherwise\n   */\n  override hasErrors(\n    ...exceptions: string[]\n  ): ConditionalAsync<InferAsync<M>, ModelErrorDefinition | undefined> {\n    const conditionCheck = (): ModelErrorDefinition | undefined => {\n      const invalidOpMessage = `Invalid operator ${this.operator}}`;\n\n      if (typeof this.attr1 === \"string\") {\n        if (this.comparison instanceof Condition)\n          return {\n            comparison: {\n              condition:\n                \"Both sides of the comparison must be of the same type\",\n            },\n          } as ModelErrorDefinition;\n        if (Object.values(Operator).indexOf(this.operator as Operator) === -1)\n          return {\n            operator: {\n              condition: invalidOpMessage,\n            },\n          } as ModelErrorDefinition;\n      }\n\n      if (this.attr1 instanceof Condition) {\n        if (\n          !(this.comparison instanceof Condition) &&\n          this.operator !== Operator.NOT\n        )\n          return {\n            comparison: {\n              condition: invalidOpMessage,\n            },\n          } as ModelErrorDefinition;\n        if (\n          Object.values(GroupOperator).indexOf(\n            this.operator as GroupOperator\n          ) === -1 &&\n          this.operator !== Operator.NOT\n        )\n          return {\n            operator: {\n              condition: invalidOpMessage,\n            },\n          } as ModelErrorDefinition;\n      }\n    };\n\n    const errors = super.hasErrors(...exceptions);\n    if (!this.isAsync())\n      return (\n        (errors as ModelErrorDefinition | undefined) ??\n        (conditionCheck() as any)\n      );\n\n    return (async () => {\n      const resolved = await Promise.resolve(\n        errors as unknown as Promise<ModelErrorDefinition | undefined>\n      );\n      return resolved ?? conditionCheck();\n    })() as ConditionalAsync<InferAsync<M>, ModelErrorDefinition | undefined>;\n  }\n\n  /**\n   * @description Creates a new condition that combines two conditions with logical AND\n   * @summary Static method that joins two conditions with an AND operator, requiring both to be true\n   * @template M - The model type this condition operates on\n   * @param {Condition<M>} condition1 - The first condition\n   * @param {Condition<M>} condition2 - The second condition\n   * @return {Condition<M>} A new condition representing the AND operation\n   */\n  static and<M extends Model>(\n    condition1: Condition<M>,\n    condition2: Condition<M>\n  ): Condition<M> {\n    return Condition.group(condition1, GroupOperator.AND, condition2);\n  }\n\n  /**\n   * @description Creates a new condition that combines two conditions with logical OR\n   * @summary Static method that joins two conditions with an OR operator, requiring at least one to be true\n   * @template M - The model type this condition operates on\n   * @param {Condition<M>} condition1 - The first condition\n   * @param {Condition<M>} condition2 - The second condition\n   * @return {Condition<M>} A new condition representing the OR operation\n   */\n  static or<M extends Model>(\n    condition1: Condition<M>,\n    condition2: Condition<M>\n  ): Condition<M> {\n    return Condition.group(condition1, GroupOperator.OR, condition2);\n  }\n\n  /**\n   * @description Creates a new condition that groups two conditions with a specified operator\n   * @summary Private static method that combines two conditions using the specified group operator\n   * @template M - The model type this condition operates on\n   * @param {Condition<M>} condition1 - The first condition\n   * @param {GroupOperator} operator - The group operator to use (AND, OR)\n   * @param {Condition<M>} condition2 - The second condition\n   * @return {Condition<M>} A new condition representing the grouped operation\n   */\n  private static group<M extends Model>(\n    condition1: Condition<M>,\n    operator: GroupOperator,\n    condition2: Condition<M>\n  ): Condition<M> {\n    return new Condition(condition1, operator, condition2);\n  }\n\n  /**\n   * @description Creates a condition builder for a specific model attribute\n   * @summary Static method that initializes a condition builder with the specified attribute\n   * @template M - The model type this condition operates on\n   * @param attr - The model attribute to build a condition for\n   * @return {AttributeOption<M>} A condition builder initialized with the attribute\n   */\n  static attribute<M extends Model>(attr: keyof M) {\n    return new Condition.Builder<M>().attribute(attr);\n  }\n\n  /**\n   * @description Alias for the attribute method\n   * @summary Shorthand method that initializes a condition builder with the specified attribute\n   * @template M - The model type this condition operates on\n   * @param attr - The model attribute to build a condition for\n   * @return {AttributeOption<M>} A condition builder initialized with the attribute\n   */\n  static attr<M extends Model>(attr: keyof M) {\n    return this.attribute(attr);\n  }\n\n  /**\n   * @description Provides a fluent API to build query conditions\n   * @summary A builder class that simplifies the creation of database query conditions\n   * with a chainable interface for setting attributes and operators\n   * @template M - The model type this condition builder operates on\n   * @class ConditionBuilder\n   */\n  private static Builder = class ConditionBuilder<M extends Model>\n    implements ConditionBuilderOption<M>, AttributeOption<M>\n  {\n    attr1?: keyof M | Condition<M> = undefined;\n    operator?: Operator | GroupOperator = undefined;\n    comparison?: any = undefined;\n\n    /**\n     * @description Sets the attribute for the condition\n     * @summary Specifies which model attribute the condition will operate on\n     * @param attr - The model attribute to use in the condition\n     * @return {AttributeOption<M>} This builder instance for method chaining\n     */\n    attribute(attr: keyof M): AttributeOption<M> {\n      this.attr1 = attr;\n      return this;\n    }\n\n    /**\n     * @description Alias for the attribute method\n     * @summary Shorthand method to specify which model attribute the condition will operate on\n     * @param attr - The model attribute to use in the condition\n     * @return {AttributeOption<M>} This builder instance for method chaining\n     */\n    attr(attr: keyof M) {\n      return this.attribute(attr);\n    }\n\n    /**\n     * @description Creates an equality condition\n     * @summary Builds a condition that checks if the attribute equals the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the equality comparison\n     */\n    eq(val: any) {\n      return this.setOp(Operator.EQUAL, val);\n    }\n\n    /**\n     * @description Creates an inequality condition\n     * @summary Builds a condition that checks if the attribute is different from the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the inequality comparison\n     */\n    dif(val: any) {\n      return this.setOp(Operator.DIFFERENT, val);\n    }\n\n    /**\n     * @description Creates a greater than condition\n     * @summary Builds a condition that checks if the attribute is greater than the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the greater than comparison\n     */\n    gt(val: any) {\n      return this.setOp(Operator.BIGGER, val);\n    }\n\n    /**\n     * @description Creates a less than condition\n     * @summary Builds a condition that checks if the attribute is less than the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the less than comparison\n     */\n    lt(val: any) {\n      return this.setOp(Operator.SMALLER, val);\n    }\n\n    /**\n     * @description Creates a greater than or equal to condition\n     * @summary Builds a condition that checks if the attribute is greater than or equal to the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the greater than or equal comparison\n     */\n    gte(val: any) {\n      return this.setOp(Operator.BIGGER_EQ, val);\n    }\n\n    /**\n     * @description Creates a less than or equal to condition\n     * @summary Builds a condition that checks if the attribute is less than or equal to the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the less than or equal comparison\n     */\n    lte(val: any) {\n      return this.setOp(Operator.SMALLER_EQ, val);\n    }\n\n    /**\n     * @description Creates an inclusion condition\n     * @summary Builds a condition that checks if the attribute value is included in the specified array\n     * @param {any[]} arr - The array of values to check against\n     * @return {Condition<M>} A new condition representing the inclusion comparison\n     */\n    in(arr: any[]) {\n      return this.setOp(Operator.IN, arr);\n    }\n\n    /**\n     * @description Creates a regular expression condition\n     * @summary Builds a condition that checks if the attribute matches the specified regular expression pattern\n     * @param {any} val - The regular expression pattern to match against\n     * @return {Condition<M>} A new condition representing the regular expression comparison\n     */\n    regexp(val: any) {\n      return this.setOp(Operator.REGEXP, new RegExp(val).source);\n    }\n\n    /**\n     * @description Sets the operator and comparison value for the condition\n     * @summary Private method that configures the condition with the specified operator and value\n     * @param {Operator} op - The operator to use for the condition\n     * @param {any} val - The value to compare against\n     * @return {Condition<M>} A new condition with the specified operator and value\n     */\n    private setOp(op: Operator, val: any) {\n      this.operator = op;\n      this.comparison = val;\n      return this.build();\n    }\n\n    /**\n     * @description Constructs a Condition instance from the builder's state\n     * @summary Finalizes the condition building process by creating a new Condition instance\n     * @throws {QueryError} If the condition cannot be built due to invalid parameters\n     * @return {Condition<M>} A new condition instance with the configured attributes\n     */\n    private build(): Condition<M> {\n      try {\n        return new Condition(\n          this.attr1 as string | Condition<M>,\n          this.operator as Operator,\n          this.comparison as any\n        );\n      } catch (e: any) {\n        throw new QueryError(e);\n      }\n    }\n  };\n\n  /**\n   * @description Creates a new condition builder\n   * @summary Factory method that returns a new instance of the condition builder\n   * @template M - The model type this condition builder will operate on\n   * @return {ConditionBuilderOption<M>} A new condition builder instance\n   */\n  static builder<M extends Model>(): ConditionBuilderOption<M> {\n    return new Condition.Builder<M>();\n  }\n}\n","import { apply, metadata } from \"@decaf-ts/reflection\";\nimport { PersistenceKeys } from \"./constants\";\nimport { Adapter } from \"./Adapter\";\n\n/**\n * @description Specifies which persistence adapter flavor a model should use\n * @summary This decorator applies metadata to a model class to indicate which persistence adapter flavor\n * should be used when performing database operations on instances of the model. The flavor is a string\n * identifier that corresponds to a registered adapter configuration.\n * @param {string} flavour - The identifier of the adapter flavor to use\n * @return {Function} A decorator function that can be applied to a model class\n * @function uses\n * @category Class Decorators\n */\nexport function uses(flavour: string) {\n  return function uses(original: any) {\n    return apply(metadata(Adapter.key(PersistenceKeys.ADAPTER), flavour))(\n      original\n    );\n  };\n}\n","import {\n  BulkCrudOperationKeys,\n  Context,\n  DBKeys,\n  DefaultSeparator,\n  enforceDBDecorators,\n  findPrimaryKey,\n  InternalError,\n  IRepository,\n  OperationKeys,\n  Repository as Rep,\n  RepositoryFlags,\n  ValidationError,\n  wrapMethodWithContext,\n} from \"@decaf-ts/db-decorators\";\nimport { Observable } from \"../interfaces/Observable\";\nimport { type Observer } from \"../interfaces/Observer\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { OrderDirection } from \"./constants\";\nimport { SequenceOptions } from \"../interfaces/SequenceOptions\";\nimport { Queriable } from \"../interfaces/Queriable\";\nimport { Reflection } from \"@decaf-ts/reflection\";\nimport { IndexMetadata } from \"./types\";\nimport { Sequence } from \"../persistence/Sequence\";\nimport { Condition } from \"../query/Condition\";\nimport { WhereOption } from \"../query/options\";\nimport { OrderBySelector, SelectSelector } from \"../query/selectors\";\nimport { getColumnName, getTableName } from \"../identity/utils\";\nimport { uses } from \"../persistence/decorators\";\nimport { Logger } from \"@decaf-ts/logging\";\nimport { ObserverHandler } from \"../persistence/ObserverHandler\";\nimport { final } from \"../utils\";\nimport {\n  EventIds,\n  InferredAdapterConfig,\n  type ObserverFilter,\n} from \"../persistence\";\n\n/**\n * @description Type alias for Repository class with simplified generic parameters.\n * @summary Provides a more concise way to reference the Repository class with its generic parameters.\n * @template M - The model type that extends Model.\n * @template F - The repository flags type.\n * @template C - The context type.\n * @template Q - The query type.\n * @template A - The adapter type.\n * @typedef Repo\n * @memberOf module:core\n */\nexport type Repo<\n  M extends Model<boolean>,\n  F extends RepositoryFlags = any,\n  C extends Context<F> = any,\n  Q = any,\n  A extends Adapter<any, any, Q, F, C> = any,\n> = Repository<M, Q, A, F, C>;\n\n/**\n * @description Core repository implementation for database operations on models on a table by table way.\n * @summary Provides CRUD operations, querying capabilities, and observer pattern implementation for model persistence.\n * @template M - The model type that extends Model.\n * @template Q - The query type used by the adapter.\n * @template A - The adapter type for database operations.\n * @template F - The repository flags type.\n * @template C - The context type for operations.\n * @param {A} [adapter] - Optional adapter instance for database operations.\n * @param {Constructor<M>} [clazz] - Optional constructor for the model class.\n * @param {...any[]} [args] - Additional arguments for repository initialization.\n * @class Repository\n * @example\n * // Creating a repository for User model\n * const userRepo = Repository.forModel(User);\n *\n * // Using the repository for CRUD operations\n * const user = await userRepo.create(new User({ name: 'John' }));\n * const retrievedUser = await userRepo.read(user.id);\n * user.name = 'Jane';\n * await userRepo.update(user);\n * await userRepo.delete(user.id);\n *\n * // Querying with conditions\n * const users = await userRepo\n *   .select()\n *   .where({ name: 'Jane' })\n *   .orderBy('createdAt', OrderDirection.DSC)\n *   .limit(10)\n *   .execute();\n * @mermaid\n * sequenceDiagram\n *   participant C as Client Code\n *   participant R as Repository\n *   participant A as Adapter\n *   participant DB as Database\n *   participant O as Observers\n *\n *   C->>+R: create(model)\n *   R->>R: createPrefix(model)\n *   R->>+A: prepare(model)\n *   A-->>-R: prepared data\n *   R->>+A: create(table, id, record)\n *   A->>+DB: Insert Operation\n *   DB-->>-A: Result\n *   A-->>-R: record\n *   R->>+A: revert(record)\n *   A-->>-R: model instance\n *   R->>R: createSuffix(model)\n *   R->>+O: updateObservers(table, CREATE, id)\n *   O-->>-R: Notification complete\n *   R-->>-C: created model\n */\nexport class Repository<\n    M extends Model<boolean>,\n    Q,\n    A extends Adapter<any, any, Q, F, C>,\n    F extends RepositoryFlags = RepositoryFlags,\n    C extends Context<F> = Context<F>,\n  >\n  extends Rep<M, F, C>\n  implements Observable, Observer, Queriable<M>, IRepository<M, F, C>\n{\n  private static _cache: Record<\n    string,\n    Constructor<Repo<Model>> | Repo<Model>\n  > = {};\n\n  protected observers: Observer[] = [];\n\n  protected observerHandler?: ObserverHandler;\n\n  private readonly _adapter!: A;\n  private _tableName!: string;\n  protected _overrides?: Partial<F>;\n\n  private logger!: Logger;\n\n  /**\n   * @description Logger instance for this repository.\n   * @summary Provides access to the logger for this repository instance.\n   * @return {Logger} The logger instance.\n   */\n  get log(): Logger {\n    if (!this.logger)\n      this.logger = (\n        this.adapter[\"log\" as keyof typeof this.adapter] as Logger\n      ).for(this.toString());\n    return this.logger;\n  }\n\n  /**\n   * @description Adapter for database operations.\n   * @summary Provides access to the adapter instance for this repository.\n   * @template A - The adapter type.\n   * @return {A} The adapter instance.\n   * @throws {InternalError} If no adapter is found.\n   */\n  protected get adapter(): A {\n    if (!this._adapter)\n      throw new InternalError(\n        `No adapter found for this repository. did you use the @uses decorator or pass it in the constructor?`\n      );\n    return this._adapter;\n  }\n\n  /**\n   * @description Table name for this repository's model.\n   * @summary Gets the database table name associated with this repository's model.\n   * @return {string} The table name.\n   */\n  protected get tableName(): string {\n    if (!this._tableName) this._tableName = Repository.table(this.class);\n    return this._tableName;\n  }\n\n  /**\n   * @description Primary key properties for this repository's model.\n   * @summary Gets the sequence options containing primary key information.\n   * @return {SequenceOptions} The primary key properties.\n   */\n  protected override get pkProps(): SequenceOptions {\n    return super.pkProps;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  constructor(adapter?: A, clazz?: Constructor<M>, ...args: any[]) {\n    super(clazz);\n    if (adapter) this._adapter = adapter;\n    if (clazz) {\n      Repository.register(clazz, this, this.adapter.alias);\n      if (adapter) {\n        const flavour = Reflect.getMetadata(\n          Adapter.key(PersistenceKeys.ADAPTER),\n          clazz\n        );\n        if (flavour && flavour !== adapter.flavour)\n          throw new InternalError(\"Incompatible flavours\");\n        uses(adapter.flavour)(clazz);\n      }\n    }\n    [this.createAll, this.readAll, this.updateAll, this.deleteAll].forEach(\n      (m) => {\n        const name = m.name;\n        wrapMethodWithContext(\n          this,\n          (this as any)[name + \"Prefix\"],\n          m,\n          (this as any)[name + \"Suffix\"]\n        );\n      }\n    );\n  }\n\n  /**\n   * @description Creates a proxy with overridden repository flags.\n   * @summary Returns a proxy of this repository with the specified flags overridden.\n   * @param {Partial<F>} flags - The flags to override.\n   * @return {Repository} A proxy of this repository with overridden flags.\n   */\n  override(flags: Partial<F>): Repository<M, Q, A, F, C> {\n    this.log\n      .for(this.override)\n      .debug(`Overriding repository flags with ${JSON.stringify(flags)}`);\n    return new Proxy(this, {\n      get: (target: typeof this, p: string | symbol, receiver: any) => {\n        const result = Reflect.get(target, p, receiver);\n        if (p !== \"_overrides\") return result;\n        return Object.assign({}, result, flags);\n      },\n    });\n  }\n\n  /**\n   * @description Creates a new instance of the Repository class with a specific adapter and arguments.\n   *\n   * @template A - The type of the adapter.\n   * @template Q - The type of the query builder.\n   * @template F - The type of the filter.\n   * @template C - The type of the context.\n   *\n   * @param {Partial<InferredAdapterConfig<A>>} conf - adapter configurations to override.\n   * @param [args] - Additional arguments to be passed to the new instance.\n   *\n   * @return A new instance of the Repository class with the specified adapter and arguments.\n   */\n  for(\n    conf: Partial<InferredAdapterConfig<A>>,\n    ...args: any[]\n  ): Repository<M, Q, A, F, C> {\n    return new Proxy(this, {\n      get: (target: any, p: string | symbol, receiver: any) => {\n        if (p === \"adapter\") {\n          return this.adapter.for(conf, ...args);\n        }\n        return Reflect.get(target, p, receiver);\n      },\n    });\n  }\n\n  /**\n   * @description Creates a new observer handler.\n   * @summary Factory method for creating an observer handler instance.\n   * @return {ObserverHandler} A new observer handler instance.\n   */\n  protected ObserverHandler(): ObserverHandler {\n    return new ObserverHandler();\n  }\n\n  /**\n   * @description Prepares a model for creation.\n   * @summary Validates the model and prepares it for creation in the database.\n   * @template M - The model type.\n   * @param {M} model - The model to create.\n   * @param {...any[]} args - Additional arguments.\n   * @return The prepared 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<M, C, F>(\n      OperationKeys.CREATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\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 = await Promise.resolve(\n      model.hasErrors(\n        ...(contextArgs.context.get(\"ignoredValidationProperties\") || [])\n      )\n    );\n    if (errors) throw new ValidationError(errors.toString());\n\n    return [model, ...contextArgs.args];\n  }\n\n  /**\n   * @description Creates a model in the database.\n   * @summary Persists a model instance to the database.\n   * @param {M} model - The model to create.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M>} The created model with updated properties.\n   */\n  async create(model: M, ...args: any[]): Promise<M> {\n    // eslint-disable-next-line prefer-const\n    let { record, id, transient } = this.adapter.prepare(model, this.pk);\n    record = await this.adapter.create(this.tableName, id, record, ...args);\n    let c: C | undefined = undefined;\n    if (args.length) c = args[args.length - 1] as C;\n    return this.adapter.revert<M>(\n      record,\n      this.class,\n      this.pk,\n      id,\n      c && c.get(\"rebuildWithTransient\") ? transient : undefined\n    );\n  }\n\n  /**\n   * @description Post-creation hook.\n   * @summary Executes after a model is created to perform additional operations.\n   * @param {M} model - The created model.\n   * @param {C} context - The operation context.\n   * @return {Promise<M>} The processed model.\n   */\n  override async createSuffix(model: M, context: C): Promise<M> {\n    return super.createSuffix(model, context);\n  }\n\n  /**\n   * @description Creates multiple models in the database.\n   * @summary Persists multiple model instances to the database in a batch operation.\n   * @param {M[]} models - The models to create.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M[]>} The created models with updated properties.\n   */\n  override async createAll(models: M[], ...args: any[]): Promise<M[]> {\n    if (!models.length) return models;\n    const prepared = models.map((m) => this.adapter.prepare(m, this.pk));\n    const ids = prepared.map((p) => p.id);\n    let records = prepared.map((p) => p.record);\n    records = await this.adapter.createAll(\n      this.tableName,\n      ids as (string | number)[],\n      records,\n      ...args\n    );\n    return records.map((r, i) =>\n      this.adapter.revert(r, this.class, this.pk, ids[i] as string | number)\n    );\n  }\n\n  /**\n   * @description Prepares multiple models for creation.\n   * @summary Validates multiple models and prepares them for creation in the database.\n   * @param {M[]} models - The models to create.\n   * @param {...any[]} args - Additional arguments.\n   * @return The prepared models and context arguments.\n   * @throws {ValidationError} If any model fails validation.\n   */\n  protected override async createAllPrefix(models: M[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    if (!models.length) return [models, ...contextArgs.args];\n    const opts = Repository.getSequenceOptions(models[0]);\n    let ids: (string | number | bigint | undefined)[] = [];\n    if (opts.type) {\n      if (!opts.name) opts.name = Sequence.pk(models[0]);\n      ids = await (await this.adapter.Sequence(opts)).range(models.length);\n    } else {\n      ids = models.map((m, i) => {\n        if (typeof m[this.pk] === \"undefined\")\n          throw new InternalError(\n            `Primary key is not defined for model in position ${i}`\n          );\n        return m[this.pk] as string;\n      });\n    }\n\n    models = await Promise.all(\n      models.map(async (m, i) => {\n        m = new this.class(m);\n        if (opts.type) {\n          m[this.pk] = (opts.type !== 'String' ? \n            ids[i] : opts.generated ? \n              ids[i] : `${m[this.pk]}`.toString()) as M[keyof M];\n        }\n    \n        await enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.CREATE,\n          OperationKeys.ON\n        );\n        return m;\n      })\n    );\n\n    const ignoredProps =\n      contextArgs.context.get(\"ignoredValidationProperties\") || [];\n\n    const errors = await Promise.all(\n      models.map((m) => Promise.resolve(m.hasErrors(...ignoredProps)))\n    );\n\n    const errorMessages = errors.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\n    if (errorMessages) throw new ValidationError(errorMessages);\n    return [models, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepares for reading a model by ID.\n   * @summary Prepares the context and enforces decorators before reading a model.\n   * @param {string} key - The primary key of the model to read.\n   * @param {...any[]} args - Additional arguments.\n   * @return The key and context arguments.\n   */\n  protected override async readPrefix(key: string, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.READ,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    const model: M = new this.class();\n    model[this.pk] = key as M[keyof M];\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.READ,\n      OperationKeys.ON\n    );\n    return [key, ...contextArgs.args];\n  }\n\n  /**\n   * @description Reads a model from the database by ID.\n   * @summary Retrieves a model instance from the database using its primary key.\n   * @param {string|number|bigint} id - The primary key of the model to read.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M>} The retrieved model instance.\n   */\n  async read(id: string | number | bigint, ...args: any[]): Promise<M> {\n    const m = await this.adapter.read(this.tableName, id, ...args);\n    return this.adapter.revert<M>(m, this.class, this.pk, id);\n  }\n\n  /**\n   * @description Prepares for reading multiple models by IDs.\n   * @summary Prepares the context and enforces decorators before reading multiple models.\n   * @param {string[]|number[]} keys - The primary keys of the models to read.\n   * @param {...any[]} args - Additional arguments.\n   * @return The keys and context arguments.\n   */\n  protected override async readAllPrefix(\n    keys: string[] | number[],\n    ...args: any[]\n  ) {\n    const contextArgs = await Context.args(\n      OperationKeys.READ,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    await Promise.all(\n      keys.map(async (k) => {\n        const m = new this.class();\n        m[this.pk] = k as M[keyof M];\n        return enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.READ,\n          OperationKeys.ON\n        );\n      })\n    );\n    return [keys, ...contextArgs.args];\n  }\n\n  /**\n   * @description Reads multiple models from the database by IDs.\n   * @summary Retrieves multiple model instances from the database using their primary keys.\n   * @param {string[]|number[]} keys - The primary keys of the models to read.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M[]>} The retrieved model instances.\n   */\n  override async readAll(\n    keys: string[] | number[],\n    ...args: any[]\n  ): Promise<M[]> {\n    const records = await this.adapter.readAll(this.tableName, keys, ...args);\n    return records.map((r, i) =>\n      this.adapter.revert(r, this.class, this.pk, keys[i])\n    );\n  }\n\n  /**\n   * @description Updates a model in the database.\n   * @summary Persists changes to an existing model instance in the database.\n   * @param {M} model - The model to update.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M>} The updated model with refreshed properties.\n   */\n  async update(model: M, ...args: any[]): Promise<M> {\n    // eslint-disable-next-line prefer-const\n    let { record, id, transient } = this.adapter.prepare(model, this.pk);\n    record = await this.adapter.update(this.tableName, id, record, ...args);\n    return this.adapter.revert<M>(record, this.class, this.pk, id, transient);\n  }\n\n  /**\n   * @description Prepares a model for update.\n   * @summary Validates the model and prepares it for update in the database.\n   * @param {M} model - The model to update.\n   * @param {...any[]} args - Additional arguments.\n   * @return The prepared model and context arguments.\n   * @throws {InternalError} If the model has no 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      this.adapter,\n      this._overrides || {}\n    );\n    const pk = model[this.pk] as string;\n    if (!pk)\n      throw new InternalError(\n        `No value for the Id is defined under the property ${this.pk as string}`\n      );\n    const oldModel = await this.read(pk, ...contextArgs.args);\n    model = this.merge(oldModel, model);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.UPDATE,\n      OperationKeys.ON,\n      oldModel\n    );\n\n    const errors = await Promise.resolve(\n      model.hasErrors(\n        oldModel,\n        ...Repository.relations(this.class),\n        ...(contextArgs.context.get(\"ignoredValidationProperties\") || [])\n      )\n    );\n    if (errors) throw new ValidationError(errors.toString());\n    if (Repository.getMetadata(oldModel)) {\n      if (!Repository.getMetadata(model))\n        Repository.setMetadata(model, Repository.getMetadata(oldModel));\n    }\n    return [model, ...contextArgs.args];\n  }\n\n  /**\n   * @description Updates multiple models in the database.\n   * @summary Persists changes to multiple existing model instances in the database in a batch operation.\n   * @param {M[]} models - The models to update.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M[]>} The updated models with refreshed properties.\n   */\n  override async updateAll(models: M[], ...args: any[]): Promise<M[]> {\n    const records = models.map((m) => this.adapter.prepare(m, this.pk));\n    const updated = await this.adapter.updateAll(\n      this.tableName,\n      records.map((r) => r.id),\n      records.map((r) => r.record),\n      ...args\n    );\n    return updated.map((u, i) =>\n      this.adapter.revert(u, this.class, this.pk, records[i].id)\n    );\n  }\n\n  /**\n   * @description Prepares multiple models for update.\n   * @summary Validates multiple models and prepares them for update in the database.\n   * @param {M[]} models - The models to update.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<any[]>} The prepared models and context arguments.\n   * @throws {InternalError} If any model has no primary key value.\n   * @throws {ValidationError} If any model fails validation.\n   */\n  protected override async updateAllPrefix(\n    models: M[],\n    ...args: any[]\n  ): Promise<any[]> {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    const ids = models.map((m) => {\n      const id = m[this.pk] as string;\n      if (!id) throw new InternalError(\"missing id on update operation\");\n      return id;\n    });\n    const oldModels = await this.readAll(ids, ...contextArgs.args);\n    models = models.map((m, i) => {\n      m = this.merge(oldModels[i], m);\n      if (Repository.getMetadata(oldModels[i])) {\n        if (!Repository.getMetadata(m))\n          Repository.setMetadata(m, Repository.getMetadata(oldModels[i]));\n      }\n      return m;\n    });\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 ignoredProps =\n      contextArgs.context.get(\"ignoredValidationProperties\") || [];\n\n    const errors = await Promise.all(\n      models.map((m, i) =>\n        Promise.resolve(m.hasErrors(oldModels[i], m, ...ignoredProps))\n      )\n    );\n\n    const errorMessages = errors.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\n    if (errorMessages) throw new ValidationError(errorMessages);\n\n    models.forEach((m, i) => {\n      if (Repository.getMetadata(oldModels[i])) {\n        if (!Repository.getMetadata(m))\n          Repository.setMetadata(m, Repository.getMetadata(oldModels[i]));\n      }\n    });\n    return [models, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepares for deleting a model by ID.\n   * @summary Prepares the context and enforces decorators before deleting a model.\n   * @param {any} key - The primary key of the model to delete.\n   * @param {...any[]} args - Additional arguments.\n   * @return The key and context arguments.\n   */\n  protected override async deletePrefix(key: any, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.DELETE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    const model = await this.read(key, ...contextArgs.args);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.DELETE,\n      OperationKeys.ON\n    );\n    return [key, ...contextArgs.args];\n  }\n\n  /**\n   * @description Deletes a model from the database by ID.\n   * @summary Removes a model instance from the database using its primary key.\n   * @param {string|number|bigint} id - The primary key of the model to delete.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M>} The deleted model instance.\n   */\n  async delete(id: string | number | bigint, ...args: any[]): Promise<M> {\n    const m = await this.adapter.delete(this.tableName, id, ...args);\n    return this.adapter.revert<M>(m, this.class, this.pk, id);\n  }\n\n  /**\n   * @description Prepares for deleting multiple models by IDs.\n   * @summary Prepares the context and enforces decorators before deleting multiple models.\n   * @param {string[]|number[]} keys - The primary keys of the models to delete.\n   * @param {...any[]} args - Additional arguments.\n   * @return The keys and context arguments.\n   */\n  protected override async deleteAllPrefix(\n    keys: string[] | number[],\n    ...args: any[]\n  ) {\n    const contextArgs = await Context.args(\n      OperationKeys.DELETE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    const models = await this.readAll(keys, ...contextArgs.args);\n    await Promise.all(\n      models.map(async (m) => {\n        return enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.DELETE,\n          OperationKeys.ON\n        );\n      })\n    );\n    return [keys, ...contextArgs.args];\n  }\n\n  /**\n   * @description Deletes multiple models from the database by IDs.\n   * @summary Removes multiple model instances from the database using their primary keys.\n   * @param {string[]|number[]} keys - The primary keys of the models to delete.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M[]>} The deleted model instances.\n   */\n  override async deleteAll(\n    keys: string[] | number[],\n    ...args: any[]\n  ): Promise<M[]> {\n    const results = await this.adapter.deleteAll(this.tableName, keys, ...args);\n    return results.map((r, i) =>\n      this.adapter.revert(r, this.class, this.pk, keys[i])\n    );\n  }\n  /**\n   * @description Creates a select query without specifying fields.\n   * @summary Starts building a query that will return all fields of the model.\n   * @template S - The array type of select selectors.\n   * @return A query builder for the model.\n   */\n  select<\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    S extends readonly SelectSelector<M>[],\n  >(): WhereOption<M, M[]>;\n\n  /**\n   * @description Creates a select query with specific fields.\n   * @summary Starts building a query that will return only the specified fields of the model.\n   * @template S - The array type of select selectors.\n   * @param selector - The fields to select.\n   * @return A query builder for the selected fields.\n   */\n  select<S extends readonly SelectSelector<M>[]>(\n    selector: readonly [...S]\n  ): WhereOption<M, Pick<M, S[number]>[]>;\n\n  /**\n   * @description Implementation of the select method.\n   * @summary Creates a query builder for the model with optional field selection.\n   * @template S - The array type of select selectors.\n   * @param [selector] - Optional fields to select.\n   * @return A query builder.\n   */\n  select<S extends readonly SelectSelector<M>[]>(\n    selector?: readonly [...S]\n  ): WhereOption<M, M[]> | WhereOption<M, Pick<M, S[number]>[]> {\n    return this.adapter\n      .Statement<M>()\n      .select(selector as readonly [...S])\n      .from(this.class);\n  }\n\n  /**\n   * @description Executes a query with the specified conditions and options.\n   * @summary Provides a simplified way to query the database with common query parameters.\n   * @param {Condition<M>} condition - The condition to filter records.\n   * @param orderBy - The field to order results by.\n   * @param {OrderDirection} [order=OrderDirection.ASC] - The sort direction.\n   * @param {number} [limit] - Optional maximum number of results to return.\n   * @param {number} [skip] - Optional number of results to skip.\n   * @return {Promise<M[]>} The query results as model instances.\n   */\n  async query(\n    condition: Condition<M>,\n    orderBy: keyof M,\n    order: OrderDirection = OrderDirection.ASC,\n    limit?: number,\n    skip?: number\n  ): Promise<M[]> {\n    const sort: OrderBySelector<M> = [orderBy, order as OrderDirection];\n    const query = this.select().where(condition).orderBy(sort);\n    if (limit) query.limit(limit);\n    if (skip) query.offset(skip);\n    return query.execute();\n  }\n\n  attr(prop: keyof M) {\n    return Condition.attr<M>(prop);\n  }\n\n  /**\n   * @description Registers an observer for this repository.\n   * @summary Adds an observer that will be notified of changes to models in this repository.\n   * @param {Observer} observer - The observer to register.\n   * @param {ObserverFilter} [filter] - Optional filter to limit which events the observer receives.\n   * @return {void}\n   * @see {Observable#observe}\n   */\n  @final()\n  observe(observer: Observer, filter?: ObserverFilter): void {\n    if (!this.observerHandler)\n      Object.defineProperty(this, \"observerHandler\", {\n        value: this.ObserverHandler(),\n        writable: false,\n      });\n    const log = this.log.for(this.observe);\n    const tableName = Repository.table(this.class);\n    this.adapter.observe(this, (table: string) => tableName === table);\n    log.verbose(\n      `now observing ${this.adapter} filtering on table === ${tableName}`\n    );\n    this.observerHandler!.observe(observer, filter);\n    log.verbose(`Registered new observer ${observer.toString()}`);\n  }\n\n  /**\n   * @description Unregisters an observer from this repository.\n   * @summary Removes an observer so it will no longer receive notifications of changes.\n   * @param {Observer} observer - The observer to unregister.\n   * @return {void}\n   * @throws {InternalError} If the observer handler is not initialized.\n   * @see {Observable#unObserve}\n   */\n  @final()\n  unObserve(observer: Observer): void {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    this.observerHandler.unObserve(observer);\n    this.log\n      .for(this.unObserve)\n      .verbose(`Observer ${observer.toString()} removed`);\n    if (!this.observerHandler.count()) {\n      this.log.verbose(\n        `No more observers registered for ${this.adapter}, unsubscribing`\n      );\n      this.adapter.unObserve(this);\n      this.log.verbose(`No longer observing adapter ${this.adapter.flavour}`);\n    }\n  }\n\n  /**\n   * @description Notifies all observers of an event.\n   * @summary Updates all registered observers with information about a database event.\n   * @param {string} table - The table name where the event occurred.\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of event that occurred.\n   * @param {EventIds} id - The ID or IDs of the affected records.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<void>} A promise that resolves when all observers have been notified.\n   * @throws {InternalError} If the observer handler is not initialized.\n   */\n  async updateObservers(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ): Promise<void> {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    this.log\n      .for(this.updateObservers)\n      .verbose(\n        `Updating ${this.observerHandler.count()} observers for ${this}`\n      );\n    await this.observerHandler.updateObservers(\n      this.log,\n      table,\n      event,\n      Array.isArray(id)\n        ? id.map((i) => Sequence.parseValue(this.pkProps.type, i) as string)\n        : (Sequence.parseValue(this.pkProps.type, id) as string),\n      ...args\n    );\n  }\n\n  /**\n   * @description Alias for updateObservers.\n   * @summary Notifies all observers of an event (alias for updateObservers).\n   * @param {string} table - The table name where the event occurred.\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of event that occurred.\n   * @param {EventIds} id - The ID or IDs of the affected records.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<void>} A promise that resolves when all observers have been notified.\n   */\n  async refresh(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ) {\n    return this.updateObservers(table, event, id, ...args);\n  }\n\n  /**\n   * @description Creates or retrieves a repository for a model.\n   * @summary Factory method that returns a repository instance for the specified model.\n   * @template M - The model type that extends Model.\n   * @template R - The repository type that extends Repo<M>.\n   * @param {Constructor<M>} model - The model constructor.\n   * @param {string} [alias] - Optional default adapter flavour if not specified on the model.\n   * @param {...any[]} [args] - Additional arguments to pass to the repository constructor.\n   * @return {R} A repository instance for the model.\n   * @throws {InternalError} If no adapter is registered for the flavour.\n   */\n  static forModel<M extends Model, R extends Repo<M>>(\n    model: Constructor<M>,\n    alias?: string,\n    ...args: any[]\n  ): R {\n    let repo: R | Constructor<R> | undefined;\n\n    const _alias: string | undefined =\n      alias ||\n      Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), model) ||\n      Adapter.currentFlavour;\n    try {\n      repo = this.get(model, _alias) as Constructor<R> | R;\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: any) {\n      repo = undefined;\n    }\n\n    if (repo instanceof Repository) return repo as R;\n\n    const flavour: string | undefined =\n      alias ||\n      Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), model) ||\n      (repo &&\n        Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), repo)) ||\n      Adapter.currentFlavour;\n    const adapter: Adapter<any, any, any, any> | undefined = flavour\n      ? Adapter.get(flavour)\n      : undefined;\n\n    if (!adapter)\n      throw new InternalError(\n        `No registered persistence adapter found flavour ${flavour}`\n      );\n\n    repo = repo || (adapter.repository() as Constructor<R>);\n    return new repo(adapter, model, ...args) as R;\n  }\n\n  /**\n   * @description Retrieves a repository for a model from the cache.\n   * @summary Gets a repository constructor or instance for the specified model from the internal cache.\n   * @template M - The model type that extends Model.\n   * @param {Constructor<M>} model - The model constructor.\n   * @param {string} [alias] - The adapter alias.\n   * @return {Constructor<Repo<M>> | Repo<M>} The repository constructor or instance.\n   * @throws {InternalError} If no repository is registered for the model.\n   */\n  private static get<M extends Model>(\n    model: Constructor<M>,\n    alias?: string\n  ): Constructor<Repo<M>> | Repo<M> {\n    let name = Repository.table(model);\n    if (alias) {\n      name = [name, alias].join(DefaultSeparator);\n    }\n    if (name in this._cache)\n      return this._cache[name] as unknown as Constructor<Repo<M>> | Repo<M>;\n    throw new InternalError(\n      `Could not find repository registered under ${name}`\n    );\n  }\n\n  /**\n   * @description Registers a repository for a model.\n   * @summary Associates a repository constructor or instance with a model in the internal cache.\n   * @template M - The model type that extends Model.\n   * @param {Constructor<M>} model - The model constructor.\n   * @param {Constructor<Repo<M>> | Repo<M>} repo - The repository constructor or instance.\n   * @param {string} [alias] the adapter alias/flavour.\n   * @throws {InternalError} If a repository is already registered for the model.\n   */\n  static register<M extends Model>(\n    model: Constructor<M>,\n    repo: Constructor<Repo<M>> | Repo<M>,\n    alias?: string\n  ) {\n    let name = Repository.table(model);\n    if (alias) {\n      name = [name, alias].join(DefaultSeparator);\n    }\n    if (name in this._cache)\n      throw new InternalError(`${name} already registered as a repository`);\n    this._cache[name] = repo as any;\n  }\n\n  /**\n   * @description Sets metadata on a model instance.\n   * @summary Attaches metadata to a model instance using a non-enumerable property.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   * @param {any} metadata - The metadata to attach to the model.\n   */\n  static setMetadata<M extends Model>(model: M, metadata: any) {\n    Object.defineProperty(model, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: true,\n      writable: false,\n      value: metadata,\n    });\n  }\n\n  /**\n   * @description Gets metadata from a model instance.\n   * @summary Retrieves previously attached metadata from a model instance.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   * @return {any} The metadata or undefined if not found.\n   */\n  static getMetadata<M extends Model>(model: M) {\n    const descriptor = Object.getOwnPropertyDescriptor(\n      model,\n      PersistenceKeys.METADATA\n    );\n    return descriptor ? descriptor.value : undefined;\n  }\n\n  /**\n   * @description Removes metadata from a model instance.\n   * @summary Deletes the metadata property from a model instance.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   */\n  static removeMetadata<M extends Model>(model: M) {\n    const descriptor = Object.getOwnPropertyDescriptor(\n      model,\n      PersistenceKeys.METADATA\n    );\n    if (descriptor) delete (model as any)[PersistenceKeys.METADATA];\n  }\n\n  /**\n   * @description Gets sequence options for a model's primary key.\n   * @summary Retrieves the sequence configuration for a model's primary key from metadata.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   * @return {SequenceOptions} The sequence options for the model's primary key.\n   * @throws {InternalError} If no sequence options are defined for the model.\n   */\n  static getSequenceOptions<M extends Model>(model: M) {\n    const pk = findPrimaryKey(model).id;\n    const metadata = Reflect.getMetadata(\n      Repository.key(DBKeys.ID),\n      model,\n      pk as string\n    );\n    if (!metadata)\n      throw new InternalError(\n        \"No sequence options defined for model. did you use the @pk decorator?\"\n      );\n    return metadata as SequenceOptions;\n  }\n\n  /**\n   * @description Gets all indexes defined on a model.\n   * @summary Retrieves all index metadata from a model's property decorators.\n   * @template M - The model type that extends Model.\n   * @param {M | Constructor<M>} model - The model instance or constructor.\n   * @return {Record<string, Record<string, IndexMetadata>>} A nested record of property names to index metadata.\n   */\n  static indexes<M extends Model>(model: M | Constructor<M>) {\n    const indexDecorators = Reflection.getAllPropertyDecorators(\n      model instanceof Model ? model : new model(),\n      DBKeys.REFLECT\n    );\n    return Object.entries(indexDecorators || {}).reduce(\n      (accum: Record<string, Record<string, IndexMetadata>>, [k, val]) => {\n        const decs = val.filter((v) => v.key.startsWith(PersistenceKeys.INDEX));\n        if (decs && decs.length) {\n          for (const dec of decs) {\n            const { key, props } = dec;\n            accum[k] = accum[k] || {};\n            accum[k][key] = props as IndexMetadata;\n          }\n        }\n        return accum;\n      },\n      {}\n    );\n  }\n\n  /**\n   * @description Gets all relation properties defined on a model.\n   * @summary Retrieves the names of all properties marked as relations in the model hierarchy.\n   * @template M - The model type that extends Model.\n   * @param {M | Constructor<M>} model - The model instance or constructor.\n   * @return {string[]} An array of property names that are relations.\n   */\n  static relations<M extends Model>(model: M | Constructor<M>): string[] {\n    const result: string[] = [];\n    let prototype =\n      model instanceof Model\n        ? Object.getPrototypeOf(model)\n        : (model as any).prototype;\n    while (prototype != null) {\n      const props: string[] = prototype[PersistenceKeys.RELATIONS];\n      if (props) {\n        result.push(...props);\n      }\n      prototype = Object.getPrototypeOf(prototype);\n    }\n    return result;\n  }\n\n  /**\n   * @description Gets the table name for a model.\n   * @summary Retrieves the database table name associated with a model.\n   * @template M - The model type that extends Model.\n   * @param {M | Constructor<M>} model - The model instance or constructor.\n   * @return {string} The table name for the model.\n   */\n  static table<M extends Model>(model: M | Constructor<M>): string {\n    return getTableName(model);\n  }\n\n  /**\n   * @description Gets the column name for a model attribute.\n   * @summary Retrieves the database column name for a model property.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   * @param {string} attribute - The attribute/property name.\n   * @return {string} The column name for the attribute.\n   */\n  static column<M extends Model>(model: M, attribute: string): string {\n    return getColumnName(model, attribute);\n  }\n}\n\nif (Adapter) Adapter[\"_baseRepository\"] = Repository;\n","import { InternalError } from \"@decaf-ts/db-decorators\";\nimport { Constructor, sf } from \"@decaf-ts/decorator-validation\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { getTableName } from \"../identity/utils\";\n\n/**\n * @description Generates a unique injectable name for a repository.\n * @summary Creates a standardized injectable token for repositories using the adapter flavour and model table name.\n * This helps the DI system register and resolve repository instances consistently across adapters.\n * @template T The model type that extends Model.\n * @param {Constructor<T> | T} model The model constructor or instance from which to derive the table name.\n * @param {string} [flavour] Optional adapter flavour/alias. If omitted, it is read from model metadata.\n * @return {string} A namespaced injectable token for the repository (e.g., \"db:repo:ram:users\").\n * @throws {InternalError} If the flavour cannot be determined from arguments or metadata.\n * @function generateInjectableNameForRepository\n * @mermaid\n * sequenceDiagram\n *   participant C as Caller\n *   participant U as generateInjectableNameForRepository\n *   participant R as Reflect Metadata\n *   participant A as Adapter\n *   participant S as String Formatter\n *   C->>U: call(model, flavour?)\n *   alt flavour provided\n *     U-->>U: use provided flavour\n *   else flavour not provided\n *     U->>A: Adapter.key(ADAPTER)\n *     U->>R: getMetadata(key, model|model.ctor)\n *     alt metadata present\n *       R-->>U: flavour\n *     else missing\n *       U-->>C: throw InternalError\n *     end\n *   end\n *   U->>S: sf(INJECTABLE, flavour, Repository.table(model))\n *   S-->>C: token string\n * @memberOf module:core\n */\nexport function generateInjectableNameForRepository<T extends Model>(\n  model: Constructor<T> | T,\n  flavour?: string\n): string {\n  if (!flavour) {\n    const key = Adapter.key(PersistenceKeys.ADAPTER);\n    flavour = Reflect.getMetadata(\n      key,\n      model instanceof Model ? model.constructor : model\n    );\n    if (!flavour)\n      throw new InternalError(\n        `Could not retrieve flavour from model ${model instanceof Model ? model.constructor.name : model.name}`\n      );\n  }\n  return sf(PersistenceKeys.INJECTABLE, flavour, getTableName(model));\n}\n","import {\n  InjectableRegistryImp,\n  Injectables,\n} from \"@decaf-ts/injectable-decorators\";\nimport { Repository } from \"./Repository\";\nimport {\n  Constructor,\n  Model,\n  ModelConstructor,\n} from \"@decaf-ts/decorator-validation\";\nimport { generateInjectableNameForRepository } from \"./utils\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\n\n/**\n * @description Registry for injectable repositories with auto-resolution.\n * @summary Provides an InjectableRegistry implementation that resolves repositories by model name or constructor. If a repository\n * is not explicitly registered, it attempts to infer the correct repository using model metadata and the active or specified adapter flavour.\n * @param {void} [constructor] No constructor parameters required; the superclass handles internal state.\n * @class InjectablesRegistry\n * @example\n * // Basic usage: retrieve a repository by model name\n * const registry = new InjectablesRegistry();\n * const userRepo = registry.get<UserRepository>('User');\n * // If UserRepository is registered, it will be returned. Otherwise, a repository will be created if a User model exists.\n *\n * // Retrieve by constructor and specify adapter flavour\n * const repoByCtor = registry.get<UserRepository>(UserModel, 'ram');\n *\n * // Retrieve by symbol (e.g., injectable token)\n * const token = Symbol.for('UserRepository');\n * const byToken = registry.get<UserRepository>(token);\n * @mermaid\n * sequenceDiagram\n *   participant C as Consumer\n *   participant R as InjectablesRegistry\n *   participant B as BaseRegistry\n *   participant M as Model\n *   participant A as Adapter\n *   participant RP as Repository\n *   C->>R: get(name, flavour?)\n *   activate R\n *   R->>B: super.get(name)\n *   alt Found in base registry\n *     B-->>R: injectable\n *     R-->>C: injectable\n *   else Not found\n *     R->>M: Model.get(name)\n *     alt Model found\n *       R->>A: resolve flavour (from arg/metadata/current)\n *       R->>RP: Repository.forModel(modelCtor, alias)\n *       alt Repository instance\n *         RP-->>R: repository instance\n *         R-->>C: repository instance\n *       else Repository ctor\n *         R->>A: Adapter.get(resolvedFlavour) or Adapter.current\n *         A-->>R: adapter instance\n *         R->>RP: new repoCtor(adapter, modelCtor)\n *         R-->>C: repository instance\n *       end\n *     else Model not found\n *       R-->>C: undefined\n *     end\n *   end\n */\nexport class InjectablesRegistry extends InjectableRegistryImp {\n  private logger?: Logger;\n\n  protected get log(): Logger {\n    if (!this.logger) this.logger = Logging.for(this as any);\n    return this.logger;\n  }\n\n  constructor() {\n    super();\n  }\n\n  /**\n   * @description Retrieve an injectable with repository auto-resolution.\n   * @summary Attempts to get an injectable from the base registry; if not found and the name refers to a known model, it\n   * resolves the appropriate repository using the specified flavour or model metadata, falling back to the current adapter when needed.\n   * @template T The injectable type to be returned.\n   * @param {string | symbol | Constructor<T>} name Token, model name, or constructor associated with the injectable or model.\n   * @param {string} [flavour] Optional adapter flavour (e.g., \"ram\"). If omitted, derives from metadata or current adapter.\n   * @return {T | undefined} The located or auto-created injectable instance; otherwise undefined if it cannot be resolved.\n   * @mermaid\n   * sequenceDiagram\n   *   participant G as get(name, flavour?)\n   *   participant BR as BaseRegistry\n   *   participant M as Model\n   *   participant A as Adapter\n   *   participant RP as Repository\n   *   G->>BR: super.get(name)\n   *   alt Found\n   *     BR-->>G: injectable\n   *   else Not found\n   *     G->>M: derive modelCtor from name\n   *     alt modelCtor resolved\n   *       G->>A: resolve flavour (arg | metadata | current)\n   *       G->>RP: Repository.forModel(modelCtor, alias)\n   *       alt returns instance\n   *         RP-->>G: Repository instance\n   *       else returns ctor\n   *         G->>A: Adapter.get(flavour) | Adapter.current\n   *         A-->>G: adapter instance\n   *         G->>RP: new repoCtor(adapter, modelCtor)\n   *       end\n   *     else no modelCtor\n   *       G-->>G: return undefined\n   *     end\n   *   end\n   */\n  override get<T>(\n    name: symbol | Constructor<T> | string,\n    flavour?: string\n  ): T | undefined {\n    const log = this.log.for(this.get);\n    // First, try base registry, but guard against thrown errors\n    let injectable: T | undefined;\n    try {\n      injectable = super.get(name as any);\n    } catch {\n      // do nothing. we handle it later\n    }\n\n    if (!injectable) {\n      let modelCtor: Constructor<any> | undefined;\n      if (typeof name === \"function\") modelCtor = name as Constructor<any>;\n      else if (typeof name === \"symbol\" || typeof name === \"string\") {\n        modelCtor = Model.get(name.toString()) as ModelConstructor<any>;\n      }\n\n      if (!modelCtor) return undefined;\n\n      // Resolve flavour from metadata if not provided\n      const metaKey = Adapter.key(PersistenceKeys.ADAPTER);\n      const resolvedFlavour =\n        flavour ||\n        (Reflect.getMetadata(metaKey, modelCtor) as string | undefined);\n\n      try {\n        // Determine an alias to use: prefer a directly registered adapter; otherwise, if the current adapter\n        // has the same flavour, use its alias to satisfy Repository.forModel/Adapter.get lookups.\n        let aliasToUse = resolvedFlavour;\n        try {\n          if (resolvedFlavour) Adapter.get(resolvedFlavour);\n        } catch {\n          const current = Adapter.current as any;\n          if (current && current.flavour === resolvedFlavour)\n            aliasToUse = current.alias;\n        }\n\n        injectable = Repository.forModel(\n          modelCtor as Constructor<any>,\n          aliasToUse\n        ) as T;\n        if (injectable instanceof Repository) return injectable as T;\n\n        // Otherwise, register the resolved injectable name for later retrieval\n        const f =\n          resolvedFlavour ||\n          (Reflect.getMetadata(metaKey, (injectable as any).constructor) as\n            | string\n            | undefined) ||\n          (Reflect.getMetadata(metaKey, modelCtor) as string | undefined);\n        Injectables.register(\n          injectable,\n          generateInjectableNameForRepository(\n            modelCtor as ModelConstructor<any>,\n            f as string\n          )\n        );\n      } catch (e: unknown) {\n        log.debug(\n          `No registered repository or adapter found. falling back to default adapter. Error: ${(e as Error)?.message || JSON.stringify(e)}`\n        );\n        const repoCtor = (Repository as any)[\"get\"](modelCtor, resolvedFlavour);\n        if (typeof repoCtor === \"function\") {\n          const adapter = resolvedFlavour\n            ? (Adapter.get(resolvedFlavour) as any)\n            : (Adapter.current as any);\n          if (!adapter) return undefined;\n          const instance = new repoCtor(adapter, modelCtor);\n          return instance as T;\n        }\n      }\n    }\n\n    return injectable as T | undefined;\n  }\n}\n","import {\n  InternalError,\n  OperationKeys,\n  BulkCrudOperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { ModelConstructor } from \"@decaf-ts/decorator-validation\";\nimport { Observer } from \"../interfaces\";\nimport { Adapter } from \"./Adapter\";\nimport { UnsupportedError } from \"./errors\";\nimport { AdapterDispatch, EventIds } from \"./types\";\nimport { LoggedClass } from \"@decaf-ts/logging\";\n\n/**\n * @description Dispatches database operation events to observers\n * @summary The Dispatch class implements the Observable interface and is responsible for intercepting\n * database operations from an Adapter and notifying observers when changes occur. It uses proxies to\n * wrap the adapter's CRUD methods and automatically trigger observer updates after operations complete.\n * @template Y - The native database driver type\n * @param {void} - No constructor parameters\n * @class Dispatch\n * @example\n * ```typescript\n * // Creating and using a Dispatch instance\n * const dispatch = new Dispatch<PostgresDriver>();\n *\n * // Connect it to an adapter\n * const adapter = new PostgresAdapter(connection);\n * dispatch.observe(adapter);\n *\n * // Now any CRUD operations on the adapter will automatically\n * // trigger observer notifications\n * await adapter.create('users', 123, userModel);\n * // Observers will be notified about the creation\n *\n * // When done, you can disconnect\n * dispatch.unObserve(adapter);\n * ```\n */\nexport class Dispatch extends LoggedClass implements AdapterDispatch {\n  /**\n   * @description The adapter being observed\n   * @summary Reference to the database adapter whose operations are being monitored\n   */\n  protected adapter?: Adapter<any, any, any, any, any>;\n\n  /**\n   * @description List of model constructors\n   * @summary Array of model constructors that are registered with the adapter\n   */\n  protected models!: ModelConstructor<any>[];\n\n  /**\n   * @description Creates a new Dispatch instance\n   * @summary Initializes a new Dispatch instance without any adapter\n   */\n  constructor() {\n    super();\n  }\n\n  /**\n   * @description Initializes the dispatch by proxying adapter methods\n   * @summary Sets up proxies on the adapter's CRUD methods to intercept operations and notify observers.\n   * This method is called automatically when an adapter is observed.\n   * @return {Promise<void>} A promise that resolves when initialization is complete\n   * @mermaid\n   * sequenceDiagram\n   *   participant Dispatch\n   *   participant Adapter\n   *   participant Proxy\n   *\n   *   Dispatch->>Dispatch: initialize()\n   *   Dispatch->>Dispatch: Check if adapter exists\n   *   alt No adapter\n   *     Dispatch-->>Dispatch: Throw InternalError\n   *   end\n   *\n   *   loop For each CRUD method\n   *     Dispatch->>Adapter: Check if method exists\n   *     alt Method doesn't exist\n   *       Dispatch-->>Dispatch: Throw InternalError\n   *     end\n   *\n   *     Dispatch->>Adapter: Get property descriptor\n   *     loop While descriptor not found\n   *       Dispatch->>Adapter: Check prototype chain\n   *     end\n   *\n   *     alt Descriptor not found or not writable\n   *       Dispatch->>Dispatch: Log error and continue\n   *     else Descriptor found and writable\n   *       Dispatch->>Proxy: Create proxy for method\n   *       Dispatch->>Adapter: Replace method with proxy\n   *     end\n   *   end\n   */\n  protected async initialize(): Promise<void> {\n    if (!this.adapter) {\n      // Gracefully skip initialization when no adapter is observed yet.\n      // Some tests or setups may construct a Dispatch before calling observe().\n      // Instead of throwing, we no-op so that later observe() can proceed.\n      this.log.verbose(\n        `No adapter observed for dispatch; skipping initialization`\n      );\n      return;\n    }\n    const adapter = this.adapter as Adapter<any, any, any, any>;\n    (\n      [\n        OperationKeys.CREATE,\n        OperationKeys.UPDATE,\n        OperationKeys.DELETE,\n        BulkCrudOperationKeys.CREATE_ALL,\n        BulkCrudOperationKeys.UPDATE_ALL,\n        BulkCrudOperationKeys.DELETE_ALL,\n      ] as (keyof Adapter<any, any, any, any>)[]\n    ).forEach((method) => {\n      if (!adapter[method])\n        throw new InternalError(\n          `Method ${method} not found in ${adapter.alias} adapter to bind Observables Dispatch`\n        );\n\n      let descriptor = Object.getOwnPropertyDescriptor(adapter, method);\n      let proto: any = adapter;\n      while (!descriptor && proto !== Object.prototype) {\n        proto = Object.getPrototypeOf(proto);\n        descriptor = Object.getOwnPropertyDescriptor(proto, method);\n      }\n\n      if (!descriptor || !descriptor.writable) {\n        this.log.error(\n          `Could not find method ${method} to bind Observables Dispatch`\n        );\n        return;\n      }\n      function bulkToSingle(method: string) {\n        switch (method) {\n          case BulkCrudOperationKeys.CREATE_ALL:\n            return OperationKeys.CREATE;\n          case BulkCrudOperationKeys.UPDATE_ALL:\n            return OperationKeys.UPDATE;\n          case BulkCrudOperationKeys.DELETE_ALL:\n            return OperationKeys.DELETE;\n          default:\n            return method;\n        }\n      }\n      // @ts-expect-error because there are read only properties\n      adapter[method] = new Proxy(adapter[method], {\n        apply: async (target: any, thisArg, argArray: any[]) => {\n          const [tableName, ids] = argArray;\n          const result = await target.apply(thisArg, argArray);\n          this.updateObservers(tableName, bulkToSingle(method), ids as EventIds)\n            .then(() => {\n              this.log.verbose(\n                `Observer refresh dispatched by ${method} for ${tableName}`\n              );\n              this.log.debug(`pks: ${ids}`);\n            })\n            .catch((e: unknown) =>\n              this.log.error(\n                `Failed to dispatch observer refresh for ${method} on ${tableName}: ${e}`\n              )\n            );\n          return result;\n        },\n      });\n    });\n  }\n\n  /**\n   * @description Closes the dispatch\n   * @summary Performs any necessary cleanup when the dispatch is no longer needed\n   * @return {Promise<void>} A promise that resolves when closing is complete\n   */\n  async close(): Promise<void> {\n    // to nothing in this instance but may be required for closing connections\n  }\n\n  /**\n   * @description Starts observing an adapter\n   * @summary Connects this dispatch to an adapter to monitor its operations\n   * @param {Adapter<any, any, any, any>} observer - The adapter to observe\n   * @return {void}\n   */\n  observe(observer: Adapter<any, any, any, any>): void {\n    if (!(observer instanceof Adapter))\n      throw new UnsupportedError(\"Only Adapters can be observed by dispatch\");\n    this.adapter = observer;\n    this.models = Adapter.models(this.adapter.alias);\n    this.initialize().then(() =>\n      this.log.verbose(\n        `Dispatch initialized for ${this.adapter!.alias} adapter`\n      )\n    );\n  }\n\n  /**\n   * @description Stops observing an adapter\n   * @summary Disconnects this dispatch from an adapter\n   * @param {Observer} observer - The adapter to stop observing\n   * @return {void}\n   */\n  unObserve(observer: Observer): void {\n    if (this.adapter !== observer)\n      throw new UnsupportedError(\n        \"Only the adapter that was used to observe can be unobserved\"\n      );\n    this.adapter = undefined;\n  }\n\n  /**\n   * @description Updates observers about a database event\n   * @summary Notifies observers about a change in the database\n   * @param {string} table - The name of the table where the change occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {EventIds} id - The identifier(s) of the affected record(s)\n   * @return {Promise<void>} A promise that resolves when all observers have been notified\n   */\n  async updateObservers(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds\n  ): Promise<void> {\n    if (!this.adapter) {\n      this.log.verbose(\n        `No adapter observed for dispatch; skipping observer update for ${table}:${event}`\n      );\n      return;\n    }\n    try {\n      await this.adapter.refresh(table, event, id);\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to refresh dispatch: ${e}`);\n    }\n  }\n}\n\nif (Adapter) Adapter[\"_baseDispatch\"] = Dispatch;\n","import { inject, injectable } from \"@decaf-ts/injectable-decorators\";\nimport { DBKeys, IRepository } from \"@decaf-ts/db-decorators\";\nimport { metadata } from \"@decaf-ts/reflection\";\nimport { Constructor, Model, ModelKeys } from \"@decaf-ts/decorator-validation\";\nimport { Repository } from \"./Repository\";\nimport { Adapter, PersistenceKeys } from \"../persistence\";\n\n/**\n * @description Repository decorator for model classes.\n * @summary Creates and registers a repository for a model class. Can be used as both a property decorator and a class decorator.\n * @template T - The model type that extends Model.\n * @param {Constructor<T>} model - The constructor of the model class.\n * @param {string} [flavour] - the required adapter's flavour/alias. If not provided, it will be retrieved from the model metadata..\n * @return {any} - The decorator function.\n * @function repository\n * @mermaid\n * sequenceDiagram\n *   participant C as Client Code\n *   participant D as Decorator\n *   participant R as Repository\n *   participant M as Metadata\n *\n *   C->>D: Apply @repository(Model)\n *   alt Property Decorator\n *     D->>D: Check if propertyKey exists\n *     D->>+C: Return inject(name) decorator\n *   else Class Decorator\n *     D->>M: Set repository metadata on model\n *     D->>R: Register model with Repository\n *     D->>+C: Return injectable decorator with config\n *     C->>C: Define DBKeys.CLASS property\n *   end\n * @category Decorators\n */\nexport function repository<T extends Model>(\n  model: Constructor<T>,\n  flavour?: string\n): any {\n  return ((original: any, propertyKey?: any) => {\n    if (propertyKey) {\n      return inject(model[ModelKeys.ANCHOR as keyof typeof model] || model)(\n        original,\n        propertyKey\n      );\n    }\n\n    metadata(Repository.key(DBKeys.REPOSITORY), original.name)(model);\n    flavour =\n      flavour ||\n      Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), original);\n    Repository.register(\n      model[ModelKeys.ANCHOR as keyof typeof model] || model,\n      original,\n      flavour\n    );\n    return injectable(model[ModelKeys.ANCHOR as keyof typeof model] || model, {\n      callback: (instance: IRepository<T>) => {\n        Object.defineProperty(instance, DBKeys.CLASS, {\n          enumerable: false,\n          configurable: false,\n          writable: false,\n          value: model,\n        });\n        return instance;\n      },\n    })(original);\n  }) as any;\n}\n","import { InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Error thrown when observer communication fails.\n * @summary Represents a failure in observer communication between repositories.\n * @param {string|Error} msg - The error message or Error object.\n * @class ObserverError\n * @category Errors\n * @example\n * try {\n *   // Some repository observer operation\n * } catch (error) {\n *   if (error instanceof ObserverError) {\n *     console.error('Observer communication failed:', error.message);\n *   }\n * }\n */\nexport class ObserverError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, ObserverError.name, 500);\n  }\n}\n","/**\n * @description Interface for sequence configuration options\n * @summary Defines the configuration options for creating and managing sequences\n * @interface SequenceOptions\n * @memberOf module:core\n */\nexport interface SequenceOptions<\n  TYPE = \"Number\" | \"BigInt\" | string | undefined,\n> {\n  /**\n   * @description Optional name for the sequence\n   * @summary A unique identifier for the sequence\n   */\n  name?: string;\n\n  generated?: boolean;\n\n  /**\n   * @description The data type of the sequence\n   * @summary Specifies whether the sequence generates Number or BigInt values\n   */\n  type: TYPE;\n\n  /**\n   * @description The initial value of the sequence\n   * @summary The value that the sequence starts with\n   */\n  startWith: number;\n\n  /**\n   * @description The increment value for each step in the sequence\n   * @summary The amount by which the sequence increases with each call\n   */\n  incrementBy: number;\n\n  /**\n   * @description Optional minimum value for the sequence\n   * @summary The lowest value that the sequence can generate\n   */\n  minValue?: number;\n\n  /**\n   * @description Optional maximum value for the sequence\n   * @summary The highest value that the sequence can generate\n   */\n  maxValue?: number;\n\n  /**\n   * @description Whether the sequence should cycle when reaching its limits\n   * @summary If true, the sequence will restart from minValue when reaching maxValue\n   */\n  cycle: boolean;\n}\n\n/**\n * @description Default options for sequences\n * @summary Provides a standard configuration for number sequences starting at 0 and incrementing by 1\n * @const NoneSequenceOptions\n * @memberOf module:core\n */\nexport const NoneSequenceOptions: SequenceOptions = {\n  type: undefined,\n  generated: false,\n  startWith: 0,\n  incrementBy: 1,\n  cycle: false,\n};\n\n/**\n * @description Default options for sequences\n * @summary Provides a standard configuration for number sequences starting at 0 and incrementing by 1\n * @const DefaultSequenceOptions\n * @memberOf module:core\n */\nexport const DefaultSequenceOptions: SequenceOptions = NoneSequenceOptions;\n\n/**\n * @description Predefined options for numeric sequences\n * @summary Configuration for standard number sequences starting at 0 and incrementing by 1\n * @const NumericSequence\n * @memberOf module:core\n */\nexport const NumericSequence: SequenceOptions = {\n  type: \"Number\",\n  generated: true,\n  startWith: 0,\n  incrementBy: 1,\n  cycle: false,\n};\n\n/**\n * @description Predefined options for BigInt sequences\n * @summary Configuration for BigInt sequences starting at 0 and incrementing by 1\n * @const BigIntSequence\n * @memberOf module:core\n */\nexport const BigIntSequence: SequenceOptions = Object.assign(\n  {},\n  NumericSequence,\n  {\n    type: \"BigInt\",\n  }\n);\n","import {\n  Constructor,\n  Model,\n  ModelConstructor,\n  Validation,\n  ValidationKeys,\n} from \"@decaf-ts/decorator-validation\";\nimport { Repo, Repository } from \"../repository/Repository\";\nimport { RelationsMetadata } from \"./types\";\nimport {\n  findPrimaryKey,\n  InternalError,\n  NotFoundError,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { Cascade } from \"../repository/constants\";\nimport { Context } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Creates or updates a model instance\n * @summary Determines whether to create a new model or update an existing one based on the presence of a primary key\n * @template M - The model type extending Model\n * @template F - The repository flags type\n * @param {M} model - The model instance to create or update\n * @param {Context<F>} context - The context for the operation\n * @param {Repo<M, F, Context<F>>} [repository] - Optional repository to use for the operation\n * @return {Promise<M>} A promise that resolves to the created or updated model\n * @function createOrUpdate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant createOrUpdate\n *   participant Repository\n *   participant Model\n *\n *   Caller->>createOrUpdate: model, context, repository?\n *   alt repository not provided\n *     createOrUpdate->>Model: get(model.constructor.name)\n *     Model-->>createOrUpdate: constructor\n *     createOrUpdate->>Repository: forModel(constructor)\n *     Repository-->>createOrUpdate: repository\n *   end\n *\n *   alt primary key undefined\n *     createOrUpdate->>Repository: create(model, context)\n *     Repository-->>createOrUpdate: created model\n *   else primary key defined\n *     createOrUpdate->>Repository: update(model, context)\n *     alt update successful\n *       Repository-->>createOrUpdate: updated model\n *     else NotFoundError\n *       createOrUpdate->>Repository: create(model, context)\n *       Repository-->>createOrUpdate: created model\n *     end\n *   end\n *\n *   createOrUpdate-->>Caller: model\n */\nexport async function createOrUpdate<\n  M extends Model,\n  F extends RepositoryFlags,\n>(\n  model: M,\n  context: Context<F>,\n  alias?: string,\n  repository?: Repo<M, F, Context<F>>\n): Promise<M> {\n  if (!repository) {\n    const constructor = Model.get(model.constructor.name);\n    if (!constructor)\n      throw new InternalError(`Could not find model ${model.constructor.name}`);\n    repository = Repository.forModel<M, Repo<M>>(\n      constructor as unknown as ModelConstructor<M>,\n      alias\n    );\n  }\n  if (typeof model[repository.pk] === \"undefined\")\n    return repository.create(model, context);\n  else {\n    try {\n      return repository.update(model, context);\n    } catch (e: any) {\n      if (!(e instanceof NotFoundError)) throw e;\n      return repository.create(model, context);\n    }\n  }\n}\n\n/**\n * @description Handles one-to-one relationship creation\n * @summary Processes a one-to-one relationship when creating a model, either by referencing an existing model or creating a new one\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param {string} key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToOneOnCreate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToOneOnCreate\n *   participant repositoryFromTypeMetadata\n *   participant Model\n *   participant Repository\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToOneOnCreate: this, context, data, key, model\n *   oneToOneOnCreate->>oneToOneOnCreate: check if propertyValue exists\n *\n *   alt propertyValue is not an object\n *     oneToOneOnCreate->>repositoryFromTypeMetadata: model, key\n *     repositoryFromTypeMetadata-->>oneToOneOnCreate: innerRepo\n *     oneToOneOnCreate->>innerRepo: read(propertyValue)\n *     innerRepo-->>oneToOneOnCreate: read\n *     oneToOneOnCreate->>cacheModelForPopulate: context, model, key, propertyValue, read\n *     oneToOneOnCreate->>oneToOneOnCreate: set model[key] = propertyValue\n *   else propertyValue is an object\n *     oneToOneOnCreate->>Model: get(data.class)\n *     Model-->>oneToOneOnCreate: constructor\n *     oneToOneOnCreate->>Repository: forModel(constructor)\n *     Repository-->>oneToOneOnCreate: repo\n *     oneToOneOnCreate->>repo: create(propertyValue)\n *     repo-->>oneToOneOnCreate: created\n *     oneToOneOnCreate->>findPrimaryKey: created\n *     findPrimaryKey-->>oneToOneOnCreate: pk\n *     oneToOneOnCreate->>cacheModelForPopulate: context, model, key, created[pk], created\n *     oneToOneOnCreate->>oneToOneOnCreate: set model[key] = created[pk]\n *   end\n *\n *   oneToOneOnCreate-->>Caller: void\n */\nexport async function oneToOneOnCreate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const propertyValue: any = model[key];\n  if (!propertyValue) return;\n\n  if (typeof propertyValue !== \"object\") {\n    const innerRepo = repositoryFromTypeMetadata(\n      model,\n      key,\n      this.adapter.alias\n    );\n    const read = await innerRepo.read(propertyValue);\n    await cacheModelForPopulate(context, model, key, propertyValue, read);\n    (model as any)[key] = propertyValue;\n    return;\n  }\n\n  data.class =\n    typeof data.class === \"string\" ? data.class : (data.class as any)().name;\n\n  const constructor = Model.get(data.class as string);\n  if (!constructor)\n    throw new InternalError(`Could not find model ${data.class}`);\n  const repo: Repo<any> = Repository.forModel(constructor, this.adapter.alias);\n  const created = await repo.create(propertyValue);\n  const pk = findPrimaryKey(created).id;\n  await cacheModelForPopulate(context, model, key, created[pk], created);\n  (model as any)[key] = created[pk];\n}\n\n/**\n * @description Handles one-to-one relationship updates\n * @summary Processes a one-to-one relationship when updating a model, either by referencing an existing model or updating the related model\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToOneOnUpdate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToOneOnUpdate\n *   participant repositoryFromTypeMetadata\n *   participant createOrUpdate\n *   participant findPrimaryKey\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToOneOnUpdate: this, context, data, key, model\n *   oneToOneOnUpdate->>oneToOneOnUpdate: check if propertyValue exists\n *   oneToOneOnUpdate->>oneToOneOnUpdate: check if cascade.update is CASCADE\n *\n *   alt propertyValue is not an object\n *     oneToOneOnUpdate->>repositoryFromTypeMetadata: model, key\n *     repositoryFromTypeMetadata-->>oneToOneOnUpdate: innerRepo\n *     oneToOneOnUpdate->>innerRepo: read(propertyValue)\n *     innerRepo-->>oneToOneOnUpdate: read\n *     oneToOneOnUpdate->>cacheModelForPopulate: context, model, key, propertyValue, read\n *     oneToOneOnUpdate->>oneToOneOnUpdate: set model[key] = propertyValue\n *   else propertyValue is an object\n *     oneToOneOnUpdate->>createOrUpdate: model[key], context\n *     createOrUpdate-->>oneToOneOnUpdate: updated\n *     oneToOneOnUpdate->>findPrimaryKey: updated\n *     findPrimaryKey-->>oneToOneOnUpdate: pk\n *     oneToOneOnUpdate->>cacheModelForPopulate: context, model, key, updated[pk], updated\n *     oneToOneOnUpdate->>oneToOneOnUpdate: set model[key] = updated[pk]\n *   end\n *\n *   oneToOneOnUpdate-->>Caller: void\n */\nexport async function oneToOneOnUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const propertyValue: any = model[key];\n  if (!propertyValue) return;\n  if (data.cascade.update !== Cascade.CASCADE) return;\n\n  if (typeof propertyValue !== \"object\") {\n    const innerRepo = repositoryFromTypeMetadata(\n      model,\n      key,\n      this.adapter.alias\n    );\n    const read = await innerRepo.read(propertyValue);\n    await cacheModelForPopulate(context, model, key, propertyValue, read);\n    (model as any)[key] = propertyValue;\n    return;\n  }\n\n  const updated = await createOrUpdate(\n    model[key] as M,\n    context,\n    this.adapter.alias\n  );\n  const pk = findPrimaryKey(updated).id;\n  await cacheModelForPopulate(\n    context,\n    model,\n    key,\n    updated[pk] as string,\n    updated\n  );\n  model[key] = updated[pk];\n}\n\n/**\n * @description Handles one-to-one relationship deletion\n * @summary Processes a one-to-one relationship when deleting a model, deleting the related model if cascade is enabled\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToOneOnDelete\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToOneOnDelete\n *   participant repositoryFromTypeMetadata\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToOneOnDelete: this, context, data, key, model\n *   oneToOneOnDelete->>oneToOneOnDelete: check if propertyValue exists\n *   oneToOneOnDelete->>oneToOneOnDelete: check if cascade.update is CASCADE\n *\n *   oneToOneOnDelete->>repositoryFromTypeMetadata: model, key\n *   repositoryFromTypeMetadata-->>oneToOneOnDelete: innerRepo\n *\n *   alt propertyValue is not a Model instance\n *     oneToOneOnDelete->>innerRepo: delete(model[key], context)\n *     innerRepo-->>oneToOneOnDelete: deleted\n *   else propertyValue is a Model instance\n *     oneToOneOnDelete->>innerRepo: delete(model[key][innerRepo.pk], context)\n *     innerRepo-->>oneToOneOnDelete: deleted\n *   end\n *\n *   oneToOneOnDelete->>cacheModelForPopulate: context, model, key, deleted[innerRepo.pk], deleted\n *   oneToOneOnDelete-->>Caller: void\n */\nexport async function oneToOneOnDelete<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const propertyValue: any = model[key];\n  if (!propertyValue) return;\n  if (data.cascade.update !== Cascade.CASCADE) return;\n  const innerRepo: Repo<M> = repositoryFromTypeMetadata(\n    model,\n    key,\n    this.adapter.alias\n  );\n  let deleted: M;\n  if (!(propertyValue instanceof Model))\n    deleted = await innerRepo.delete(model[key] as string);\n  else\n    deleted = await innerRepo.delete(\n      (model[key] as M)[innerRepo.pk as keyof M] as string\n    );\n  await cacheModelForPopulate(\n    context,\n    model,\n    key,\n    deleted[innerRepo.pk] as string,\n    deleted\n  );\n}\n\n/**\n * @description Handles one-to-many relationship creation\n * @summary Processes a one-to-many relationship when creating a model, either by referencing existing models or creating new ones\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToManyOnCreate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToManyOnCreate\n *   participant repositoryFromTypeMetadata\n *   participant createOrUpdate\n *   participant findPrimaryKey\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToManyOnCreate: this, context, data, key, model\n *   oneToManyOnCreate->>oneToManyOnCreate: check if propertyValues exists and has length\n *   oneToManyOnCreate->>oneToManyOnCreate: check if all elements have same type\n *   oneToManyOnCreate->>oneToManyOnCreate: create uniqueValues set\n *\n *   alt arrayType is not \"object\"\n *     oneToManyOnCreate->>repositoryFromTypeMetadata: model, key\n *     repositoryFromTypeMetadata-->>oneToManyOnCreate: repo\n *     loop for each id in uniqueValues\n *       oneToManyOnCreate->>repo: read(id)\n *       repo-->>oneToManyOnCreate: read\n *       oneToManyOnCreate->>cacheModelForPopulate: context, model, key, id, read\n *     end\n *     oneToManyOnCreate->>oneToManyOnCreate: set model[key] = [...uniqueValues]\n *   else arrayType is \"object\"\n *     oneToManyOnCreate->>findPrimaryKey: propertyValues[0]\n *     findPrimaryKey-->>oneToManyOnCreate: pkName\n *     oneToManyOnCreate->>oneToManyOnCreate: create result set\n *     loop for each m in propertyValues\n *       oneToManyOnCreate->>createOrUpdate: m, context\n *       createOrUpdate-->>oneToManyOnCreate: record\n *       oneToManyOnCreate->>cacheModelForPopulate: context, model, key, record[pkName], record\n *       oneToManyOnCreate->>oneToManyOnCreate: add record[pkName] to result\n *     end\n *     oneToManyOnCreate->>oneToManyOnCreate: set model[key] = [...result]\n *   end\n *\n *   oneToManyOnCreate-->>Caller: void\n */\nexport async function oneToManyOnCreate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const propertyValues: any = model[key];\n  if (!propertyValues || !propertyValues.length) return;\n  const arrayType = typeof propertyValues[0];\n  if (!propertyValues.every((item: any) => typeof item === arrayType))\n    throw new InternalError(\n      `Invalid operation. All elements of property ${key as string} must match the same type.`\n    );\n  const uniqueValues = new Set([...propertyValues]);\n  if (arrayType !== \"object\") {\n    const repo = repositoryFromTypeMetadata(model, key, this.adapter.alias);\n    for (const id of uniqueValues) {\n      const read = await repo.read(id);\n      await cacheModelForPopulate(context, model, key, id, read);\n    }\n    (model as any)[key] = [...uniqueValues];\n    return;\n  }\n\n  const pkName = findPrimaryKey(propertyValues[0]).id;\n\n  const result: Set<string> = new Set();\n\n  for (const m of propertyValues) {\n    const record = await createOrUpdate(m, context, this.adapter.alias);\n    await cacheModelForPopulate(context, model, key, record[pkName], record);\n    result.add(record[pkName]);\n  }\n\n  (model as any)[key] = [...result];\n}\n\n/**\n * @description Handles one-to-many relationship updates\n * @summary Processes a one-to-many relationship when updating a model, delegating to oneToManyOnCreate if cascade update is enabled\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToManyOnUpdate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToManyOnUpdate\n *   participant oneToManyOnCreate\n *\n *   Caller->>oneToManyOnUpdate: this, context, data, key, model\n *   oneToManyOnUpdate->>oneToManyOnUpdate: check if cascade.update is CASCADE\n *\n *   alt cascade.update is CASCADE\n *     oneToManyOnUpdate->>oneToManyOnCreate: apply(this, [context, data, key, model])\n *     oneToManyOnCreate-->>oneToManyOnUpdate: void\n *   end\n *\n *   oneToManyOnUpdate-->>Caller: void\n */\nexport async function oneToManyOnUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const { cascade } = data;\n  if (cascade.update !== Cascade.CASCADE) return;\n  return oneToManyOnCreate.apply(this as any, [\n    context,\n    data,\n    key as keyof Model,\n    model,\n  ]);\n}\n\n/**\n * @description Handles one-to-many relationship deletion\n * @summary Processes a one-to-many relationship when deleting a model, deleting all related models if cascade delete is enabled\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToManyOnDelete\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToManyOnDelete\n *   participant Repository\n *   participant repositoryFromTypeMetadata\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToManyOnDelete: this, context, data, key, model\n *   oneToManyOnDelete->>oneToManyOnDelete: check if cascade.delete is CASCADE\n *   oneToManyOnDelete->>oneToManyOnDelete: check if values exists and has length\n *   oneToManyOnDelete->>oneToManyOnDelete: check if all elements have same type\n *\n *   alt isInstantiated (arrayType is \"object\")\n *     oneToManyOnDelete->>Repository: forModel(values[0])\n *     Repository-->>oneToManyOnDelete: repo\n *   else not instantiated\n *     oneToManyOnDelete->>repositoryFromTypeMetadata: model, key\n *     repositoryFromTypeMetadata-->>oneToManyOnDelete: repo\n *   end\n *\n *   oneToManyOnDelete->>oneToManyOnDelete: create uniqueValues set\n *\n *   loop for each id in uniqueValues\n *     oneToManyOnDelete->>repo: delete(id, context)\n *     repo-->>oneToManyOnDelete: deleted\n *     oneToManyOnDelete->>cacheModelForPopulate: context, model, key, id, deleted\n *   end\n *\n *   oneToManyOnDelete->>oneToManyOnDelete: set model[key] = [...uniqueValues]\n *   oneToManyOnDelete-->>Caller: void\n */\nexport async function oneToManyOnDelete<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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.cascade.delete !== Cascade.CASCADE) return;\n  const values = model[key] as any;\n  if (!values || !values.length) return;\n  const arrayType = typeof values[0];\n  const areAllSameType = values.every((item: any) => typeof item === arrayType);\n  if (!areAllSameType)\n    throw new InternalError(\n      `Invalid operation. All elements of property ${key as string} must match the same type.`\n    );\n  const isInstantiated = arrayType === \"object\";\n  const repo = isInstantiated\n    ? Repository.forModel(values[0], this.adapter.alias)\n    : repositoryFromTypeMetadata(model, key, this.adapter.alias);\n\n  const uniqueValues = new Set([\n    ...(isInstantiated\n      ? values.map((v: Record<string, any>) => v[repo.pk as string])\n      : values),\n  ]);\n\n  for (const id of uniqueValues.values()) {\n    const deleted = await repo.delete(id);\n    await cacheModelForPopulate(context, model, key, id, deleted);\n  }\n  (model as any)[key] = [...uniqueValues];\n}\n\n/**\n * @description Generates a key for caching populated model relationships\n * @summary Creates a unique key for storing and retrieving populated model relationships in the cache\n * @param {string} tableName - The name of the table or model\n * @param {string} fieldName - The name of the field or property\n * @param {string|number} id - The identifier of the related model\n * @return {string} A dot-separated string that uniquely identifies the relationship\n * @function getPopulateKey\n * @memberOf module:core\n */\nexport function getPopulateKey(\n  tableName: string,\n  fieldName: string,\n  id: string | number\n) {\n  return [PersistenceKeys.POPULATE, tableName, fieldName, id].join(\".\");\n}\n\n/**\n * @description Caches a model for later population\n * @summary Stores a model in the context cache for efficient retrieval during relationship population\n * @template M - The model type extending Model\n * @template F - The repository flags type\n * @param {Context<F>} context - The context for the operation\n * @param {M} parentModel - The parent model that contains the relationship\n * @param propertyKey - The property key of the relationship\n * @param {string | number} pkValue - The primary key value of the related model\n * @param {any} cacheValue - The model instance to cache\n * @return {Promise<any>} A promise that resolves with the result of the cache operation\n * @function cacheModelForPopulate\n * @memberOf module:core\n */\nexport async function cacheModelForPopulate<\n  M extends Model,\n  F extends RepositoryFlags,\n>(\n  context: Context<F>,\n  parentModel: M,\n  propertyKey: keyof M | string,\n  pkValue: string | number,\n  cacheValue: any\n) {\n  const cacheKey = getPopulateKey(\n    parentModel.constructor.name,\n    propertyKey as string,\n    pkValue\n  );\n  return context.accumulate({ [cacheKey]: cacheValue });\n}\n\n/**\n * @description Populates a model's relationship\n * @summary Retrieves and attaches related models to a model's relationship property\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function populate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant populate\n *   participant fetchPopulateValues\n *   participant getPopulateKey\n *   participant Context\n *   participant repositoryFromTypeMetadata\n *\n *   Caller->>populate: this, context, data, key, model\n *   populate->>populate: check if data.populate is true\n *   populate->>populate: get nested value and check if it exists\n *\n *   populate->>fetchPopulateValues: context, model, key, isArr ? nested : [nested]\n *\n *   fetchPopulateValues->>fetchPopulateValues: initialize variables\n *\n *   loop for each proKeyValue in propKeyValues\n *     fetchPopulateValues->>getPopulateKey: model.constructor.name, propName, proKeyValue\n *     getPopulateKey-->>fetchPopulateValues: cacheKey\n *\n *     alt try to get from cache\n *       fetchPopulateValues->>Context: get(cacheKey)\n *       Context-->>fetchPopulateValues: val\n *     else catch error\n *       fetchPopulateValues->>repositoryFromTypeMetadata: model, propName\n *       repositoryFromTypeMetadata-->>fetchPopulateValues: repo\n *       fetchPopulateValues->>repo: read(proKeyValue)\n *       repo-->>fetchPopulateValues: val\n *     end\n *\n *     fetchPopulateValues->>fetchPopulateValues: add val to results\n *   end\n *\n *   fetchPopulateValues-->>populate: results\n *   populate->>populate: set model[key] = isArr ? res : res[0]\n *   populate-->>Caller: void\n */\nexport async function populate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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.populate) return;\n  const nested: any = model[key];\n  const isArr = Array.isArray(nested);\n  if (typeof nested === \"undefined\" || (isArr && nested.length === 0)) return;\n\n  async function fetchPopulateValues(\n    c: Context<F>,\n    model: M,\n    propName: string,\n    propKeyValues: any[],\n    alias?: string\n  ) {\n    let cacheKey: string;\n    let val: any;\n    const results: M[] = [];\n    for (const proKeyValue of propKeyValues) {\n      cacheKey = getPopulateKey(model.constructor.name, propName, proKeyValue);\n      try {\n        val = await c.get(cacheKey as any);\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: any) {\n        const repo = repositoryFromTypeMetadata(model, propName, alias);\n        if (!repo) throw new InternalError(\"Could not find repo\");\n        val = await repo.read(proKeyValue);\n      }\n      results.push(val);\n    }\n    return results;\n  }\n  const res = await fetchPopulateValues(\n    context,\n    model,\n    key as string,\n    isArr ? nested : [nested],\n    this.adapter.alias\n  );\n  (model as any)[key] = isArr ? res : res[0];\n}\n\n/**\n * @description List of common JavaScript types\n * @summary An array of strings representing common JavaScript types that are not custom model types\n * @const commomTypes\n * @memberOf module:core\n */\nconst commomTypes = [\n  \"array\",\n  \"string\",\n  \"number\",\n  \"boolean\",\n  \"symbol\",\n  \"function\",\n  \"object\",\n  \"undefined\",\n  \"null\",\n  \"bigint\",\n];\n\n/**\n * @description Retrieves a repository for a model property based on its type metadata\n * @summary Examines a model property's type metadata to determine the appropriate repository for related models\n * @template M - The model type extending Model\n * @param {any} model - The model instance containing the property\n * @param propertyKey - The property key to examine\n * @return {Repo<M>} A repository for the model type associated with the property\n * @function repositoryFromTypeMetadata\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant repositoryFromTypeMetadata\n *   participant Reflect\n *   participant Validation\n *   participant Model\n *   participant Repository\n *\n *   Caller->>repositoryFromTypeMetadata: model, propertyKey\n *\n *   repositoryFromTypeMetadata->>Validation: key(Array.isArray(model[propertyKey]) ? ValidationKeys.LIST : ValidationKeys.TYPE)\n *   Validation-->>repositoryFromTypeMetadata: validationKey\n *\n *   repositoryFromTypeMetadata->>Reflect: getMetadata(validationKey, model, propertyKey)\n *   Reflect-->>repositoryFromTypeMetadata: types\n *\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: determine customTypes based on property type\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: check if types and customTypes exist\n *\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: create allowedTypes array\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: find constructorName not in commomTypes\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: check if constructorName exists\n *\n *   repositoryFromTypeMetadata->>Model: get(constructorName)\n *   Model-->>repositoryFromTypeMetadata: constructor\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: check if constructor exists\n *\n *   repositoryFromTypeMetadata->>Repository: forModel(constructor)\n *   Repository-->>repositoryFromTypeMetadata: repo\n *\n *   repositoryFromTypeMetadata-->>Caller: repo\n */\nexport function repositoryFromTypeMetadata<M extends Model>(\n  model: any,\n  propertyKey: string | keyof M,\n  alias?: string\n): Repo<M> {\n  const types = Reflect.getMetadata(\n    Validation.key(\n      Array.isArray(model[propertyKey])\n        ? ValidationKeys.LIST\n        : ValidationKeys.TYPE\n    ),\n    model,\n    propertyKey as string\n  );\n  const customTypes: any = Array.isArray(model[propertyKey])\n    ? types.clazz\n    : types.customTypes;\n  if (!types || !customTypes)\n    throw new InternalError(\n      `Failed to find types decorators for property ${propertyKey as string}`\n    );\n\n  const allowedTypes: string[] = (\n    Array.isArray(customTypes) ? [...customTypes] : [customTypes]\n  ).map((t) => (typeof t === \"function\" ? t() : t));\n  const constructorName = allowedTypes.find(\n    (t) => !commomTypes.includes(`${t}`.toLowerCase())\n  );\n  if (!constructorName)\n    throw new InternalError(\n      `Property key ${propertyKey as string} does not have a valid constructor type`\n    );\n  const constructor: Constructor<M> | undefined = Model.get(constructorName);\n  if (!constructor)\n    throw new InternalError(`No registered model found for ${constructorName}`);\n\n  return Repository.forModel(constructor, alias);\n}\n","import {\n  ConflictError,\n  onCreate,\n  onCreateUpdate,\n  onDelete,\n  onUpdate,\n  afterAny,\n  RepositoryFlags,\n  Context,\n  timestamp,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { CascadeMetadata, IndexMetadata } from \"../repository/types\";\nimport { DefaultCascade, OrderDirection } from \"../repository/constants\";\nimport {\n  Constructor,\n  Decoration,\n  list,\n  Model,\n  prop,\n  propMetadata,\n  type,\n} from \"@decaf-ts/decorator-validation\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Repo, Repository } from \"../repository/Repository\";\nimport { Condition } from \"../query/Condition\";\nimport {\n  JoinColumnOptions,\n  JoinTableMultipleColumnsOptions,\n  JoinTableOptions,\n  RelationsMetadata,\n} from \"./types\";\nimport {\n  oneToManyOnCreate,\n  oneToManyOnDelete,\n  oneToManyOnUpdate,\n  oneToOneOnCreate,\n  oneToOneOnDelete,\n  oneToOneOnUpdate,\n  populate as pop,\n} from \"./construction\";\nimport { AuthorizationError } from \"../utils\";\n\n/**\n * @description Specifies the database table name for a model\n * @summary Decorator that sets the table name for a model class in the database\n * @param {string} opts - The name of the table in the database\n * @return {Function} A decorator function that can be applied to a class\n * @function table\n * @category Class Decorators\n */\nexport function table<OPTS = string>(opts?: OPTS) {\n  return function table(target: any) {\n    const key = Adapter.key(PersistenceKeys.TABLE);\n    return Decoration.for(key)\n      .define({\n        decorator: metadata,\n        args: [key, opts || target.name.toLowerCase()],\n      })\n      .apply()(target);\n  };\n}\n\n/**\n * @description Specifies the database column name for a model property\n * @summary Decorator that maps a model property to a specific column name in the database\n * @param {string} columnName - The name of the column in the database\n * @return {Function} A decorator function that can be applied to a class property\n * @function column\n * @category Property Decorators\n */\nexport function column<OPTS = string>(columnName?: OPTS) {\n  const key = Adapter.key(PersistenceKeys.COLUMN);\n  return Decoration.for(key)\n    .define({\n      decorator: function column(k, c) {\n        return function column(obj: any, attr: any) {\n          return propMetadata(k, c || attr)(obj, attr);\n        };\n      },\n      args: [key, columnName],\n    })\n    .apply();\n}\n\n/**\n * @description Creates an index on a model property for improved query performance\n * @summary Decorator that marks a property to be indexed in the database, optionally with specific directions and compositions\n * @param {OrderDirection[]} [directions] - Optional array of sort directions for the index\n * @param {string[]} [compositions] - Optional array of property names to create a composite index\n * @return {Function} A decorator function that can be applied to a class property\n * @function index\n * @category Property Decorators\n */\nexport function index(): ReturnType<typeof propMetadata>;\nexport function index(name: string): ReturnType<typeof propMetadata>;\nexport function index(\n  directions: OrderDirection[]\n): ReturnType<typeof propMetadata>;\nexport function index(\n  directions: OrderDirection[],\n  name: string\n): ReturnType<typeof propMetadata>;\nexport function index(compositions: string[]): ReturnType<typeof propMetadata>;\nexport function index(\n  compositions: string[],\n  name: string\n): ReturnType<typeof propMetadata>;\nexport function index(\n  directions?: OrderDirection[] | string[] | string,\n  compositions?: string[] | string,\n  name?: string\n) {\n  function index(\n    directions?: OrderDirection[] | string[] | string,\n    compositions?: string[] | string,\n    name?: string\n  ) {\n    if (typeof directions === \"string\") {\n      name = directions;\n      directions = undefined;\n      compositions = undefined;\n    }\n    if (typeof compositions === \"string\") {\n      name = compositions;\n      compositions = undefined;\n    }\n    if (!compositions && directions) {\n      if (\n        directions.find(\n          (d) => ![OrderDirection.ASC, OrderDirection.DSC].includes(d as any)\n        )\n      ) {\n        compositions = directions as string[];\n        directions = undefined;\n      }\n    }\n\n    return propMetadata(\n      Repository.key(\n        `${PersistenceKeys.INDEX}${compositions && compositions.length ? `.${compositions.join(\".\")}` : \"\"}`\n      ),\n      {\n        directions: directions,\n        compositions: compositions,\n        name: name,\n      } as IndexMetadata\n    );\n  }\n\n  return Decoration.for(PersistenceKeys.INDEX)\n    .define({\n      decorator: index,\n      args: [directions, compositions, name],\n    })\n    .apply();\n}\n\n/**\n * @description Enforces uniqueness constraint during model creation and update\n * @summary Internal function used by the unique decorator to check if a property value already exists in the database\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The metadata type\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The metadata for the property\n * @param key - The property key to check for uniqueness\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the check is complete or rejects with a ConflictError\n * @function uniqueOnCreateUpdate\n * @memberOf module:core\n */\nexport async function uniqueOnCreateUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends object,\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 (!(model as any)[key]) return;\n  const existing = await this.select()\n    .where(Condition.attribute(key).eq(model[key]))\n    .execute();\n  if (existing.length)\n    throw new ConflictError(\n      `model already exists with property ${key as string} equal to ${JSON.stringify((model as any)[key], undefined, 2)}`\n    );\n}\n\n/**\n * @description Tags a property as unique\n * @summary Decorator that ensures a property value is unique across all instances of a model in the database\n * @return {Function} A decorator function that can be applied to a class property\n * @function unique\n * @category Property Decorators\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @unique()\n *   @required()\n *   username!: string;\n * }\n * ```\n */\nexport function unique() {\n  const key = Repository.key(PersistenceKeys.UNIQUE);\n  return Decoration.for(key)\n    .define(onCreateUpdate(uniqueOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\n/**\n * @description Handles user identification for ownership tracking\n * @summary Internal function used by the createdBy and updatedBy decorators to set ownership information\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The metadata for the property\n * @param key - The property key to store the user identifier\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that rejects with an AuthorizationError if user identification is not supported\n * @function createdByOnCreateUpdate\n * @memberOf module:core\n */\nexport async function createdByOnCreateUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  this: R,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  context: Context<F>,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  data: V,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  key: keyof M,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  model: M\n): Promise<void> {\n  throw new AuthorizationError(\n    \"This adapter does not support user identification\"\n  );\n}\n\n/**\n * @description Tracks the creator of a model instance\n * @summary Decorator that marks a property to store the identifier of the user who created the model instance\n * @return {Function} A decorator function that can be applied to a class property\n * @function createdBy\n * @category Property Decorators\n * @example\n * ```typescript\n * class Document extends BaseModel {\n *   @createdBy()\n *   creator!: string;\n * }\n * ```\n */\nexport function createdBy() {\n  const key = Repository.key(PersistenceKeys.CREATED_BY);\n  return Decoration.for(key)\n    .define(onCreate(createdByOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\n/**\n * @description Tracks the last updater of a model instance\n * @summary Decorator that marks a property to store the identifier of the user who last updated the model instance\n * @return {Function} A decorator function that can be applied to a class property\n * @function updatedBy\n * @category Property Decorators\n * @example\n * ```typescript\n * class Document extends BaseModel {\n *   @updatedBy()\n *   lastEditor!: string;\n * }\n * ```\n */\nexport function updatedBy() {\n  const key = Repository.key(PersistenceKeys.UPDATED_BY);\n  return Decoration.for(key)\n    .define(onCreateUpdate(createdByOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\nexport function createdAt() {\n  return timestamp([OperationKeys.CREATE]);\n}\n\nexport function updatedAt() {\n  return timestamp();\n}\n\n/**\n * @description Defines a one-to-one relationship between models\n * @summary Decorator that establishes a one-to-one relationship between the current model and another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function oneToOne\n * @category Property Decorators\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @oneToOne(Profile)\n *   profile!: string | Profile;\n * }\n *\n * class Profile extends BaseModel {\n *   @required()\n *   bio!: string;\n * }\n * ```\n * @see oneToMany\n * @see manyToOne\n */\nexport function oneToOne<M extends Model>(\n  clazz: Constructor<M> | (() => Constructor<M>),\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true,\n  joinColumnOpts?: JoinColumnOptions,\n  fk?: string\n) {\n  const key = Repository.key(PersistenceKeys.ONE_TO_ONE);\n  // Model.register(clazz as Constructor<M>);\n\n  function oneToOneDec(\n    clazz: Constructor<M> | (() => Constructor<M>),\n    cascade: CascadeMetadata,\n    populate: boolean,\n    joinColumnOpts?: JoinColumnOptions,\n    fk?: string\n  ) {\n    const meta: RelationsMetadata = {\n      class: clazz.name ? clazz.name : (clazz as any),\n      cascade: cascade,\n      populate: populate,\n    };\n    if (joinColumnOpts) meta.joinTable = joinColumnOpts;\n    if (fk) meta.name = fk;\n    return apply(\n      prop(PersistenceKeys.RELATIONS),\n      type([\n        clazz.name ? clazz.name : (clazz as any),\n        String.name,\n        Number.name,\n        BigInt.name,\n      ]),\n      onCreate(oneToOneOnCreate, meta),\n      onUpdate(oneToOneOnUpdate, meta),\n      onDelete(oneToOneOnDelete, meta),\n      afterAny(pop, meta),\n      propMetadata(key, meta)\n    );\n  }\n\n  return Decoration.for(key)\n    .define({\n      decorator: oneToOneDec,\n      args: [clazz, cascadeOptions, populate, joinColumnOpts, fk],\n    })\n    .apply();\n}\n\n/**\n * @description Defines a one-to-many relationship between models\n * @summary Decorator that establishes a one-to-many relationship between the current model and multiple instances of another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function oneToMany\n * @category Property Decorators\n * @example\n * ```typescript\n * class Author extends BaseModel {\n *   @required()\n *   name!: string;\n *\n *   @oneToMany(Book)\n *   books!: string[] | Book[];\n * }\n *\n * class Book extends BaseModel {\n *   @required()\n *   title!: string;\n * }\n * ```\n * @see oneToOne\n * @see manyToOne\n */\nexport function oneToMany<M extends Model>(\n  clazz: Constructor<M> | (() => Constructor<M>),\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true,\n  joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n  fk?: string\n) {\n  const key = Repository.key(PersistenceKeys.ONE_TO_MANY);\n\n  function oneToManyDec(\n    clazz: Constructor<M> | (() => Constructor<M>),\n    cascade: CascadeMetadata,\n    populate: boolean,\n    joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n    fk?: string\n  ) {\n    const metadata: RelationsMetadata = {\n      class: clazz.name ? clazz.name : (clazz as any),\n      cascade: cascade,\n      populate: populate,\n    };\n    if (joinTableOpts) metadata.joinTable = joinTableOpts;\n    if (fk) metadata.name = fk;\n    return apply(\n      prop(PersistenceKeys.RELATIONS),\n      list([\n        clazz as Constructor<M>,\n        String,\n        Number,\n        // @ts-expect-error Bigint is not a constructor\n        BigInt,\n      ]),\n      onCreate(oneToManyOnCreate, metadata),\n      onUpdate(oneToManyOnUpdate, metadata),\n      onDelete(oneToManyOnDelete, metadata),\n      afterAny(pop, metadata),\n      propMetadata(key, metadata)\n    );\n  }\n\n  return Decoration.for(key)\n    .define({\n      decorator: oneToManyDec,\n      args: [clazz, cascadeOptions, populate, joinTableOpts, fk],\n    })\n    .apply();\n}\n\n/**\n * @description Defines a many-to-one relationship between models\n * @summary Decorator that establishes a many-to-one relationship between multiple instances of the current model and another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function manyToOne\n * @category Property Decorators\n * @example\n * ```typescript\n * class Book extends BaseModel {\n *   @required()\n *   title!: string;\n *\n *   @manyToOne(Author)\n *   author!: string | Author;\n * }\n *\n * class Author extends BaseModel {\n *   @required()\n *   name!: string;\n * }\n * ```\n * @see oneToMany\n * @see oneToOne\n */\nexport function manyToOne<M extends Model>(\n  clazz: Constructor<M> | (() => Constructor<M>),\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate = true,\n  joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n  fk?: string\n) {\n  // Model.register(clazz as Constructor<M>);\n  const key = Repository.key(PersistenceKeys.MANY_TO_ONE);\n\n  function manyToOneDec(\n    clazz: Constructor<M> | (() => Constructor<M>),\n    cascade: CascadeMetadata,\n    populate: boolean,\n    joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n    fk?: string\n  ) {\n    const clazzName = () =>\n      (clazz?.name ? clazz : (clazz as () => Constructor<M>)()).name;\n\n    const metadata: RelationsMetadata = {\n      class: clazz?.name ? clazz.name : (clazz as any),\n      cascade: cascade,\n      populate: populate,\n    };\n    if (joinTableOpts) metadata.joinTable = joinTableOpts;\n    if (fk) metadata.name = fk;\n    return apply(\n      prop(PersistenceKeys.RELATIONS),\n      type([clazzName, String.name, Number.name, BigInt.name]),\n      // onCreate(oneToManyOnCreate, metadata),\n      // onUpdate(oneToManyOnUpdate, metadata),\n      // onDelete(oneToManyOnDelete, metadata),\n      // afterAny(pop, metadata),\n      propMetadata(key, metadata)\n    );\n  }\n\n  return Decoration.for(key)\n    .define({\n      decorator: manyToOneDec,\n      args: [clazz, cascadeOptions, populate, joinTableOpts, fk],\n    })\n    .apply();\n}\n\n/**\n * @description Defines a many-to-one relationship between models\n * @summary Decorator that establishes a many-to-one relationship between multiple instances of the current model and another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function manyToOne\n * @category Property Decorators\n * @example\n * ```typescript\n * class Book extends BaseModel {\n *   @required()\n *   title!: string;\n *\n *   @manyToOne(Author)\n *   author!: string | Author;\n * }\n *\n * class Author extends BaseModel {\n *   @required()\n *   name!: string;\n * }\n * ```\n * @see oneToMany\n * @see oneToOne\n */\nexport function manyToMany<M extends Model>(\n  clazz: Constructor<M> | (() => Constructor<M>),\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate = true,\n  joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n  fk?: string\n) {\n  // Model.register(clazz as Constructor<M>);\n  const key = Repository.key(PersistenceKeys.MANY_TO_MANY);\n\n  function manyToManyDec(\n    clazz: Constructor<M> | (() => Constructor<M>),\n    cascade: CascadeMetadata,\n    populate: boolean,\n    joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n    fk?: string\n  ) {\n    const metadata: RelationsMetadata = {\n      class: clazz.name ? clazz.name : (clazz as any),\n      cascade: cascade,\n      populate: populate,\n    };\n    if (joinTableOpts) metadata.joinTable = joinTableOpts;\n    if (fk) metadata.name = fk;\n    return apply(\n      prop(PersistenceKeys.RELATIONS),\n      list([\n        clazz.name ? clazz.name : (clazz as any),\n        String.name,\n        Number.name,\n        BigInt.name,\n      ]),\n      // onCreate(oneToManyOnCreate, metadata),\n      // onUpdate(oneToManyOnUpdate, metadata),\n      // onDelete(oneToManyOnDelete, metadata),\n      // afterAll(populate, metadata),\n      propMetadata(key, metadata)\n    );\n  }\n  return Decoration.for(key)\n    .define({\n      decorator: manyToManyDec,\n      args: [clazz, cascadeOptions, populate, joinTableOpts, fk],\n    })\n    .apply();\n}\n","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  GroupSort,\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\nconst defaultPkPriority = 60; // Default priority for primary key to run latter than other properties\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, groupsort?: GroupSort) {\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, groupsort),\n        propMetadata(DBKeys.ID, attr)\n      )(obj, attr);\n    };\n  }\n  return Decoration.for(key)\n    .define({\n      decorator: pkDec,\n      args: [opts, { priority: defaultPkPriority }],\n    })\n    .apply();\n}\n","import { ModelArg, Model } from \"@decaf-ts/decorator-validation\";\nimport { createdAt, updatedAt } from \"./decorators\";\n\n/**\n * @description Base model class for all domain models\n * @summary An abstract base class that extends the Model class from decorator-validation and adds timestamp functionality.\n * All domain models in the application should extend this class to inherit common properties and behaviors.\n * @param {ModelArg<BaseModel>} arg - Optional initialization data for the model\n * @class BaseModel\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @required()\n *   username!: string;\n *   \n *   @email()\n *   email!: string;\n *   \n *   constructor(data?: ModelArg<User>) {\n *     super(data);\n *   }\n * }\n * \n * const user = new User({ username: 'john', email: 'john@example.com' });\n * ```\n */\nexport abstract class BaseModel extends Model {\n  /**\n   * @description Creation timestamp for the model\n   * @summary Automatically set to the current date and time when the model is created\n   */\n  @createdAt()\n  createdOn!: Date;\n\n  /**\n   * @description Last update timestamp for the model\n   * @summary Automatically updated to the current date and time whenever the model is modified\n   */\n  @updatedAt()\n  updatedOn!: Date;\n\n  protected constructor(arg?: ModelArg<BaseModel>) {\n    super(arg);\n  }\n}\n","import { PagingError } from \"./errors\";\nimport { Adapter } from \"../persistence\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\n\n/**\n * @description Handles pagination for database queries\n * @summary Provides functionality for navigating through paginated query results\n *\n * This abstract class manages the state and navigation of paginated database query results.\n * It tracks the current page, total pages, and record count, and provides methods for\n * moving between pages.\n *\n * @template M - The model type this paginator operates on\n * @template R - The return type of the paginated query (defaults to M[])\n * @template Q - The query type (defaults to any)\n * @param {Adapter<any, Q, any, any>} adapter - The database adapter to use for executing queries\n * @param {Q} query - The query to paginate\n * @param {number} size - The number of records per page\n * @param {Constructor<M>} clazz - The constructor for the model type\n * @class Paginator\n * @example\n * // Create a paginator for a user query\n * const userQuery = db.select().from(User);\n * const paginator = await userQuery.paginate(10); // 10 users per page\n *\n * // Get the first page of results\n * const firstPage = await paginator.page(1);\n *\n * // Navigate to the next page\n * const secondPage = await paginator.next();\n *\n * // Get information about the pagination\n * console.log(`Page ${paginator.current} of ${paginator.total}, ${paginator.count} total records`);\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Paginator\n *   participant Adapter\n *   participant Database\n *\n *   Client->>Paginator: new Paginator(adapter, query, size, clazz)\n *   Client->>Paginator: page(1)\n *   Paginator->>Paginator: validatePage(1)\n *   Paginator->>Paginator: prepare(query)\n *   Paginator->>Adapter: execute query with pagination\n *   Adapter->>Database: execute query\n *   Database-->>Adapter: return results\n *   Adapter-->>Paginator: return results\n *   Paginator-->>Client: return page results\n *\n *   Client->>Paginator: next()\n *   Paginator->>Paginator: page(current + 1)\n *   Paginator->>Paginator: validatePage(current + 1)\n *   Paginator->>Adapter: execute query with pagination\n *   Adapter->>Database: execute query\n *   Database-->>Adapter: return results\n *   Adapter-->>Paginator: return results\n *   Paginator-->>Client: return page results\n */\nexport abstract class Paginator<M extends Model, R = M[], Q = any> {\n  protected _currentPage!: number;\n  protected _totalPages!: number;\n  protected _recordCount!: number;\n  protected limit!: number;\n\n  private _statement?: Q;\n\n  get current() {\n    return this._currentPage;\n  }\n\n  get total() {\n    return this._totalPages;\n  }\n\n  get count(): number {\n    return this._recordCount;\n  }\n\n  protected get statement() {\n    if (!this._statement) this._statement = this.prepare(this.query);\n    return this._statement;\n  }\n\n  protected constructor(\n    protected readonly adapter: Adapter<any, any, Q, any, any>,\n    protected readonly query: Q,\n    readonly size: number,\n    protected readonly clazz: Constructor<M>\n  ) {}\n\n  protected abstract prepare(rawStatement: Q): Q;\n\n  async next() {\n    return this.page(this.current + 1);\n  }\n\n  async previous() {\n    return this.page(this.current - 1);\n  }\n\n  protected validatePage(page: number) {\n    if (page < 1 || !Number.isInteger(page))\n      throw new PagingError(\n        \"Page number cannot be under 1 and must be an integer\"\n      );\n    if (typeof this._totalPages !== \"undefined\" && page > this._totalPages)\n      throw new PagingError(\n        `Only ${this._totalPages} are available. Cannot go to page ${page}`\n      );\n    return page;\n  }\n\n  abstract page(page?: number): Promise<R[]>;\n}\n","import { type Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport type { Executor, RawExecutor } from \"../interfaces\";\nimport type {\n  FromSelector,\n  GroupBySelector,\n  OrderBySelector,\n  SelectSelector,\n} from \"./selectors\";\nimport { Condition } from \"./Condition\";\nimport { findPrimaryKey, InternalError } from \"@decaf-ts/db-decorators\";\nimport { final } from \"../utils/decorators\";\nimport type {\n  CountOption,\n  DistinctOption,\n  LimitOption,\n  MaxOption,\n  MinOption,\n  OffsetOption,\n  OrderAndGroupOption,\n  SelectOption,\n  WhereOption,\n} from \"./options\";\nimport { Paginatable } from \"../interfaces/Paginatable\";\nimport { Paginator } from \"./Paginator\";\nimport { Adapter } from \"../persistence\";\nimport { QueryError } from \"./errors\";\nimport { Logger } from \"@decaf-ts/logging\";\nimport { LoggedClass } from \"@decaf-ts/logging\";\n\n/**\n * @description Base class for database query statements\n * @summary Provides a foundation for building and executing database queries\n *\n * This abstract class implements the query builder pattern for constructing\n * database queries. It supports various query operations like select, from,\n * where, orderBy, groupBy, limit, and offset. It also provides methods for\n * executing queries and handling pagination.\n *\n * @template Q - The query type specific to the database adapter\n * @template M - The model type this statement operates on\n * @template R - The return type of the query\n * @param {Adapter<any, Q, any, any>} adapter - The database adapter to use for executing queries\n * @class Statement\n * @example\n * // Create a statement to query users\n * const statement = new SQLStatement(adapter);\n * const users = await statement\n *   .select()\n *   .from(User)\n *   .where(Condition.attribute(\"status\").eq(\"active\"))\n *   .orderBy([\"createdAt\", \"DESC\"])\n *   .limit(10)\n *   .execute();\n *\n * // Use pagination\n * const paginator = await statement\n *   .select()\n *   .from(User)\n *   .paginate(20); // 20 users per page\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Statement\n *   participant Adapter\n *   participant Database\n *\n *   Client->>Statement: select()\n *   Client->>Statement: from(Model)\n *   Client->>Statement: where(condition)\n *   Client->>Statement: orderBy([field, direction])\n *   Client->>Statement: limit(value)\n *   Client->>Statement: execute()\n *   Statement->>Statement: build()\n *   Statement->>Adapter: raw(query)\n *   Adapter->>Database: execute query\n *   Database-->>Adapter: return results\n *   Adapter-->>Statement: return processed results\n *   Statement-->>Client: return final results\n */\nexport abstract class Statement<Q, M extends Model, R>\n  extends LoggedClass\n  implements Executor<R>, RawExecutor<Q>, Paginatable<M, R, Q>\n{\n  protected readonly selectSelector?: SelectSelector<M>[];\n  protected distinctSelector?: SelectSelector<M>;\n  protected maxSelector?: SelectSelector<M>;\n  protected minSelector?: SelectSelector<M>;\n  protected countSelector?: SelectSelector<M>;\n  protected fromSelector!: Constructor<M>;\n  protected whereCondition?: Condition<M>;\n  protected orderBySelector?: OrderBySelector<M>;\n  protected groupBySelector?: GroupBySelector<M>;\n  protected limitSelector?: number;\n  protected offsetSelector?: number;\n\n  protected constructor(protected adapter: Adapter<any, any, Q, any, any>) {\n    super();\n  }\n\n  protected override get log(): Logger {\n    return (this.adapter as any).log.for(Statement);\n  }\n\n  select<\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    S extends readonly SelectSelector<M>[],\n  >(): SelectOption<M, M[]>;\n  select<S extends readonly SelectSelector<M>[]>(\n    selector: readonly [...S]\n  ): SelectOption<M, Pick<M, S[number]>[]>;\n\n  @final()\n  select<S extends readonly SelectSelector<M>[]>(\n    selector?: readonly [...S]\n  ): SelectOption<M, M[]> | SelectOption<M, Pick<M, S[number]>[]> {\n    Object.defineProperty(this, \"selectSelector\", {\n      value: selector,\n      writable: false,\n    });\n    return this as SelectOption<M, M[]> | SelectOption<M, Pick<M, S[number]>[]>;\n  }\n\n  @final()\n  distinct<S extends SelectSelector<M>>(\n    selector: S\n  ): DistinctOption<M, M[S][]> {\n    this.distinctSelector = selector;\n    return this as DistinctOption<M, M[S][]>;\n  }\n\n  @final()\n  max<S extends SelectSelector<M>>(selector: S): MaxOption<M, M[S]> {\n    this.maxSelector = selector;\n    return this as MaxOption<M, M[S]>;\n  }\n\n  @final()\n  min<S extends SelectSelector<M>>(selector: S): MinOption<M, M[S]> {\n    this.minSelector = selector;\n    return this as MinOption<M, M[S]>;\n  }\n\n  @final()\n  count<S extends SelectSelector<M>>(selector?: S): CountOption<M, number> {\n    this.countSelector = selector;\n    return this as CountOption<M, number>;\n  }\n\n  @final()\n  public from(selector: FromSelector<M>): WhereOption<M, R> {\n    this.fromSelector = (\n      typeof selector === \"string\" ? Model.get(selector) : selector\n    ) as Constructor<M>;\n    if (!this.fromSelector)\n      throw new QueryError(`Could not find selector model: ${selector}`);\n    return this;\n  }\n\n  @final()\n  public where(condition: Condition<M>): OrderAndGroupOption<M, R> {\n    this.whereCondition = condition;\n    return this;\n  }\n\n  @final()\n  public orderBy(\n    selector: OrderBySelector<M>\n  ): LimitOption<M, R> & OffsetOption<R> {\n    this.orderBySelector = selector;\n    return this;\n  }\n\n  @final()\n  public groupBy(selector: GroupBySelector<M>): LimitOption<M, R> {\n    this.groupBySelector = selector;\n    return this;\n  }\n\n  @final()\n  public limit(value: number): OffsetOption<R> {\n    this.limitSelector = value;\n    return this;\n  }\n\n  @final()\n  public offset(value: number): Executor<R> {\n    this.offsetSelector = value;\n    return this;\n  }\n\n  @final()\n  async execute(): Promise<R> {\n    try {\n      const query: Q = this.build();\n      return (await this.raw(query)) as R;\n    } catch (e: unknown) {\n      throw new InternalError(e as Error);\n    }\n  }\n\n  async raw<R>(rawInput: Q): Promise<R> {\n    const results = await this.adapter.raw<R>(rawInput);\n    if (!this.selectSelector) return results;\n    const pkAttr = findPrimaryKey(\n      new (this.fromSelector as Constructor<M>)()\n    ).id;\n\n    const processor = function recordProcessor(\n      this: Statement<Q, M, R>,\n      r: any\n    ) {\n      const id = r[pkAttr];\n      return this.adapter.revert(\n        r,\n        this.fromSelector as Constructor<any>,\n        pkAttr,\n        id\n      ) as any;\n    }.bind(this as any);\n\n    if (Array.isArray(results)) return results.map(processor) as R;\n    return processor(results) as R;\n  }\n\n  protected abstract build(): Q;\n  protected abstract parseCondition(condition: Condition<M>, ...args: any[]): Q;\n  abstract paginate(size: number): Promise<Paginator<M, R, Q>>;\n}\n","import { Condition } from \"./Condition\";\nimport { OrderBySelector } from \"./selectors\";\n\n/**\n * @description\n * Options for configuring query building behavior.\n *\n * @summary\n * The `QueryOptions` type defines flags that determine whether certain clauses\n * (limit, offset, order by) are permitted, as well as whether violations\n * should throw an error during query construction.\n *\n * @memberOf module:query\n */\nexport type QueryOptions = {\n  allowLimit?: boolean;\n  allowOffset?: boolean;\n  allowOrderBy?: boolean;\n  throws?: boolean;\n};\n\n/**\n * @description\n * Structured query object representing parsed query clauses.\n *\n * @summary\n * The `QueryAssist` interface defines the standard structure returned\n * by query builders. It includes actions such as find, optional clauses\n * like select, groupBy, and orderBy, and pagination controls (limit, offset).\n *\n * @template T The entity or record type that conditions may apply to.\n *\n * @interface QueryAssist\n * @memberOf module:query\n */\nexport interface QueryAssist {\n  action: \"find\";\n  select: undefined | string[];\n  where: Condition<any>;\n  groupBy?: string[];\n  orderBy?: OrderBySelector<any>[];\n  limit: number | undefined;\n  offset: number | undefined;\n}\n\n/**\n * @description\n * Enumeration of supported query clauses for building method-based queries.\n *\n * @summary\n * The `QueryClause` enum defines string literals that represent\n * different segments of a query (e.g., `findBy`, `Select`, `And`, `Or`).\n *\n * @enum QueryClause\n * @memberOf module:query\n */\nexport enum QueryClause {\n  FIND_BY = \"findBy\",\n  SELECT = \"Select\",\n  AND = \"And\",\n  OR = \"Or\",\n  GROUP_BY = \"GroupBy\",\n  ORDER_BY = \"OrderBy\",\n  THEN = \"Then\",\n  THEN_BY = \"ThenBy\",\n}\n\n/**\n * @description\n * Function signature for parsing operators in query building.\n *\n * @summary\n * The `OperatorParser` type represents a function that takes a field name\n * and arguments, then produces a `Condition` object that can be used in a query.\n *\n * @template T The type of the condition result.\n *\n * @param field {string} - The name of the field being parsed.\n * @param args {any[]} - Additional arguments for operator evaluation.\n *\n * @return {Condition<any>} A condition object representing the parsed operator.\n *\n * @memberOf module:query\n */\nexport type OperatorParser = (field: string, ...args: any) => Condition<any>;\n\n/**\n * @description\n * Descriptor for fields and their associated operators in query parsing.\n *\n * @summary\n * The `FilterDescriptor` interface defines the structure used when parsing\n * method segments into filterable fields and associated operators.\n *\n * @interface FilterDescriptor\n * @memberOf module:query\n */\nexport interface FilterDescriptor {\n  field: string;\n  operator?: string;\n}\n","import { Condition } from \"./Condition\";\nimport { OperatorParser } from \"./types\";\n\n/**\n * @description\n * Map of supported operators to their corresponding parser functions.\n *\n * @summary\n * The `OperatorsMap` defines a collection of operator names as keys\n * (such as `Equals`, `LessThan`, `Between`, etc.), each mapped to a\n * function that constructs a `Condition` object for that operator.\n * These functions translate query clauses into concrete condition\n * builders, enabling dynamic query construction from method names.\n *\n * @template T The type of the field values used in conditions.\n *\n * @param f {string} - The field name the condition applies to.\n * @param v1 {any} - The value to compare the field against or the lower bound value for range-based operators.\n * @param v2 {any} - The upper bound value for range-based operators.\n *\n * @return {Condition<any>} A condition object representing the operator applied to the field.\n *\n * @function OperatorsMap\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client as Caller\n *   participant Map as OperatorsMap\n *   participant Parser as OperatorParser\n *   participant Cond as Condition\n *\n *   Client->>Map: Request operator parser (\"Between\", field, v1, v2)\n *   Map->>Parser: Call corresponding operator function\n *   Parser->>Cond: Condition.attribute(field)\n *   Cond-->>Parser: Condition instance\n *   Parser->>Cond: Apply gte(v1)\n *   Parser->>Cond: Apply and(lte(v2))\n *   Parser-->>Client: Return built Condition\n *\n * @memberOf module:query\n */\nexport const OperatorsMap: Record<string, OperatorParser> = {\n  Equals: (f, v) => Condition.attribute(f as any).eq(v),\n  Diff: (f, v) => Condition.attribute(f as any).dif(v),\n  LessThan: (f, v) => Condition.attribute(f as any).lt(v),\n  LessThanEqual: (f, v) => Condition.attribute(f as any).lte(v),\n  GreaterThan: (f, v) => Condition.attribute(f as any).gt(v),\n  GreaterThanEqual: (f, v) => Condition.attribute(f as any).gte(v),\n  Between: (f, v1, v2) =>\n    Condition.attribute(f as any)\n      .gte(v1)\n      .and(Condition.attribute(f as any).lte(v2)),\n  In: (f, v) => Condition.attribute(f as any).in(v),\n  Matches: (f, v) => Condition.attribute(f as any).regexp(v),\n};\n","import { Condition, OrderBySelector } from \"../query\";\nimport { FilterDescriptor, QueryAssist, QueryClause } from \"./types\";\nimport { OperatorsMap } from \"./utils\";\n\nconst lowerFirst = (str: string): string =>\n  str.charAt(0).toLowerCase() + str.slice(1);\n\nexport type OrderLimitOffsetExtract = {\n  orderBy?: OrderBySelector<any>[];\n  limit?: number;\n  offset?: number;\n};\n\n/**\n * @description\n * Utility class to build query objects from repository method names.\n *\n * @summary\n * The `MethodQueryBuilder` class parses method names that follow a specific naming convention\n * (e.g., `findByNameAndAgeOrderByCountryAsc`) and converts them into structured query objects\n * (`QueryAssist`). It extracts clauses such as `select`, `where`, `groupBy`, `orderBy`, `limit`,\n * and `offset`, ensuring that developers can declare repository queries using expressive method names.\n *\n * @param methodName {string} - The repository method name to parse and convert into a query.\n * @param values {any[]} - The values corresponding to method parameters used for query conditions.\n *\n * @return {QueryAssist} A structured query object describing the parsed action, select, where,\n * groupBy, orderBy, limit, and offset clauses.\n *\n * @class\n *\n * @example\n * ```ts\n * const query = MethodQueryBuilder.build(\n *   \"findByNameAndAgeOrderByCountryAsc\",\n *   \"John\",\n *   25,\n *   [[\"country\", \"ASC\"]]\n * );\n *\n * console.log(query);\n * // {\n * //   action: \"find\",\n * //   select: undefined,\n * //   where: { ... },\n * //   groupBy: undefined,\n * //   orderBy: [[\"country\", \"ASC\"]],\n * //   limit: undefined,\n * //   offset: undefined\n * // }\n * ```\n *\n * @mermaid\n * sequenceDiagram\n *   participant Repo as Repository Method\n *   participant MQB as MethodQueryBuilder\n *   participant Query as QueryAssist\n *\n *   Repo->>MQB: build(methodName, ...values)\n *   MQB->>MQB: extractCore(methodName)\n *   MQB->>MQB: extractSelect(methodName)\n *   MQB->>MQB: extractGroupBy(methodName)\n *   MQB->>MQB: buildWhere(core, values)\n *   MQB->>MQB: extractOrderLimitOffset(core, values)\n *   MQB->>Query: return structured QueryAssist object\n */\nexport class MethodQueryBuilder {\n  /**\n   * @description\n   * Builds a `QueryAssist` object by parsing a repository method name and values.\n   *\n   * @summary\n   * The method validates the method name, extracts clauses (core, select, groupBy, where,\n   * orderBy, limit, and offset), and assembles them into a structured query object\n   * that can be executed against a data source.\n   *\n   * @param methodName {string} - The repository method name that encodes query information.\n   * @param values {any[]} - The values corresponding to conditions and extra clauses.\n   *\n   * @return {QueryAssist} A structured query object representing the parsed query.\n   */\n  static build(methodName: string, ...values: any[]): QueryAssist {\n    if (!methodName.startsWith(QueryClause.FIND_BY)) {\n      throw new Error(`Unsupported method ${methodName}`);\n    }\n\n    const core = this.extractCore(methodName);\n    const select = this.extractSelect(methodName);\n    const groupBy = this.extractGroupBy(methodName);\n    // const orderBy = this.extractOrderBy(methodName);\n    const where = this.buildWhere(core, values);\n    const { orderBy, limit, offset } = this.extractOrderLimitOffset(\n      core,\n      values\n    );\n\n    return {\n      action: \"find\",\n      select: select,\n      where,\n      groupBy,\n      orderBy,\n      limit,\n      offset,\n    };\n  }\n\n  /**\n   * @description\n   * Extracts the core part of the method name after `findBy` and before any special clauses.\n   *\n   * @summary\n   * Removes prefixes and detects delimiters (`Then`, `OrderBy`, `GroupBy`, `Limit`, `Offset`)\n   * to isolate the main conditional part of the query.\n   *\n   * @param methodName {string} - The method name to parse.\n   *\n   * @return {string} The extracted core string used for building conditions.\n   */\n  private static extractCore(methodName: string): string {\n    const afterFindBy = methodName.substring(QueryClause.FIND_BY.length);\n    const regex = /(Then[A-Z]|OrderBy|GroupBy|Limit|Offset)/;\n    const match = afterFindBy.match(regex);\n    return match ? afterFindBy.substring(0, match.index) : afterFindBy;\n  }\n\n  /**\n   * @description\n   * Extracts the select clause from a method name.\n   *\n   * @summary\n   * Detects the `Select` keyword in the method name, isolates the fields following it,\n   * and returns them as an array of lowercase-first strings.\n   *\n   * @param methodName {string} - The method name to parse.\n   *\n   * @return {string[] | undefined} An array of selected fields or `undefined` if no select clause exists.\n   */\n  private static extractSelect(methodName: string): string[] | undefined {\n    const selectIndex = methodName.indexOf(QueryClause.SELECT);\n    if (selectIndex === -1) return undefined;\n\n    const afterSelect = methodName.substring(\n      selectIndex + QueryClause.SELECT.length\n    );\n\n    // Search for next Then, GroupBy, OrderBy...\n    const match = afterSelect.match(/(Then[A-Z]|OrderBy|GroupBy|Limit|Offset)/);\n\n    const selectPart = match\n      ? afterSelect.substring(0, match.index)\n      : afterSelect;\n\n    return selectPart.split(QueryClause.AND).map(lowerFirst).filter(Boolean);\n  }\n\n  /**\n   * @description\n   * Extracts the group by clause from a method name.\n   *\n   * @summary\n   * Detects the `GroupBy` keyword in the method name, isolates the fields following it,\n   * and returns them as an array of lowercase-first strings.\n   *\n   * @param methodName {string} - The method name to parse.\n   *\n   * @return {string[] | undefined} An array of group by fields or `undefined` if no group by clause exists.\n   */\n  private static extractGroupBy(methodName: string): string[] | undefined {\n    const groupByIndex = methodName.indexOf(QueryClause.GROUP_BY);\n    if (groupByIndex === -1) return undefined;\n\n    const after = methodName.substring(\n      groupByIndex + QueryClause.GROUP_BY.length\n    );\n    const groupByPart = after.split(QueryClause.ORDER_BY)[0];\n    return groupByPart\n      .split(QueryClause.THEN_BY)\n      .map(lowerFirst)\n      .filter(Boolean);\n  }\n\n  // private static extractOrderBy(\n  //   methodName: string\n  // ): OrderBySelector<any>[] | undefined {\n  //   const orderByIndex = methodName.indexOf(QueryClause.ORDER_BY);\n  //   if (orderByIndex === -1) return undefined;\n  //\n  //   const after = methodName.substring(\n  //     orderByIndex + QueryClause.ORDER_BY.length\n  //   );\n  //   const orderParts = after.split(\"ThenBy\");\n  //\n  //   return orderParts.map((part) => {\n  //     const match = part.match(/(.*?)(Asc|Desc|Dsc)$/);\n  //     if (!match) throw new Error(`Invalid OrderBy part: ${part}`);\n  //     const [, field, dir] = match;\n  //     return [\n  //       lowerFirst(field),\n  //       dir.toLowerCase() === \"dsc\"\n  //         ? OrderDirection.DSC\n  //         : (dir.toLowerCase() as OrderDirection),\n  //     ];\n  //   });\n  // }\n\n  /**\n   * @description\n   * Builds the `where` condition object based on the parsed core string and parameter values.\n   *\n   * @summary\n   * Splits the core string by logical operators (`And`, `Or`), parses each token into a field\n   * and operator, and combines them into a `Condition` object using the provided values.\n   *\n   * @param core {string} - The extracted core string from the method name.\n   * @param values {any[]} - The values corresponding to the conditions.\n   *\n   * @return {Condition<any>} A structured condition object representing the query's where clause.\n   */\n  private static buildWhere(core: string, values: any[]): Condition<any> {\n    const parts = core.split(/OrderBy|GroupBy/)[0] || \"\";\n    const conditions = parts.split(/And|Or/);\n\n    const operators = core.match(/And|Or/g) || [];\n\n    let where: Condition<any> | undefined;\n\n    conditions.forEach((token, idx) => {\n      const { field, operator } = this.parseFieldAndOperator(token);\n      const parser = operator ? OperatorsMap[operator] : OperatorsMap.Equals;\n      if (!parser) throw new Error(`Unsupported operator ${operator}`);\n\n      const conditionValue = values[idx];\n      if (typeof conditionValue === \"undefined\") {\n        throw new Error(`Invalid value for field ${field}`);\n      }\n\n      const condition = parser(field, conditionValue);\n      where =\n        idx === 0\n          ? condition\n          : operators[idx - 1] === QueryClause.AND\n            ? where!.and(condition)\n            : where!.or(condition);\n    });\n\n    if (!where) throw new Error(\"No conditions found in method name\");\n    return where;\n  }\n\n  /**\n   * @description\n   * Parses a field name and operator from a string token.\n   *\n   * @summary\n   * Identifies the operator suffix (if present) and returns a descriptor containing the field\n   * name in lowercase-first format along with the operator.\n   *\n   * @param str {string} - The token string to parse.\n   *\n   * @return {FilterDescriptor} An object containing the field name and operator.\n   */\n  private static parseFieldAndOperator(str: string): FilterDescriptor {\n    for (const operator of Object.keys(OperatorsMap)) {\n      if (str.endsWith(operator)) {\n        const field = str.slice(0, -operator.length);\n        return { field: lowerFirst(field), operator };\n      }\n    }\n    return { field: lowerFirst(str) };\n  }\n\n  /**\n   * @description\n   * Extracts `orderBy`, `limit`, and `offset` clauses from method arguments.\n   *\n   * @summary\n   * Determines the number of condition arguments, then checks the remaining arguments\n   * to resolve sorting, limiting, and pagination.\n   *\n   * @param core {string} - The extracted core string from the method name.\n   * @param values {any[]} - The values corresponding to method arguments, including conditions and extras.\n   *\n   * @return {OrderLimitOffsetExtract} An object containing orderBy, limit, and offset values if present.\n   */\n  private static extractOrderLimitOffset(\n    core: string,\n    values: any[]\n  ): OrderLimitOffsetExtract {\n    const conditionCount = core.split(/And|Or/).length;\n    const extraArgs = values.slice(conditionCount);\n\n    let orderBy: OrderBySelector<any>[] | undefined;\n    let limit: number | undefined;\n    let offset: number | undefined;\n\n    if (extraArgs.length >= 1 && Array.isArray(extraArgs[0]))\n      orderBy = extraArgs[0] as OrderBySelector<any>[];\n\n    if (extraArgs.length >= 2 && typeof extraArgs[1] === \"number\")\n      limit = extraArgs[1];\n\n    if (extraArgs.length >= 3 && typeof extraArgs[2] === \"number\")\n      offset = extraArgs[2];\n\n    return { orderBy, limit, offset };\n  }\n}\n","import { QueryOptions } from \"./types\";\nimport { MethodQueryBuilder } from \"./MethodQueryBuilder\";\nimport { QueryError } from \"./errors\";\n\nexport function query(options: QueryOptions = {}) {\n  return (\n    target: object,\n    propertyKey?: any,\n    descriptor?: TypedPropertyDescriptor<any>\n  ): any => {\n    // const originalMethod = descriptor.value;\n    const methodName = propertyKey.toString();\n    (descriptor as TypedPropertyDescriptor<any>).value = function (\n      ...args: any[]\n    ) {\n      const { select, where, groupBy, orderBy, limit, offset } =\n        MethodQueryBuilder.build(methodName, ...args);\n\n      let stmt = (this as any).select(select) as any;\n      if (where) stmt = stmt.where(where);\n      // if (orderBy) stmt = stmt.orderBy(orderBy[0]);\n      if (groupBy) {\n        // group by not implemented yet\n        /* stmt = stmt.groupBy(groupBy); */\n      }\n\n      // allow limit and offset by default\n      const { allowLimit, allowOffset, allowOrderBy, throws } = {\n        allowLimit: true,\n        allowOrderBy: true,\n        allowOffset: true,\n        throws: true,\n        ...options,\n      } as QueryOptions;\n\n      const params = [\n        // keep the order to ensure the expected behavior\n        { key: \"orderBy\", value: (orderBy || [])[0], allowed: allowOrderBy }, // orderBy only supports one sentence\n        { key: \"limit\", value: limit, allowed: allowLimit },\n        { key: \"offset\", value: offset, allowed: allowOffset },\n      ];\n\n      for (const param of params) {\n        if (param.value !== undefined) {\n          if (!param.allowed && throws) {\n            throw new QueryError(\n              `${param.key[0].toUpperCase() + param.key.slice(1)} is not allowed for this query`\n            );\n          } else if (param.allowed) {\n            stmt = stmt[param.key](param.value);\n          }\n        }\n      }\n\n      return stmt.execute();\n    };\n  };\n}\n","import { RawRamQuery } from \"./types\";\nimport { Paginator } from \"../query\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { Adapter } from \"../persistence\";\n\n/**\n * @description RAM-specific paginator implementation\n * @summary Extends the base Paginator class to provide pagination functionality for RAM adapter queries.\n * This class handles the pagination of query results from the in-memory storage, allowing\n * for efficient retrieval of large result sets in smaller chunks.\n * @template M - The model type being paginated\n * @template R - The result type returned by the paginator\n * @class RamPaginator\n * @category Ram\n * @example\n * ```typescript\n * // Create a query for User model\n * const query: RawRamQuery<User> = {\n *   select: undefined, // Select all fields\n *   from: User,\n *   where: (user) => user.active === true\n * };\n *\n * // Create a paginator with page size of 10\n * const paginator = new RamPaginator<User, User>(adapter, query, 10, User);\n *\n * // Get the first page of results\n * const firstPage = await paginator.page(1);\n *\n * // Get the next page\n * const secondPage = await paginator.page(2);\n * ```\n */\nexport class RamPaginator<M extends Model, R> extends Paginator<\n  M,\n  R,\n  RawRamQuery<M>\n> {\n  constructor(\n    adapter: Adapter<any, RawRamQuery<M>, any, any>,\n    query: RawRamQuery<M>,\n    size: number,\n    clazz: Constructor<M>\n  ) {\n    super(adapter, query, size, clazz);\n  }\n\n  /**\n   * @description Prepares a RAM query for pagination\n   * @summary Modifies the raw query statement to include pagination parameters.\n   * This protected method sets the limit parameter on the query to match the page size.\n   * @param {RawRamQuery<M>} rawStatement - The original query statement\n   * @return {RawRamQuery<M>} The modified query with pagination parameters\n   */\n  protected prepare(rawStatement: RawRamQuery<M>): RawRamQuery<M> {\n    const query: RawRamQuery<any> = Object.assign({}, rawStatement);\n    query.limit = this.size;\n    return query;\n  }\n\n  /**\n   * @description Retrieves a specific page of results\n   * @summary Executes the query with pagination parameters to retrieve a specific page of results.\n   * This method calculates the appropriate skip value based on the page number and page size,\n   * executes the query, and updates the current page tracking.\n   * @param {number} [page=1] - The page number to retrieve (1-based)\n   * @return {Promise<R[]>} A promise that resolves to an array of results for the requested page\n   */\n  async page(page: number = 1): Promise<R[]> {\n    const statement = this.prepare(this.statement);\n    if (!this._recordCount || !this._totalPages) {\n        this._totalPages = this._recordCount = 0;\n        const results: R[] = await this.adapter.raw({ ...statement, limit: undefined }) || [];\n        this._recordCount = results.length;\n        if (this._recordCount > 0) {\n            const size = statement?.limit || this.size;\n            this._totalPages = Math.ceil(this._recordCount / size);\n        }\n    }\n\n    page = this.validatePage(page);\n    statement.skip = (page - 1) * this.size;\n    const results: any[] = await this.adapter.raw(statement);\n    this._currentPage = page;\n    return results;\n  }\n}\n","import {\n  Condition,\n  GroupOperator,\n  Operator,\n  Paginator,\n  QueryError,\n} from \"../query\";\nimport { RawRamQuery } from \"./types\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { RamPaginator } from \"./RamPaginator\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport { Statement } from \"../query/Statement\";\nimport { Reflection } from \"@decaf-ts/reflection\";\nimport { RamAdapter } from \"./RamAdapter\";\n\n/**\n * @description RAM-specific query statement builder\n * @summary Extends the base Statement class to provide query building functionality for the RAM adapter.\n * This class translates high-level query operations into predicates that can filter and sort\n * in-memory data structures.\n * @template M - The model type being queried\n * @template R - The result type returned by the query\n * @param {RamAdapter} adapter - The RAM adapter instance to use for executing queries\n * @class RamStatement\n * @category Ram\n * @example\n * ```typescript\n * // Create a statement for querying User models\n * const statement = new RamStatement<User, User>(ramAdapter);\n *\n * // Build a query to find active users with age > 18\n * const results = await statement\n *   .from(User)\n *   .where(Condition.and(\n *     Condition.eq('active', true),\n *     Condition.gt('age', 18)\n *   ))\n *   .orderBy('lastName', 'asc')\n *   .limit(10)\n *   .execute();\n * ```\n */\nexport class RamStatement<M extends Model, R> extends Statement<\n  RawRamQuery<M>,\n  M,\n  R\n> {\n  constructor(adapter: RamAdapter) {\n    super(adapter as any);\n  }\n\n  /**\n   * @description Creates a sort comparator function\n   * @summary Generates a function that compares two model instances based on the orderBy criteria.\n   * This method handles different data types (string, number, date) and sort directions (asc, desc).\n   * @return {function(Model, Model): number} A comparator function for sorting model instances\n   */\n  private getSort() {\n    return (el1: Model, el2: Model) => {\n      if (!this.orderBySelector)\n        throw new InternalError(\n          \"orderBySelector not set. Should be impossible\"\n        );\n      const selector = this.orderBySelector;\n      const [key, direction] = selector;\n      const type = Reflection.getTypeFromDecorator(el1, key as string);\n      if (!type)\n        throw new QueryError(`type not compatible with sorting: ${type}`);\n\n      switch (type) {\n        case \"string\":\n        case \"String\":\n          return (\n            (direction === \"asc\" ? 1 : -1) *\n            (el1[key as keyof Model] as unknown as string).localeCompare(\n              el2[key as keyof Model] as unknown as string\n            )\n          );\n        case \"number\":\n        case \"Number\":\n          return (\n            (direction === \"asc\" ? 1 : -1) *\n            ((el1[key as keyof Model] as unknown as number) -\n              (el2[key as keyof Model] as unknown as number))\n          );\n        case \"object\":\n        case \"Object\":\n          if (\n            el1[key as keyof Model] instanceof Date &&\n            el2[key as keyof Model] instanceof Date\n          )\n            return (\n              (direction === \"asc\" ? 1 : -1) *\n              ((el1[key as keyof Model] as unknown as Date).valueOf() -\n                (el2[key as keyof Model] as unknown as Date).valueOf())\n            );\n          throw new QueryError(`Sorting not supported for not date classes`);\n        default:\n          throw new QueryError(`sorting not supported for type ${type}`);\n      }\n    };\n  }\n\n  /**\n   * @description Builds a RAM query from the statement\n   * @summary Converts the statement's selectors and conditions into a RawRamQuery object\n   * that can be executed by the RAM adapter. This method assembles all query components\n   * (select, from, where, limit, offset, sort) into the final query structure.\n   * @return {RawRamQuery<M>} The constructed RAM query object\n   */\n  protected build(): RawRamQuery<M> {\n    const result: RawRamQuery<M> = {\n      select: this.selectSelector,\n      from: this.fromSelector,\n      where: this.whereCondition\n        ? this.parseCondition(this.whereCondition).where\n        : // eslint-disable-next-line @typescript-eslint/no-unused-vars\n          (el: M) => {\n            return true;\n          },\n      limit: this.limitSelector,\n      skip: this.offsetSelector,\n    };\n    if (this.orderBySelector) result.sort = this.getSort();\n    return result;\n  }\n\n  /**\n   * @description Creates a paginator for the query\n   * @summary Builds the query and wraps it in a RamPaginator to enable pagination of results.\n   * This allows retrieving large result sets in smaller chunks.\n   * @param {number} size - The page size (number of results per page)\n   * @return {Promise<Paginator<M, R, RawRamQuery<M>>>} A promise that resolves to a paginator for the query\n   */\n  async paginate(size: number): Promise<Paginator<M, R, RawRamQuery<M>>> {\n    try {\n      const query = this.build();\n      return new RamPaginator<M, R>(\n        this.adapter,\n        query,\n        size,\n        this.fromSelector\n      );\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n\n  /**\n   * @description Parses a condition into a RAM query predicate\n   * @summary Converts a Condition object into a predicate function that can be used\n   * to filter model instances in memory. This method handles both simple conditions\n   * (equals, greater than, etc.) and complex conditions with logical operators (AND, OR).\n   * @template M - The model type for the condition\n   * @param {Condition<M>} condition - The condition to parse\n   * @return {RawRamQuery<M>} A RAM query object with a where predicate function\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamStatement\n   *   participant SimpleCondition\n   *   participant ComplexCondition\n   *\n   *   Caller->>RamStatement: parseCondition(condition)\n   *   alt Simple condition (eq, gt, lt, etc.)\n   *     RamStatement->>SimpleCondition: Extract attr1, operator, comparison\n   *     SimpleCondition-->>RamStatement: Return predicate function\n   *   else Logical operator (AND, OR)\n   *     RamStatement->>ComplexCondition: Extract nested conditions\n   *     RamStatement->>RamStatement: parseCondition(leftCondition)\n   *     RamStatement->>RamStatement: parseCondition(rightCondition)\n   *     ComplexCondition-->>RamStatement: Combine predicates with logical operator\n   *   end\n   *   RamStatement-->>Caller: Return query with where predicate\n   */\n  parseCondition<M extends Model>(condition: Condition<M>): RawRamQuery<M> {\n    return {\n      where: (m: Model) => {\n        const { attr1, operator, comparison } = condition as unknown as {\n          attr1: string | Condition<M>;\n          operator: Operator | GroupOperator;\n          comparison: any;\n        };\n\n        if (\n          [GroupOperator.AND, GroupOperator.OR, Operator.NOT].indexOf(\n            operator as GroupOperator\n          ) === -1\n        ) {\n          switch (operator) {\n            case Operator.BIGGER:\n              return m[attr1 as keyof Model] > comparison;\n            case Operator.BIGGER_EQ:\n              return m[attr1 as keyof Model] >= comparison;\n            case Operator.DIFFERENT:\n              return m[attr1 as keyof Model] !== comparison;\n            case Operator.EQUAL:\n              return m[attr1 as keyof Model] === comparison;\n            case Operator.REGEXP:\n              if (typeof m[attr1 as keyof Model] !== \"string\")\n                throw new QueryError(\n                  `Invalid regexp comparison on a non string attribute: ${m[attr1 as keyof Model]}`\n                );\n              return !!(m[attr1 as keyof Model] as unknown as string).match(\n                new RegExp(comparison, \"g\")\n              );\n            case Operator.SMALLER:\n              return m[attr1 as keyof Model] < comparison;\n            case Operator.SMALLER_EQ:\n              return m[attr1 as keyof Model] <= comparison;\n            default:\n              throw new InternalError(\n                `Invalid operator for standard comparisons: ${operator}`\n              );\n          }\n        } else if (operator === Operator.NOT) {\n          throw new InternalError(\"Not implemented\");\n        } else {\n          const op1: RawRamQuery<any> = this.parseCondition(\n            attr1 as Condition<M>\n          );\n          const op2: RawRamQuery<any> = this.parseCondition(\n            comparison as Condition<M>\n          );\n          switch (operator) {\n            case GroupOperator.AND:\n              return op1.where(m) && op2.where(m);\n            case GroupOperator.OR:\n              return op1.where(m) || op2.where(m);\n            default:\n              throw new InternalError(\n                `Invalid operator for And/Or comparisons: ${operator}`\n              );\n          }\n        }\n      },\n    } as RawRamQuery<any>;\n  }\n}\n","import { Context } from \"@decaf-ts/db-decorators\";\nimport { RamFlags } from \"./types\";\n\n/**\n * @description Context class for RAM adapter operations\n * @summary Provides a specialized context for RAM adapter operations, extending the base Context with RAM-specific flags. This context is used to pass operation parameters and user information.\n * @class RamContext\n * @category Ram\n * @example\n * ```typescript\n * // Create a new RAM context\n * const context = new RamContext();\n * // Optionally set a flag\n * context.set('UUID', '123e4567-e89b-12d3-a456-426614174000');\n * // Access a flag from the context\n * const uuid = context.get('UUID');\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant RamContext\n *   participant BaseContext as Context\n *   Caller->>RamContext: new RamContext()\n *   RamContext->>BaseContext: super()\n *   RamContext-->>Caller: instance\n */\nexport class RamContext extends Context<RamFlags> {\n  constructor() {\n    super();\n  }\n}\n","import { model, required } from \"@decaf-ts/decorator-validation\";\nimport type { ModelArg } from \"@decaf-ts/decorator-validation\";\nimport { BaseModel, index, table } from \"../../model\";\nimport { pk } from \"../../identity\";\n\n/**\n * @description RAM sequence model for auto-incrementing values\n * @summary A model class that represents a sequence in the RAM adapter. It stores the current value\n * of a sequence that can be used for generating sequential identifiers for entities.\n * The sequence is identified by its ID and maintains the current value.\n * @param {ModelArg<Sequence>} seq - Initial sequence data\n * @class Sequence\n * @category Ram\n * @example\n * ```typescript\n * // Create a new sequence\n * const orderSequence = new Sequence({ id: 'order_seq', current: 1 });\n *\n * // Use the sequence to get the next value\n * const nextOrderId = parseInt(orderSequence.current.toString()) + 1;\n * orderSequence.current = nextOrderId;\n * ```\n */\n@table(\"__RamSequence\")\n@model()\nexport class RamSequenceModel extends BaseModel {\n  /**\n   * @description Primary key identifier for the sequence\n   */\n  @pk()\n  id!: string;\n\n  /**\n   * @description Current value of the sequence\n   * Used to generate the next sequential value\n   */\n  @required()\n  @index()\n  current!: string | number;\n\n  constructor(seq?: ModelArg<RamSequenceModel>) {\n    super(seq);\n  }\n}\n","import { RamSequenceModel } from \"./model/RamSequenceModel\";\nimport { InternalError, NotFoundError } from \"@decaf-ts/db-decorators\";\nimport { Sequence } from \"../persistence\";\nimport { SequenceOptions } from \"../interfaces\";\nimport { RamAdapter } from \"./RamAdapter\";\nimport { Repo, Repository } from \"../repository\";\n\n/**\n * @description RAM-specific sequence implementation\n * @summary Extends the base Sequence class to provide auto-incrementing sequence functionality\n * for the RAM adapter. This class manages sequences stored in memory, allowing for the generation\n * of sequential identifiers for entities.\n * @param {SequenceOptions} options - Configuration options for the sequence\n * @param {RamAdapter} adapter - The RAM adapter instance to use for storage\n * @class RamSequence\n * @category Ram\n * @example\n * ```typescript\n * // Create a new numeric sequence starting at 1\n * const sequence = new RamSequence({\n *   name: 'order_sequence',\n *   type: 'Number',\n *   startWith: 1,\n *   incrementBy: 1\n * }, ramAdapter);\n *\n * // Get the next value in the sequence\n * const nextId = await sequence.next();\n *\n * // Get a range of values\n * const idRange = await sequence.range(5); // Returns 5 sequential values\n * ```\n */\nexport class RamSequence extends Sequence {\n  protected repo: Repo<RamSequenceModel>;\n\n  constructor(options: SequenceOptions, adapter: RamAdapter) {\n    super(options);\n    this.repo = Repository.forModel(RamSequenceModel, adapter.alias);\n  }\n\n  /**\n   * @description Retrieves the current value of the sequence\n   * @summary Gets the current value of the sequence from storage. If the sequence\n   * doesn't exist yet, it returns the configured starting value.\n   * @return A promise that resolves to the current sequence value\n   */\n  async current(): Promise<string | number | bigint> {\n    const { name, startWith } = this.options;\n    try {\n      const sequence: RamSequenceModel = await this.repo.read(name as string);\n      return this.parse(sequence.current as string | number);\n    } catch (e: any) {\n      if (e instanceof NotFoundError) {\n        if (typeof startWith === \"undefined\")\n          throw new InternalError(\n            \"Starting value is not defined for a non existing sequence\"\n          );\n        try {\n          return this.parse(startWith);\n        } catch (e: any) {\n          throw new InternalError(\n            `Failed to parse initial value for sequence ${startWith}: ${e}`\n          );\n        }\n      }\n      throw new InternalError(\n        `Failed to retrieve current value for sequence ${name}: ${e}`\n      );\n    }\n  }\n\n  /**\n   * @description Parses a value according to the sequence type\n   * @summary Converts a value to the appropriate type for the sequence (string, number, or bigint)\n   * using the base Sequence class's parseValue method.\n   * @param {string | number | bigint} value - The value to parse\n   * @return {string | number | bigint} The parsed value in the correct type\n   */\n  private parse(value: string | number | bigint): string | number | bigint {\n    return Sequence.parseValue(this.options.type, value);\n  }\n\n  /**\n   * @description Increments the sequence value\n   * @summary Increases the current sequence value by the specified amount and persists\n   * the new value to storage. This method handles both numeric and BigInt sequence types.\n   * @param {string | number | bigint} current - The current value of the sequence\n   * @param {number} [count] - Optional amount to increment by, defaults to the sequence's incrementBy value\n   * @return A promise that resolves to the new sequence value after incrementing\n   */\n  private async increment(\n    current: string | number | bigint,\n    count?: number\n  ): Promise<string | number | bigint> {\n    const { type, incrementBy, name } = this.options;\n    let next: string | number | bigint;\n    const toIncrementBy = count || incrementBy;\n    if (toIncrementBy % incrementBy !== 0)\n      throw new InternalError(\n        `Value to increment does not consider the incrementBy setting: ${incrementBy}`\n      );\n    switch (type) {\n      case \"Number\":\n        next = (this.parse(current) as number) + toIncrementBy;\n        break;\n      case \"BigInt\":\n        next = (this.parse(current) as bigint) + BigInt(toIncrementBy);\n        break;\n      case \"String\":\n        next = this.parse(current);\n        break;\n      default:\n        throw new InternalError(\"Should never happen\");\n    }\n    let seq: RamSequenceModel;\n    const repo = this.repo.override({\n      ignoredValidationProperties: [\"updatedOn\"],\n    });\n    try {\n      seq = await repo.update(new RamSequenceModel({ id: name, current: next }));\n    } catch (e: any) {\n      if (!(e instanceof NotFoundError)) {\n        throw e;\n      }\n      seq = await repo.create(new RamSequenceModel({ id: name, current: next }));\n    }\n\n    return seq.current as string | number | bigint;\n  }\n\n  /**\n   * @description Gets the next value in the sequence\n   * @summary Retrieves the current value of the sequence and increments it by the\n   * configured increment amount. This is the main method used to get a new sequential value.\n   * @return A promise that resolves to the next value in the sequence\n   */\n  async next(): Promise<number | string | bigint> {\n    const current = await this.current();\n    return this.increment(current);\n  }\n\n  /**\n   * @description Generates a range of sequential values\n   * @summary Retrieves a specified number of sequential values from the sequence.\n   * This is useful when you need to allocate multiple IDs at once.\n   * The method increments the sequence by the total amount needed and returns all values in the range.\n   * @param {number} count - The number of sequential values to generate\n   * @return A promise that resolves to an array of sequential values\n   */\n  async range(count: number): Promise<(number | string | bigint)[]> {\n    const current = (await this.current()) as number;\n    const incrementBy = this.parse(\n      this.options.incrementBy as number\n    ) as number;\n    const next: string | number | bigint = await this.increment(\n      current,\n      (this.parse(count) as number) * incrementBy\n    );\n    const range: (number | string | bigint)[] = [];\n    for (let i: number = 1; i <= count; i++) {\n      range.push(current + incrementBy * (this.parse(i) as number));\n    }\n    if (range[range.length - 1] !== next && this.options.type !== \"String\")\n      throw new InternalError(\"Miscalculation of range\");\n    return range;\n  }\n}\n","import { Model } from \"@decaf-ts/decorator-validation\";\nimport { Repo } from \"../repository\";\nimport { RelationsMetadata } from \"../model\";\nimport { RamFlags } from \"./types\";\nimport { Context } from \"@decaf-ts/db-decorators\";\nimport { UnsupportedError } from \"../persistence\";\n\n/**\n * @description Sets the created by field on a model during RAM create/update operations\n * @summary Automatically populates a model field with the UUID from the context during create or update operations.\n * This function is designed to be used as a handler for RAM operations to track entity creation.\n * @template M - Type of the model being created/updated\n * @template R - Type of the repository handling the model\n * @template V - Type of the relations metadata\n * @template F - Type of the RAM flags\n * @template C - Type of the context\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The operation context containing user identification\n * @param {V} data - The relations metadata\n * @param key - The property key to set with the UUID\n * @param {M} model - The model instance being created/updated\n * @return {Promise<void>} A promise that resolves when the field has been set\n * @function createdByOnRamCreateUpdate\n * @memberOf module:core\n * @category Ram\n */\nexport async function createdByOnRamCreateUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\n  F extends RamFlags,\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  const uuid: string = context.get(\"UUID\");\n  if (!uuid)\n    throw new UnsupportedError(\n      \"This adapter does not support user identification\"\n    );\n  model[key] = uuid as M[keyof M];\n}\n","/**\n * @description Identifier for the RAM adapter\n * @summary A constant string that uniquely identifies the RAM adapter in the system. Used for adapter type identification and configuration across the core module.\n * @const RamFlavour\n * @memberOf module:core\n * @category Ram\n */\nexport const RamFlavour = \"ram\";\n","import {\n  RamFlags,\n  RawRamQuery,\n  RamStorage,\n  RamRepository,\n  RamConfig,\n} from \"./types\";\nimport { RamStatement } from \"./RamStatement\";\nimport { RamContext } from \"./RamContext\";\nimport { Repository } from \"../repository/Repository\";\nimport { Adapter, PersistenceKeys, Sequence } from \"../persistence\";\nimport { SequenceOptions } from \"../interfaces\";\nimport { Lock } from \"@decaf-ts/transactional-decorators\";\nimport {\n  Constructor,\n  Decoration,\n  hashObj,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport {\n  BaseError,\n  ConflictError,\n  findPrimaryKey,\n  InternalError,\n  NotFoundError,\n  onCreate,\n  onCreateUpdate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { RamSequence } from \"./RamSequence\";\nimport { createdByOnRamCreateUpdate } from \"./handlers\";\nimport { RamFlavour } from \"./constants\";\n\nAdapter.setCurrent(RamFlavour);\n\n/**\n * @description In-memory adapter for data persistence\n * @summary The RamAdapter provides an in-memory implementation of the persistence layer.\n * It stores data in JavaScript Maps and provides CRUD operations and query capabilities.\n * This adapter is useful for testing, prototyping, and applications that don't require\n * persistent storage across application restarts.\n * @class RamAdapter\n * @category Ram\n * @example\n * ```typescript\n * // Create a new RAM adapter\n * const adapter = new RamAdapter('myRamAdapter');\n *\n * // Create a repository for a model\n * const userRepo = new (adapter.repository<User>())(User, adapter);\n *\n * // Perform CRUD operations\n * const user = new User({ name: 'John', email: 'john@example.com' });\n * await userRepo.create(user);\n * const retrievedUser = await userRepo.findById(user.id);\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Repository\n *   participant RamAdapter\n *   participant Storage as In-Memory Storage\n *\n *   Client->>Repository: create(model)\n *   Repository->>RamAdapter: create(tableName, id, model)\n *   RamAdapter->>RamAdapter: lock.acquire()\n *   RamAdapter->>Storage: set(id, model)\n *   RamAdapter->>RamAdapter: lock.release()\n *   RamAdapter-->>Repository: model\n *   Repository-->>Client: model\n *\n *   Client->>Repository: findById(id)\n *   Repository->>RamAdapter: read(tableName, id)\n *   RamAdapter->>Storage: get(id)\n *   Storage-->>RamAdapter: model\n *   RamAdapter-->>Repository: model\n *   Repository-->>Client: model\n */\nexport class RamAdapter extends Adapter<\n  RamConfig,\n  RamStorage,\n  RawRamQuery<any>,\n  RamFlags,\n  RamContext\n> {\n  constructor(conf: RamConfig = {} as any, alias?: string) {\n    super(conf, RamFlavour, alias);\n  }\n\n  /**\n   * @description Gets the repository constructor for a model\n   * @summary Returns a constructor for creating repositories that work with the specified model type.\n   * This method overrides the base implementation to provide RAM-specific repository functionality.\n   * @template M - The model type for the repository\n   * @return {Constructor<RamRepository<M>>} A constructor for creating RAM repositories\n   */\n  override repository<M extends Model<boolean>>(): Constructor<\n    RamRepository<M>\n  > {\n    return super.repository<M>() as Constructor<RamRepository<M>>;\n  }\n\n  /**\n   * @description Creates operation flags with UUID\n   * @summary Extends the base flags with a UUID for user identification.\n   * This method ensures that all operations have a unique identifier for tracking purposes.\n   * @template M - The model type for the operation\n   * @param {OperationKeys} operation - The type of operation being performed\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<RamFlags>} flags - Partial flags to be extended\n   * @return {Promise<RamFlags>} Complete flags with UUID\n   */\n  override async flags<M extends Model<boolean>>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<RamFlags>\n  ): Promise<RamFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      UUID: this.config.user || \"\" + Date.now(),\n    }) as RamFlags;\n  }\n\n  override Context = RamContext;\n\n  private indexes: Record<\n    string,\n    Record<string | number, Record<string, any>>\n  > = {};\n\n  private lock = new Lock();\n\n  /**\n   * @description Indexes models in the RAM adapter\n   * @summary A no-op indexing method for the RAM adapter.\n   * Since RAM adapter doesn't require explicit indexing, this method simply resolves immediately.\n   * @param models - Models to be indexed (unused)\n   * @return {Promise<any>} A promise that resolves when indexing is complete\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async index(...models: Record<string, any>[]): Promise<any> {\n    return Promise.resolve(undefined);\n  }\n\n  /**\n   * @description Prepares a model for storage\n   * @summary Converts a model instance to a format suitable for storage in the RAM adapter.\n   * This method extracts the primary key and creates a record without the primary key field.\n   * @template M - The model type being prepared\n   * @param {M} model - The model instance to prepare\n   * @param pk - The primary key property name\n   * @return Object containing the record and ID\n   */\n  override prepare<M extends Model>(\n    model: M,\n    pk: keyof M\n  ): { record: Record<string, any>; id: string } {\n    const prepared = super.prepare(model, pk);\n    delete prepared.record[pk as string];\n    return prepared;\n  }\n\n  /**\n   * @description Converts a stored record back to a model instance\n   * @summary Reconstructs a model instance from a stored record by adding back the primary key.\n   * This method is the inverse of the prepare method.\n   * @template M - The model type to revert to\n   * @param {Record<string, any>} obj - The stored record\n   * @param {string | Constructor<M>} clazz - The model class or name\n   * @param pk - The primary key property name\n   * @param {string | number} id - The primary key value\n   * @return {M} The reconstructed model instance\n   */\n  override revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: string | Constructor<M>,\n    pk: keyof M,\n    id: string | number\n  ): M {\n    const res = super.revert(obj, clazz, pk, id);\n    return res;\n  }\n\n  /**\n   * @description Creates a new record in the in-memory storage\n   * @summary Stores a new record in the specified table with the given ID.\n   * This method acquires a lock to ensure thread safety, creates the table if it doesn't exist,\n   * checks for conflicts, and stores the model.\n   * @param {string} tableName - The name of the table to store the record in\n   * @param {string | number} id - The unique identifier for the record\n   * @param {Record<string, any>} model - The record data to store\n   * @return {Promise<Record<string, any>>} A promise that resolves to the stored record\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: create(tableName, id, model)\n   *   RamAdapter->>RamAdapter: lock.acquire()\n   *   RamAdapter->>Storage: has(tableName)\n   *   alt Table doesn't exist\n   *     RamAdapter->>Storage: set(tableName, new Map())\n   *   end\n   *   RamAdapter->>Storage: has(id)\n   *   alt Record exists\n   *     RamAdapter-->>Caller: throw ConflictError\n   *   end\n   *   RamAdapter->>Storage: set(id, model)\n   *   RamAdapter->>RamAdapter: lock.release()\n   *   RamAdapter-->>Caller: model\n   */\n  async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    await this.lock.acquire();\n    if (!this.client.has(tableName)) this.client.set(tableName, new Map());\n    if (this.client.get(tableName) && this.client.get(tableName)?.has(id))\n      throw new ConflictError(\n        `Record with id ${id} already exists in table ${tableName}`\n      );\n    this.client.get(tableName)?.set(id, model);\n    this.lock.release();\n    return model;\n  }\n\n  /**\n   * @description Retrieves a record from in-memory storage\n   * @summary Fetches a record with the specified ID from the given table.\n   * This method checks if the table and record exist and throws appropriate errors if not.\n   * @param {string} tableName - The name of the table to retrieve from\n   * @param {string | number} id - The unique identifier of the record to retrieve\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved record\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: read(tableName, id)\n   *   RamAdapter->>Storage: has(tableName)\n   *   alt Table doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: has(id)\n   *   alt Record doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: get(id)\n   *   Storage-->>RamAdapter: record\n   *   RamAdapter-->>Caller: record\n   */\n  async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    if (!this.client.has(tableName))\n      throw new NotFoundError(`Table ${tableName} not found`);\n    if (!this.client.get(tableName)?.has(id))\n      throw new NotFoundError(\n        `Record with id ${id} not found in table ${tableName}`\n      );\n    return this.client.get(tableName)?.get(id);\n  }\n\n  /**\n   * @description Updates an existing record in the in-memory storage\n   * @summary Updates a record with the specified ID in the given table.\n   * This method acquires a lock to ensure thread safety, checks if the table and record exist,\n   * and updates the record with the new data.\n   * @param {string} tableName - The name of the table containing the record\n   * @param {string | number} id - The unique identifier of the record to update\n   * @param {Record<string, any>} model - The new record data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated record\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: update(tableName, id, model)\n   *   RamAdapter->>RamAdapter: lock.acquire()\n   *   RamAdapter->>Storage: has(tableName)\n   *   alt Table doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: has(id)\n   *   alt Record doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: set(id, model)\n   *   RamAdapter->>RamAdapter: lock.release()\n   *   RamAdapter-->>Caller: model\n   */\n  async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    await this.lock.acquire();\n    if (!this.client.has(tableName))\n      throw new NotFoundError(`Table ${tableName} not found`);\n    if (!this.client.get(tableName)?.has(id))\n      throw new NotFoundError(\n        `Record with id ${id} not found in table ${tableName}`\n      );\n    this.client.get(tableName)?.set(id, model);\n    this.lock.release();\n    return model;\n  }\n\n  /**\n   * @description Deletes a record from the in-memory storage\n   * @summary Removes a record with the specified ID from the given table.\n   * This method acquires a lock to ensure thread safety, checks if the table and record exist,\n   * retrieves the record before deletion, and then removes it from storage.\n   * @param {string} tableName - The name of the table containing the record\n   * @param {string | number} id - The unique identifier of the record to delete\n   * @return {Promise<Record<string, any>>} A promise that resolves to the deleted record\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: delete(tableName, id)\n   *   RamAdapter->>RamAdapter: lock.acquire()\n   *   RamAdapter->>Storage: has(tableName)\n   *   alt Table doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: has(id)\n   *   alt Record doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: get(id)\n   *   Storage-->>RamAdapter: record\n   *   RamAdapter->>Storage: delete(id)\n   *   RamAdapter->>RamAdapter: lock.release()\n   *   RamAdapter-->>Caller: record\n   */\n  async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    await this.lock.acquire();\n    if (!this.client.has(tableName))\n      throw new NotFoundError(`Table ${tableName} not found`);\n    if (!this.client.get(tableName)?.has(id))\n      throw new NotFoundError(\n        `Record with id ${id} not found in table ${tableName}`\n      );\n    const natived = this.client.get(tableName)?.get(id);\n    this.client.get(tableName)?.delete(id);\n    this.lock.release();\n    return natived;\n  }\n\n  /**\n   * @description Gets or creates a table in the in-memory storage\n   * @summary Retrieves the Map representing a table for a given model or table name.\n   * If the table doesn't exist, it creates a new one. This is a helper method used\n   * by other methods to access the correct storage location.\n   * @template M - The model type for the table\n   * @param {string | Constructor<M>} from - The model class or table name\n   * @return {Map<string | number, any> | undefined} The table Map or undefined\n   */\n  protected tableFor<M extends Model>(from: string | Constructor<M>) {\n    if (typeof from === \"string\") from = Model.get(from) as Constructor<M>;\n    const table = Repository.table(from);\n    if (!this.client.has(table)) this.client.set(table, new Map());\n    return this.client.get(table);\n  }\n\n  /**\n   * @description Executes a raw query against the in-memory storage\n   * @summary Performs a query operation on the in-memory data store using the provided query specification.\n   * This method supports filtering, sorting, pagination, and field selection.\n   * @template R - The return type of the query\n   * @param {RawRamQuery<any>} rawInput - The query specification\n   * @return {Promise<R>} A promise that resolves to the query results\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: raw(rawInput)\n   *   RamAdapter->>RamAdapter: tableFor(from)\n   *   alt Table doesn't exist\n   *     RamAdapter-->>Caller: throw InternalError\n   *   end\n   *   RamAdapter->>RamAdapter: findPrimaryKey(new from())\n   *   RamAdapter->>Storage: entries()\n   *   Storage-->>RamAdapter: entries\n   *   loop For each entry\n   *     RamAdapter->>RamAdapter: revert(r, from, id, pk)\n   *   end\n   *   alt Where condition exists\n   *     RamAdapter->>RamAdapter: result.filter(where)\n   *   end\n   *   alt Sort condition exists\n   *     RamAdapter->>RamAdapter: result.sort(sort)\n   *   end\n   *   alt Skip specified\n   *     RamAdapter->>RamAdapter: result.slice(skip)\n   *   end\n   *   alt Limit specified\n   *     RamAdapter->>RamAdapter: result.slice(0, limit)\n   *   end\n   *   alt Select fields specified\n   *     loop For each result\n   *       RamAdapter->>RamAdapter: Filter to selected fields\n   *     end\n   *   end\n   *   RamAdapter-->>Caller: result\n   */\n  async raw<R>(rawInput: RawRamQuery<any>): Promise<R> {\n    const { where, sort, limit, skip, from } = rawInput;\n    let { select } = rawInput;\n    const collection = this.tableFor(from);\n    if (!collection)\n      throw new InternalError(`Table ${from} not found in RamAdapter`);\n    const { id, props } = findPrimaryKey(new from());\n\n    let result: any[] = Array.from(collection.entries()).map(([pk, r]) =>\n      this.revert(\n        r,\n        from,\n        id as any,\n        Sequence.parseValue(props.type as any, pk as string) as string\n      )\n    );\n\n    result = where ? result.filter(where) : result;\n\n    if (sort) result = result.sort(sort);\n\n    if (skip) result = result.slice(skip);\n    if (limit) result = result.slice(0, limit);\n\n    if (select) {\n      select = Array.isArray(select) ? select : [select];\n      result = result.map((r) =>\n        Object.entries(r).reduce((acc: Record<string, any>, [key, val]) => {\n          if ((select as string[]).includes(key)) acc[key] = val;\n          return acc;\n        }, {})\n      );\n    }\n\n    return result as unknown as R;\n  }\n\n  /**\n   * @description Parses and converts errors to appropriate types\n   * @summary Ensures that errors are of the correct type for consistent error handling.\n   * If the error is already a BaseError, it's returned as is; otherwise, it's wrapped in an InternalError.\n   * @template V - The expected error type, extending BaseError\n   * @param {Error} err - The error to parse\n   * @return {V} The parsed error of the expected type\n   */\n  parseError<V extends BaseError>(err: Error): V {\n    if (err instanceof BaseError) return err as V;\n    return new InternalError(err) as V;\n  }\n\n  /**\n   * @description Creates a new statement builder for queries\n   * @summary Factory method that creates a new RamStatement instance for building queries.\n   * This method allows for fluent query construction against the RAM adapter.\n   * @template M - The model type for the statement\n   * @return {RamStatement<M, any>} A new statement builder instance\n   */\n  Statement<M extends Model<boolean>>(): RamStatement<M, any> {\n    return new RamStatement<M, any>(this as any);\n  }\n\n  /**\n   * @description Creates a new sequence for generating sequential IDs\n   * @summary Factory method that creates a new RamSequence instance for ID generation.\n   * This method provides a way to create auto-incrementing sequences for entity IDs.\n   * @param {SequenceOptions} options - Configuration options for the sequence\n   * @return {Promise<Sequence>} A promise that resolves to the new sequence instance\n   */\n  async Sequence(options: SequenceOptions): Promise<Sequence> {\n    return new RamSequence(options, this);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  override for(config: Partial<RamConfig>, ...args: any[]): typeof this {\n    if (!this.proxies) this.proxies = {};\n    const key = `${this.alias} - ${hashObj(config)}`;\n    if (key in this.proxies) return this.proxies[key] as typeof this;\n\n    const proxy = new Proxy(this, {\n      get: (target: typeof this, p: string | symbol, receiver: any) => {\n        if (p === \"_config\") {\n          const originalConf: RamConfig = Reflect.get(target, p, receiver);\n          return Object.assign({}, originalConf, config);\n        }\n        return Reflect.get(target, p, receiver);\n      },\n    });\n    this.proxies[key] = proxy;\n    return proxy;\n  }\n\n  /**\n   * @description Sets up RAM-specific decorations for model properties\n   * @summary Configures decorations for createdBy and updatedBy fields in the RAM adapter.\n   * This static method is called during initialization to set up handlers that automatically\n   * populate these fields with the current user's UUID during create and update operations.\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant RamAdapter\n   *   participant Decoration\n   *   participant Repository\n   *\n   *   RamAdapter->>Repository: key(PersistenceKeys.CREATED_BY)\n   *   Repository-->>RamAdapter: createdByKey\n   *   RamAdapter->>Repository: key(PersistenceKeys.UPDATED_BY)\n   *   Repository-->>RamAdapter: updatedByKey\n   *\n   *   RamAdapter->>Decoration: flavouredAs(RamFlavour)\n   *   Decoration-->>RamAdapter: DecoratorBuilder\n   *   RamAdapter->>Decoration: for(createdByKey)\n   *   RamAdapter->>Decoration: define(onCreate, propMetadata)\n   *   RamAdapter->>Decoration: apply()\n   *\n   *   RamAdapter->>Decoration: flavouredAs(RamFlavour)\n   *   Decoration-->>RamAdapter: DecoratorBuilder\n   *   RamAdapter->>Decoration: for(updatedByKey)\n   *   RamAdapter->>Decoration: define(onCreate, propMetadata)\n   *   RamAdapter->>Decoration: apply()\n   */\n  static override decoration(): void {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(RamFlavour)\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnRamCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n    Decoration.flavouredAs(RamFlavour)\n      .for(updatedByKey)\n      .define(\n        onCreateUpdate(createdByOnRamCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n\n  protected override getClient(): RamStorage {\n    return new Map();\n  }\n}\n","/**\n * @module core\n * @description Core module for the Decaf TypeScript framework\n * @summary This module provides the foundational components of the Decaf framework, including identity management,\n * model definitions, repository patterns, persistence layer, query building, and utility functions.\n * It exports functionality from various submodules and sets up the injectable registry for repository decorators.\n */\n\nimport { InjectablesRegistry } from \"./repository/injectables\";\nimport { Injectables } from \"@decaf-ts/injectable-decorators\";\n\n// overrides the previous Injectables registry to enable the @repository decorator\nInjectables.setRegistry(new InjectablesRegistry());\n\n// imported first on purpose\nexport * from \"./repository\";\n\nexport * from \"./identity\";\nexport * from \"./interfaces\";\nexport * from \"./model\";\nexport * from \"./query\";\nexport * from \"./utils\";\nexport * from \"./ram/RamAdapter\";\n//left to last on purpose\nexport * from \"./persistence\";\n\n/**\n * @description Stores the current package version\n * @summary A constant representing the version of the core package\n * @const VERSION\n * @memberOf module:core\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":["Repository","Repo","Rep","populate","pop"],"mappings":"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"}
|
|
5703
|
+
export { Adapter, AuthorizationError, BaseModel, BigIntSequence, Cascade, Condition, ConnectionError, DefaultCascade, DefaultSequenceOptions, Dispatch, ForbiddenError, GroupOperator, InjectablesRegistry, MethodQueryBuilder, NoneSequenceOptions, NumericSequence, ObserverError, ObserverHandler, Operator, OperatorsMap, OrderDirection, Paginator, PagingError, PersistenceKeys, QueryClause, QueryError, RamAdapter, Repository, Sequence, Statement, UnsupportedError, VERSION, cacheModelForPopulate, column, createOrUpdate, createdAt, createdBy, createdByOnCreateUpdate, final, generateInjectableNameForRepository, getColumnName, getPopulateKey, getTableName, index, manyToMany, manyToOne, noValidateOn, noValidateOnCreate, noValidateOnCreateUpdate, noValidateOnUpdate, oneToMany, oneToManyOnCreate, oneToManyOnDelete, oneToManyOnUpdate, oneToOne, oneToOneOnCreate, oneToOneOnDelete, oneToOneOnUpdate, pk, pkOnCreate, populate, query, repository, repositoryFromTypeMetadata, sequenceNameForModel, table, unique, uniqueOnCreateUpdate, updatedAt, updatedBy, uses };
|
|
5704
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"core.esm.cjs","sources":["../src/persistence/constants.ts","../src/utils/decorators.ts","../src/utils/errors.ts","../src/persistence/ObserverHandler.ts","../src/identity/utils.ts","../src/persistence/Adapter.ts","../src/repository/constants.ts","../src/persistence/errors.ts","../src/persistence/Sequence.ts","../src/query/constants.ts","../src/query/errors.ts","../src/query/Condition.ts","../src/persistence/decorators.ts","../src/repository/Repository.ts","../src/repository/utils.ts","../src/repository/injectables.ts","../src/persistence/Dispatch.ts","../src/overrides/overrides.ts","../src/repository/decorators.ts","../src/repository/errors.ts","../src/interfaces/SequenceOptions.ts","../src/model/construction.ts","../src/model/decorators.ts","../src/identity/decorators.ts","../src/model/BaseModel.ts","../src/query/Paginator.ts","../src/query/Statement.ts","../src/query/types.ts","../src/query/utils.ts","../src/query/MethodQueryBuilder.ts","../src/query/decorators.ts","../src/ram/RamPaginator.ts","../src/ram/RamStatement.ts","../src/ram/RamContext.ts","../src/ram/model/RamSequenceModel.ts","../src/ram/RamSequence.ts","../src/ram/handlers.ts","../src/ram/constants.ts","../src/ram/RamAdapter.ts","../src/index.ts"],"sourcesContent":["/**\n * @description Persistence-related constant keys\n * @summary Enum containing string constants used throughout the persistence layer for metadata, relations, and other persistence-related operations\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum PersistenceKeys {\n  /** @description Key for index metadata */\n  INDEX = \"index\",\n\n  /** @description Key for unique constraint metadata */\n  UNIQUE = \"unique\",\n\n  /** @description Key for adapter metadata */\n  ADAPTER = \"adapter\",\n\n  /** @description Template for injectable adapter names */\n  INJECTABLE = \"decaf_{0}_adapter_for_{1}\",\n\n  /** @description Key for table name metadata */\n  TABLE = \"table\",\n\n  /** @description Key for column name metadata */\n  COLUMN = \"column\",\n\n  /** @description Key for general metadata storage */\n  METADATA = \"__metadata\",\n\n  // Ownership\n  /** @description Key for created-by ownership metadata */\n  OWNERSHIP = \"ownership\",\n\n  /** @description Key for created-by ownership metadata */\n  CREATED_BY = `${OWNERSHIP}.created-by`,\n\n  /** @description Key for updated-by ownership metadata */\n  UPDATED_BY = `${OWNERSHIP}.updated-by`,\n\n  // Relations\n\n  /** @description Key for relations metadata storage */\n  RELATIONS = \"__relations\",\n\n  /** @description Key for relations metadata storage */\n  RELATION = \"relation\",\n\n  /** @description Key for one-to-one relation metadata */\n  ONE_TO_ONE = `${RELATION}.one-to-one`,\n\n  /** @description Key for one-to-many relation metadata */\n  ONE_TO_MANY = `${RELATION}.one-to-many`,\n\n  /** @description Key for many-to-one relation metadata */\n  MANY_TO_ONE = `${RELATION}.many-to-one`,\n  /** @description Key for many-to-one relation metadata */\n  MANY_TO_MANY = `${RELATION}.many-to-many`,\n\n  /** @description Key for populate metadata */\n  POPULATE = \"populate\",\n  /** @description Key for populate metadata */\n  NO_VALIDATE = \"no-validate\",\n}\n","/**\n * @description Creates a decorator that makes a method non-configurable\n * @summary This decorator prevents a method from being overridden by making it non-configurable.\n * It throws an error if used on anything other than a method.\n * @return {Function} A decorator function that can be applied to methods\n * @function final\n * @category Method Decorators\n */\nexport function final() {\n  return (\n    target: object,\n    propertyKey?: any,\n    descriptor?: PropertyDescriptor\n  ) => {\n    if (!descriptor)\n      throw new Error(\"final decorator can only be used on methods\");\n    if (descriptor?.configurable) {\n      descriptor.configurable = false;\n    }\n    return descriptor;\n  };\n}\n","import { BadRequestError, InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Error thrown when a user is not authorized to perform an action\n * @summary This error is thrown when a user attempts to access a resource or perform an action without proper authentication\n * @param {string|Error} msg - The error message or Error object\n * @class AuthorizationError\n * @category Errors\n * @example\n * ```typescript\n * // Example of throwing an AuthorizationError\n * if (!user.isAuthenticated()) {\n *   throw new AuthorizationError('User not authenticated');\n * }\n * ```\n */\nexport class AuthorizationError extends BadRequestError {\n  constructor(msg: string | Error, name = AuthorizationError.name, code = 401) {\n    super(msg, name, code);\n  }\n}\n\n/**\n * @description Error thrown when a user is forbidden from accessing a resource\n * @summary This error is thrown when an authenticated user attempts to access a resource or perform an action they don't have permission for\n * @param {string|Error} msg - The error message or Error object\n * @return {void}\n * @class ForbiddenError\n * @category Errors\n * @example\n * ```typescript\n * // Example of throwing a ForbiddenError\n * if (!user.hasPermission('admin')) {\n *   throw new ForbiddenError('User does not have admin permissions');\n * }\n * ```\n */\nexport class ForbiddenError extends AuthorizationError {\n  constructor(msg: string | Error, name = ForbiddenError.name) {\n    super(msg, name, 403);\n  }\n}\n\n/**\n * @description Error thrown when a connection to a service fails\n * @summary This error is thrown when the application fails to establish a connection to a required service or resource\n * @param {string|Error} msg - The error message or Error object\n * @return {void}\n * @class ConnectionError\n * @category Errors\n * @example\n * ```typescript\n * // Example of throwing a ConnectionError\n * try {\n *   await database.connect();\n * } catch (error) {\n *   throw new ConnectionError('Failed to connect to database');\n * }\n * ```\n */\nexport class ConnectionError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, ConnectionError.name, 503);\n  }\n}\n","import { Observable, Observer } from \"../interfaces\";\nimport { EventIds, ObserverFilter } from \"./types\";\nimport {\n  BulkCrudOperationKeys,\n  InternalError,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { Logger } from \"@decaf-ts/logging\";\n\n/**\n * @description Manages a collection of observers for database events\n * @summary The ObserverHandler class implements the Observable interface and provides a centralized\n * way to manage multiple observers. It allows registering observers with optional filters to control\n * which events they receive notifications for, and handles the process of notifying all relevant\n * observers when database events occur.\n * @class ObserverHandler\n * @example\n * ```typescript\n * // Create an observer handler\n * const handler = new ObserverHandler();\n *\n * // Register an observer\n * const myObserver = {\n *   refresh: async (table, event, id) => {\n *     console.log(`Change in ${table}: ${event} for ID ${id}`);\n *   }\n * };\n *\n * // Add observer with a filter for only user table events\n * handler.observe(myObserver, (table, event, id) => table === 'users');\n *\n * // Notify observers about an event\n * await handler.updateObservers(logger, 'users', 'CREATE', 123);\n *\n * // Remove an observer when no longer needed\n * handler.unObserve(myObserver);\n * ```\n */\nexport class ObserverHandler implements Observable {\n  /**\n   * @description Collection of registered observers\n   * @summary Array of observer objects along with their optional filters\n   */\n  protected readonly observers: {\n    observer: Observer;\n    filter?: ObserverFilter;\n  }[] = [];\n\n  /**\n   * @description Gets the number of registered observers\n   * @summary Returns the count of observers currently registered with this handler\n   * @return {number} The number of registered observers\n   */\n  count() {\n    return this.observers.length;\n  }\n\n  /**\n   * @description Registers a new observer\n   * @summary Adds an observer to the collection with an optional filter function\n   * @param {Observer} observer - The observer to register\n   * @param {ObserverFilter} [filter] - Optional filter function to determine which events the observer receives\n   * @return {void}\n   */\n  observe(observer: Observer, filter?: ObserverFilter): void {\n    const index = this.observers.map((o) => o.observer).indexOf(observer);\n    if (index !== -1) throw new InternalError(\"Observer already registered\");\n    this.observers.push({ observer: observer, filter: filter });\n  }\n\n  /**\n   * @description Unregisters an observer\n   * @summary Removes an observer from the collection\n   * @param {Observer} observer - The observer to unregister\n   * @return {void}\n   */\n  unObserve(observer: Observer): void {\n    const index = this.observers.map((o) => o.observer).indexOf(observer);\n    if (index === -1) throw new InternalError(\"Failed to find Observer\");\n    this.observers.splice(index, 1);\n  }\n\n  /**\n   * @description Notifies all relevant observers about a database event\n   * @summary Filters observers based on their filter functions and calls refresh on each matching observer\n   * @param {Logger} log - Logger for recording notification activities\n   * @param {string} table - The name of the table where the event occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {EventIds} id - The identifier(s) of the affected record(s)\n   * @param {...any[]} args - Additional arguments to pass to the observers\n   * @return {Promise<void>} A promise that resolves when all observers have been notified\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant ObserverHandler\n   *   participant Observer\n   *\n   *   Client->>ObserverHandler: updateObservers(log, table, event, id, ...args)\n   *\n   *   ObserverHandler->>ObserverHandler: Filter observers\n   *\n   *   loop For each observer with matching filter\n   *     alt Observer has filter\n   *       ObserverHandler->>Observer: Apply filter(table, event, id)\n   *       alt Filter throws error\n   *         ObserverHandler->>Logger: Log error\n   *         ObserverHandler-->>ObserverHandler: Skip observer\n   *       else Filter returns true\n   *         ObserverHandler->>Observer: refresh(table, event, id, ...args)\n   *       else Filter returns false\n   *         ObserverHandler-->>ObserverHandler: Skip observer\n   *       end\n   *     else No filter\n   *       ObserverHandler->>Observer: refresh(table, event, id, ...args)\n   *     end\n   *   end\n   *\n   *   ObserverHandler->>ObserverHandler: Process results\n   *   loop For each result\n   *     alt Result is rejected\n   *       ObserverHandler->>Logger: Log error\n   *     end\n   *   end\n   *\n   *   ObserverHandler-->>Client: Return\n   */\n  async updateObservers(\n    log: Logger,\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ): Promise<void> {\n    const results = await Promise.allSettled(\n      this.observers\n        .filter((o) => {\n          const { filter } = o;\n          if (!filter) return true;\n          try {\n            return filter(table, event, id);\n          } catch (e: unknown) {\n            log.error(\n              `Failed to filter observer ${o.observer.toString()}: ${e}`\n            );\n            return false;\n          }\n        })\n        .map((o) => {\n          o.observer.refresh(table, event, id, ...args);\n        })\n    );\n    results.forEach((result, i) => {\n      if (result.status === \"rejected\")\n        log.error(\n          `Failed to update observable ${this.observers[i].toString()}: ${result.reason}`\n        );\n    });\n  }\n}\n","import { Constructor, Model, ModelKeys } from \"@decaf-ts/decorator-validation\";\nimport { Repository } from \"@decaf-ts/db-decorators\";\nimport { PersistenceKeys } from \"../persistence/constants\";\n\n/**\n * @description Gets the table name for a model\n * @summary Retrieves the table name associated with a model by checking metadata or falling back to the constructor name\n * @template M - Type that extends Model\n * @param {M | Constructor<M>} model - The model instance or constructor to get the table name for\n * @return {string} The table name for the model\n * @function getTableName\n * @memberOf module:core\n */\nexport function getTableName<M extends Model>(\n  model: M | Constructor<M>\n): string {\n  const obj = model instanceof Model ? model.constructor : model;\n\n  const metadata = Reflect.getOwnMetadata(\n    Repository.key(PersistenceKeys.TABLE),\n    obj[ModelKeys.ANCHOR as unknown as keyof typeof obj] || obj\n  );\n  if (metadata) {\n    return metadata;\n  }\n  if (model instanceof Model) {\n    return model.constructor.name;\n  }\n  return model.name;\n}\n\nexport function getColumnName<M extends Model>(\n  model: M,\n  attribute: string\n): string {\n  const metadata = Reflect.getMetadata(\n    Repository.key(PersistenceKeys.COLUMN),\n    model,\n    attribute\n  );\n  return metadata ? metadata : attribute;\n}\n\n/**\n * @description Generates a sequence name for a model\n * @summary Creates a standardized sequence name by combining the table name with additional arguments\n * @template M - Type that extends Model\n * @param {M | Constructor<M>} model - The model instance or constructor to generate the sequence name for\n * @param {...string} args - Additional string arguments to append to the sequence name\n * @return {string} The generated sequence name\n * @function sequenceNameForModel\n * @memberOf module:core\n */\nexport function sequenceNameForModel<M extends Model>(\n  model: M | Constructor<M>,\n  ...args: string[]\n) {\n  return [getTableName(model), ...args].join(\"_\");\n}\n","import {\n  BaseError,\n  DBKeys,\n  InternalError,\n  Context,\n  OperationKeys,\n  RepositoryFlags,\n  DefaultRepositoryFlags,\n  Contextual,\n  BulkCrudOperationKeys,\n  modelToTransient,\n} from \"@decaf-ts/db-decorators\";\nimport { type Observer } from \"../interfaces/Observer\";\nimport {\n  type Constructor,\n  Decoration,\n  DefaultFlavour,\n  hashObj,\n  Model,\n  ModelConstructor,\n  ModelRegistry,\n} from \"@decaf-ts/decorator-validation\";\nimport { SequenceOptions } from \"../interfaces/SequenceOptions\";\nimport { RawExecutor } from \"../interfaces/RawExecutor\";\nimport { Observable } from \"../interfaces/Observable\";\nimport { PersistenceKeys } from \"./constants\";\nimport type { Repository } from \"../repository/Repository\";\nimport { Sequence } from \"./Sequence\";\nimport { ErrorParser } from \"../interfaces\";\nimport { Statement } from \"../query/Statement\";\nimport { final } from \"../utils\";\nimport type { Dispatch } from \"./Dispatch\";\nimport { type EventIds, type ObserverFilter } from \"./types\";\nimport { ObserverHandler } from \"./ObserverHandler\";\nimport { LoggedClass } from \"@decaf-ts/logging\";\nimport { getColumnName, getTableName } from \"../identity/utils\";\nimport { Repository as Repo } from \"@decaf-ts/db-decorators\";\nimport { AdapterDispatch } from \"./types\";\nimport { Metadata } from \"@decaf-ts/decoration\";\n\nDecoration.setFlavourResolver((obj: object) => {\n  try {\n    return (\n      Adapter.flavourOf(Model.isModel(obj) ? obj.constructor : (obj as any)) ||\n      Adapter.currentFlavour ||\n      DefaultFlavour\n    );\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    // return DefaultFlavour;\n  }\n  try {\n    return Adapter.currentFlavour || DefaultFlavour;\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    return DefaultFlavour;\n  }\n});\n\n/**\n * @description Abstract Facade class for persistence adapters\n * @summary Provides the foundation for all database adapters in the persistence layer. This class\n * implements several interfaces to provide a consistent API for database operations, observer\n * pattern support, and error handling. It manages adapter registration, CRUD operations, and\n * observer notifications.\n * @template CONFIG - The underlying persistence driver config\n * @template QUERY - The query object type used by the adapter\n * @template FLAGS - The repository flags type\n * @template CONTEXT - The context type\n * @param {CONFIG} _config - The underlying persistence driver config\n * @param {string} flavour - The identifier for this adapter type\n * @param {string} [_alias] - Optional alternative name for this adapter\n * @class Adapter\n * @example\n * ```typescript\n * // Implementing a concrete adapter\n * class PostgresAdapter extends Adapter<pg.PoolConfig, pg.Query, PostgresFlags, PostgresContext> {\n *   constructor(client: pg.PoolConfig) {\n *     super(client, 'postgres');\n *   }\n *\n *   async initialize() {\n *     // Set up the adapter\n *     await this.native.connect();\n *   }\n *\n *   async create(tableName, id, model) {\n *     // Implementation for creating records\n *     const columns = Object.keys(model).join(', ');\n *     const values = Object.values(model);\n *     const placeholders = values.map((_, i) => `$${i+1}`).join(', ');\n *\n *     const query = `INSERT INTO ${tableName} (${columns}) VALUES (${placeholders}) RETURNING *`;\n *     const result = await this.native.query(query, values);\n *     return result.rows[0];\n *   }\n *\n *   // Other required method implementations...\n * }\n *\n * // Using the adapter\n * const pgClient = new pg.Client(connectionString);\n * const adapter = new PostgresAdapter(pgClient);\n * await adapter.initialize();\n *\n * // Set as the default adapter\n * Adapter.setCurrent('postgres');\n *\n * // Perform operations\n * const user = await adapter.create('users', 1, { name: 'John', email: 'john@example.com' });\n * ```\n * @mermaid\n * classDiagram\n *   class Adapter {\n *     +Y native\n *     +string flavour\n *     +string alias\n *     +create(tableName, id, model)\n *     +read(tableName, id)\n *     +update(tableName, id, model)\n *     +delete(tableName, id)\n *     +observe(observer, filter)\n *     +unObserve(observer)\n *     +static current\n *     +static get(flavour)\n *     +static setCurrent(flavour)\n *   }\n *\n *   class RawExecutor {\n *     +raw(query)\n *   }\n *\n *   class Observable {\n *     +observe(observer, filter)\n *     +unObserve(observer)\n *     +updateObservers(table, event, id)\n *   }\n *\n *   class Observer {\n *     +refresh(table, event, id)\n *   }\n *\n *   class ErrorParser {\n *     +parseError(err)\n *   }\n *\n *   Adapter --|> RawExecutor\n *   Adapter --|> Observable\n *   Adapter --|> Observer\n *   Adapter --|> ErrorParser\n */\nexport abstract class Adapter<\n    CONF,\n    CONN,\n    QUERY,\n    FLAGS extends RepositoryFlags = RepositoryFlags,\n    CONTEXT extends Context<FLAGS> = Context<FLAGS>,\n  >\n  extends LoggedClass\n  implements\n    RawExecutor<QUERY>,\n    Contextual<FLAGS, CONTEXT>,\n    Observable,\n    Observer,\n    ErrorParser\n{\n  private static _currentFlavour: string;\n  private static _cache: Record<string, Adapter<any, any, any, any, any>> = {};\n  private static _baseRepository: Constructor<\n    Repository<any, any, any, any, any>\n  >;\n  private static _baseDispatch: Constructor<Dispatch>;\n\n  protected dispatch?: AdapterDispatch;\n\n  protected readonly observerHandler?: ObserverHandler;\n\n  protected _client?: CONN;\n\n  /**\n   * @description Gets the native persistence config\n   * @summary Provides access to the underlying persistence driver config\n   * @template CONF\n   * @return {CONF} The native persistence driver config\n   */\n  get config(): CONF {\n    return this._config;\n  }\n\n  /**\n   * @description Gets the adapter's alias or flavor name\n   * @summary Returns the alias if set, otherwise returns the flavor name\n   * @return {string} The adapter's identifier\n   */\n  get alias(): string {\n    return this._alias || this.flavour;\n  }\n\n  /**\n   * @description Gets the repository constructor for this adapter\n   * @summary Returns the constructor for creating repositories that work with this adapter\n   * @template M - The model type\n   * @return {Constructor<Repository<M, QUERY, Adapter<CONF, CONN, QUERY, FLAGS, CONTEXT>, FLAGS, CONTEXT>>} The repository constructor\n   */\n  repository<M extends Model<boolean>>(): Constructor<\n    Repository<\n      M,\n      QUERY,\n      Adapter<CONF, CONN, QUERY, FLAGS, CONTEXT>,\n      FLAGS,\n      CONTEXT\n    >\n  > {\n    if (!Adapter._baseRepository)\n      throw new InternalError(\n        `This should be overridden when necessary. Otherwise it will be replaced lazily`\n      );\n    return Adapter._baseRepository;\n  }\n\n  @final()\n  protected async shutdownProxies(k?: string) {\n    if (!this.proxies) return;\n    if (k && !(k in this.proxies))\n      throw new InternalError(`No proxy found for ${k}`);\n    if (!k) {\n      for (const key in this.proxies) {\n        try {\n          await this.proxies[key].shutdown();\n        } catch (e: unknown) {\n          this.log.error(`Failed to shutdown proxied adapter ${key}: ${e}`);\n          continue;\n        }\n        delete this.proxies[key];\n      }\n    } else {\n      try {\n        await this.proxies[k].shutdown();\n        delete this.proxies[k];\n      } catch (e: unknown) {\n        this.log.error(`Failed to shutdown proxied adapter ${k}: ${e}`);\n      }\n    }\n  }\n\n  /**\n   * @description Shuts down the adapter\n   * @summary Performs any necessary cleanup tasks, such as closing connections\n   * When overriding this method, ensure to call the base method first\n   * @return {Promise<void>} A promise that resolves when shutdown is complete\n   */\n  async shutdown(): Promise<void> {\n    await this.shutdownProxies();\n    if (this.dispatch) await this.dispatch.close();\n  }\n\n  /**\n   * @description Creates a new adapter instance\n   * @summary Initializes the adapter with the native driver and registers it in the adapter cache\n   */\n  protected constructor(\n    private readonly _config: CONF,\n    readonly flavour: string,\n    private readonly _alias?: string\n  ) {\n    super();\n    if (this.alias in Adapter._cache)\n      throw new InternalError(\n        `${this.alias} persistence adapter ${this._alias ? `(${this.flavour}) ` : \"\"} already registered`\n      );\n    Adapter._cache[this.alias] = this;\n    this.log.info(\n      `Created ${this.alias} persistence adapter ${this._alias ? `(${this.flavour}) ` : \"\"} persistence adapter`\n    );\n    if (!Adapter._currentFlavour) {\n      this.log.verbose(`Defined ${this.alias} persistence adapter as current`);\n      Adapter._currentFlavour = this.alias;\n    }\n  }\n\n  /**\n   * @description Creates a new statement builder for a model\n   * @summary Returns a statement builder that can be used to construct queries for a specific model\n   * @template M - The model type\n   * @return {Statement} A statement builder for the model\n   */\n  abstract Statement<M extends Model>(): Statement<QUERY, M, any>;\n\n  /**\n   * @description Creates a new dispatch instance\n   * @summary Factory method that creates a dispatch instance for this adapter\n   * @return {Dispatch} A new dispatch instance\n   */\n  protected Dispatch(): Dispatch {\n    return new Adapter._baseDispatch();\n  }\n\n  /**\n   * @description Creates a new observer handler\n   * @summary Factory method that creates an observer handler for this adapter\n   * @return {ObserverHandler} A new observer handler instance\n   */\n  protected ObserverHandler(): ObserverHandler {\n    return new ObserverHandler();\n  }\n\n  /**\n   * @description Checks if an attribute name is reserved\n   * @summary Determines if a given attribute name is reserved and cannot be used as a column name\n   * @param {string} attr - The attribute name to check\n   * @return {boolean} True if the attribute is reserved, false otherwise\n   */\n  protected isReserved(attr: string): boolean {\n    return !attr;\n  }\n\n  /**\n   * @description Parses a database error into a standardized error\n   * @summary Converts database-specific errors into standardized application errors\n   * @param {Error} err - The original database error\n   * @return {BaseError} A standardized error\n   */\n  abstract parseError(err: Error): BaseError;\n\n  /**\n   * @description Initializes the adapter\n   * @summary Performs any necessary setup for the adapter, such as establishing connections\n   * @param {...any[]} args - Initialization arguments\n   * @return {Promise<void>} A promise that resolves when initialization is complete\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async initialize(...args: any[]): Promise<void> {}\n\n  /**\n   * @description Creates a sequence generator\n   * @summary Factory method that creates a sequence generator for generating sequential values\n   * @param {SequenceOptions} options - Configuration options for the sequence\n   * @return {Promise<Sequence>} A promise that resolves to a new sequence instance\n   */\n  abstract Sequence(options: SequenceOptions): Promise<Sequence>;\n\n  /**\n   * @description Creates repository flags for an operation\n   * @summary Generates a set of flags that describe a database operation, combining default flags with overrides\n   * @template F - The Repository Flags type\n   * @template M - The model type\n   * @param {OperationKeys} operation - The type of operation being performed\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<F>} flags - Custom flag overrides\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<F>} The complete set of flags\n   */\n  protected async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<FLAGS>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<FLAGS> {\n    return Object.assign({}, DefaultRepositoryFlags, flags, {\n      affectedTables: getTableName(model),\n      writeOperation: operation !== OperationKeys.READ,\n      timestamp: new Date(),\n      operation: operation,\n      ignoredValidationProperties: Metadata.validationExceptions(\n        model,\n        operation\n      ),\n    }) as FLAGS;\n  }\n\n  /**\n   * @description The context constructor for this adapter\n   * @summary Reference to the context class constructor used by this adapter\n   */\n  protected Context = Context<FLAGS>;\n\n  /**\n   * @description Creates a context for a database operation\n   * @summary Generates a context object that describes a database operation, used for tracking and auditing\n   * @template F - The Repository flags type\n   * @template M - The model type\n   * @param {OperationKeys.CREATE|OperationKeys.READ|OperationKeys.UPDATE|OperationKeys.DELETE} operation - The type of operation\n   * @param {Partial<F>} overrides - Custom flag overrides\n   * @param {Constructor<M>} model - The model constructor\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<C>} A promise that resolves to the context object\n   */\n  @final()\n  async context<M extends Model>(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    overrides: Partial<FLAGS>,\n    model: Constructor<M>,\n    ...args: any[]\n  ): Promise<CONTEXT> {\n    const log = this.log.for(this.context);\n    log.debug(\n      `Creating new context for ${operation} operation on ${model.name} model with flag overrides: ${JSON.stringify(overrides)}`\n    );\n    const flags = await this.flags(operation, model, overrides, ...args);\n    return new this.Context().accumulate(flags) as unknown as CONTEXT;\n  }\n\n  /**\n   * @description Prepares a model for persistence\n   * @summary Converts a model instance into a format suitable for database storage,\n   * handling column mapping and separating transient properties\n   * @template M - The model type\n   * @param {M} model - The model instance to prepare\n   * @param pk - The primary key property name\n   * @return The prepared data\n   */\n  prepare<M extends Model>(\n    model: M,\n    pk: keyof M\n  ): {\n    record: Record<string, any>;\n    id: string;\n    transient?: Record<string, any>;\n  } {\n    const log = this.log.for(this.prepare);\n    const split = modelToTransient(model);\n    const result = Object.entries(split.model).reduce(\n      (accum: Record<string, any>, [key, val]) => {\n        if (typeof val === \"undefined\") return accum;\n        const mappedProp = getColumnName(model, key);\n        if (this.isReserved(mappedProp))\n          throw new InternalError(`Property name ${mappedProp} is reserved`);\n        accum[mappedProp] = val;\n        return accum;\n      },\n      {}\n    );\n    if ((model as any)[PersistenceKeys.METADATA]) {\n      log.silly(\n        `Passing along persistence metadata for ${(model as any)[PersistenceKeys.METADATA]}`\n      );\n      Object.defineProperty(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        configurable: true,\n        value: (model as any)[PersistenceKeys.METADATA],\n      });\n    }\n\n    return {\n      record: result,\n      id: model[pk] as string,\n      transient: split.transient,\n    };\n  }\n\n  /**\n   * @description Converts database data back into a model instance\n   * @summary Reconstructs a model instance from database data, handling column mapping\n   * and reattaching transient properties\n   * @template M - The model type\n   * @param obj - The database record\n   * @param {string|Constructor<M>} clazz - The model class or name\n   * @param pk - The primary key property name\n   * @param {string|number|bigint} id - The primary key value\n   * @param [transient] - Transient properties to reattach\n   * @return {M} The reconstructed model instance\n   */\n  revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: string | Constructor<M>,\n    pk: keyof M,\n    id: string | number | bigint,\n    transient?: Record<string, any>\n  ): M {\n    const log = this.log.for(this.revert);\n    const ob: Record<string, any> = {};\n    ob[pk as string] = id;\n    const m = (\n      typeof clazz === \"string\" ? Model.build(ob, clazz) : new clazz(ob)\n    ) as M;\n    log.silly(`Rebuilding model ${m.constructor.name} id ${id}`);\n    const metadata = obj[PersistenceKeys.METADATA];\n    const result = Object.keys(m).reduce((accum: M, key) => {\n      if (key === pk) return accum;\n      (accum as Record<string, any>)[key] = obj[getColumnName(accum, key)];\n      return accum;\n    }, m);\n\n    if (transient) {\n      log.verbose(\n        `re-adding transient properties: ${Object.keys(transient).join(\", \")}`\n      );\n      Object.entries(transient).forEach(([key, val]) => {\n        if (key in result)\n          throw new InternalError(\n            `Transient property ${key} already exists on model ${m.constructor.name}. should be impossible`\n          );\n        result[key as keyof M] = val;\n      });\n    }\n\n    if (metadata) {\n      log.silly(\n        `Passing along ${this.flavour} persistence metadata for ${m.constructor.name} id ${id}: ${metadata}`\n      );\n      Object.defineProperty(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        configurable: false,\n        writable: false,\n        value: metadata,\n      });\n    }\n\n    return result;\n  }\n\n  /**\n   * @description Creates a new record in the database\n   * @summary Inserts a new record with the given ID and data into the specified table\n   * @param {string} tableName - The name of the table to insert into\n   * @param {string|number} id - The identifier for the new record\n   * @param model - The data to insert\n   * @param {any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to the created record\n   */\n  abstract create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Creates multiple records in the database\n   * @summary Inserts multiple records with the given IDs and data into the specified table\n   * @param {string} tableName - The name of the table to insert into\n   * @param id - The identifiers for the new records\n   * @param model - The data to insert for each record\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to an array of created records\n   */\n  async createAll(\n    tableName: string,\n    id: (string | number)[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const log = this.log.for(this.createAll);\n    log.verbose(`Creating ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(\n      id.map((i, count) => this.create(tableName, i, model[count], ...args))\n    );\n  }\n\n  /**\n   * @description Retrieves a record from the database\n   * @summary Fetches a record with the given ID from the specified table\n   * @param {string} tableName - The name of the table to read from\n   * @param {string|number|bigint} id - The identifier of the record to retrieve\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to the retrieved record\n   */\n  abstract read(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Retrieves multiple records from the database\n   * @summary Fetches multiple records with the given IDs from the specified table\n   * @param {string} tableName - The name of the table to read from\n   * @param id - The identifiers of the records to retrieve\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to an array of retrieved records\n   */\n  async readAll(\n    tableName: string,\n    id: (string | number | bigint)[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.readAll);\n    log.verbose(`Reading ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(id.map((i) => this.read(tableName, i, ...args)));\n  }\n\n  /**\n   * @description Updates a record in the database\n   * @summary Modifies an existing record with the given ID in the specified table\n   * @param {string} tableName - The name of the table to update\n   * @param {string|number} id - The identifier of the record to update\n   * @param  model - The new data for the record\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to the updated record\n   */\n  abstract update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Updates multiple records in the database\n   * @summary Modifies multiple existing records with the given IDs in the specified table\n   * @param {string} tableName - The name of the table to update\n   * @param {string[]|number[]} id - The identifiers of the records to update\n   * @param model - The new data for each record\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to an array of updated records\n   */\n  async updateAll(\n    tableName: string,\n    id: string[] | number[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const log = this.log.for(this.updateAll);\n    log.verbose(`Updating ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(\n      id.map((i, count) => this.update(tableName, i, model[count], ...args))\n    );\n  }\n\n  /**\n   * @description Deletes a record from the database\n   * @summary Removes a record with the given ID from the specified table\n   * @param {string} tableName - The name of the table to delete from\n   * @param {string|number|bigint} id - The identifier of the record to delete\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to the deleted record\n   */\n  abstract delete(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Deletes multiple records from the database\n   * @summary Removes multiple records with the given IDs from the specified table\n   * @param {string} tableName - The name of the table to delete from\n   * @param id - The identifiers of the records to delete\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return A promise that resolves to an array of deleted records\n   */\n  async deleteAll(\n    tableName: string,\n    id: (string | number | bigint)[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.createAll);\n    log.verbose(`Deleting ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(id.map((i) => this.delete(tableName, i, ...args)));\n  }\n\n  /**\n   * @description Executes a raw query against the database\n   * @summary Allows executing database-specific queries directly\n   * @template Q - The raw query type\n   * @template R - The return type of the query\n   * @param {Q} rawInput - The query to execute\n   * @param {...any[]} args - Additional arguments specific to the adapter implementation\n   * @return {Promise<R>} A promise that resolves to the query result\n   */\n  abstract raw<R>(rawInput: QUERY, ...args: any[]): Promise<R>;\n\n  /**\n   * @description Registers an observer for database events\n   * @summary Adds an observer to be notified about database changes. The observer can optionally\n   * provide a filter function to receive only specific events.\n   * @param {Observer} observer - The observer to register\n   * @param {ObserverFilter} [filter] - Optional filter function to determine which events the observer receives\n   * @return {void}\n   */\n  @final()\n  observe(observer: Observer, filter?: ObserverFilter): void {\n    if (!this.observerHandler)\n      Object.defineProperty(this, \"observerHandler\", {\n        value: this.ObserverHandler(),\n        writable: false,\n      });\n    this.observerHandler!.observe(observer, filter);\n    this.log\n      .for(this.observe)\n      .verbose(`Registering new observer ${observer.toString()}`);\n    if (!this.dispatch) {\n      this.log.for(this.observe).info(`Creating dispatch for ${this.alias}`);\n      this.dispatch = this.Dispatch();\n      this.dispatch.observe(this);\n    }\n  }\n\n  /**\n   * @description Unregisters an observer\n   * @summary Removes a previously registered observer so it no longer receives database event notifications\n   * @param {Observer} observer - The observer to unregister\n   * @return {void}\n   */\n  @final()\n  unObserve(observer: Observer): void {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    this.observerHandler.unObserve(observer);\n    this.log\n      .for(this.unObserve)\n      .verbose(`Observer ${observer.toString()} removed`);\n  }\n\n  /**\n   * @description Notifies all observers about a database event\n   * @summary Sends notifications to all registered observers about a change in the database,\n   * filtering based on each observer's filter function\n   * @param {string} table - The name of the table where the change occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {EventIds} id - The identifier(s) of the affected record(s)\n   * @param {...any[]} args - Additional arguments to pass to the observers\n   * @return {Promise<void>} A promise that resolves when all observers have been notified\n   */\n  async updateObservers(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ): Promise<void> {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    const log = this.log.for(this.updateObservers);\n    log.verbose(\n      `Updating ${this.observerHandler.count()} observers for adapter ${this.alias}`\n    );\n    await this.observerHandler.updateObservers(\n      this.log,\n      table,\n      event,\n      id,\n      ...args\n    );\n  }\n\n  /**\n   * @description Refreshes data based on a database event\n   * @summary Implementation of the Observer interface method that delegates to updateObservers\n   * @param {string} table - The name of the table where the change occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {EventIds} id - The identifier(s) of the affected record(s)\n   * @param {...any[]} args - Additional arguments related to the event\n   * @return {Promise<void>} A promise that resolves when the refresh is complete\n   */\n  async refresh(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ) {\n    return this.updateObservers(table, event, id, ...args);\n  }\n\n  /**\n   * @description Gets a string representation of the adapter\n   * @summary Returns a human-readable string identifying this adapter\n   * @return {string} A string representation of the adapter\n   */\n  override toString() {\n    return `${this.flavour} persistence Adapter`;\n  }\n\n  /**\n   * @description Gets the adapter flavor associated with a model\n   * @summary Retrieves the adapter flavor that should be used for a specific model class\n   * @template M - The model type\n   * @param {Constructor<M>} model - The model constructor\n   * @return {string} The adapter flavor name\n   */\n  static flavourOf<M extends Model>(model: Constructor<M>): string {\n    return (\n      Reflect.getMetadata(this.key(PersistenceKeys.ADAPTER), model) ||\n      this.current?.flavour\n    );\n  }\n\n  static get currentFlavour() {\n    if (!Adapter._currentFlavour)\n      throw new InternalError(\n        `No persistence flavour set. Please initialize your adapter`\n      );\n    return Adapter._currentFlavour;\n  }\n\n  /**\n   * @description Gets the current default adapter\n   * @summary Retrieves the adapter that is currently set as the default for operations\n   * @return {Adapter<any, any, any, any>} The current adapter\n   */\n  static get current(): Adapter<any, any, any, any> | undefined {\n    return Adapter.get(this.currentFlavour);\n  }\n\n  /**\n   * @description Gets an adapter by flavor\n   * @summary Retrieves a registered adapter by its flavor name\n   * @template CONF - The database driver config\n   * @template CONN - The database driver instance\n   * @template QUERY - The query type\n   * @template CCONTEXT - The context type\n   * @template FLAGS - The repository flags type\n   * @param {string} flavour - The flavor name of the adapter to retrieve\n   * @return {Adapter<CONF, CONN, QUERY, CONTEXT, FLAGS> | undefined} The adapter instance or undefined if not found\n   */\n  static get<\n    CONF,\n    CONN,\n    QUERY,\n    CONTEXT extends Context<FLAGS>,\n    FLAGS extends RepositoryFlags,\n  >(flavour?: any): Adapter<CONF, CONN, QUERY, FLAGS, CONTEXT> | undefined {\n    if (!flavour) return Adapter.get(this._currentFlavour);\n    if (flavour in this._cache) return this._cache[flavour];\n    throw new InternalError(`No Adapter registered under ${flavour}.`);\n  }\n\n  /**\n   * @description Sets the current default adapter\n   * @summary Changes which adapter is used as the default for operations\n   * @param {string} flavour - The flavor name of the adapter to set as current\n   * @return {void}\n   */\n  static setCurrent(flavour: string): void {\n    this._currentFlavour = flavour;\n  }\n\n  /**\n   * @description Creates a metadata key\n   * @summary Generates a standardized metadata key for persistence-related metadata\n   * @param {string} key - The base key name\n   * @return {string} The formatted metadata key\n   */\n  static key(key: string) {\n    return Repo.key(key);\n  }\n\n  /**\n   * @description Gets all models associated with an adapter flavor\n   * @summary Retrieves all model constructors that are configured to use a specific adapter flavor\n   * @template M - The model type\n   * @param {string} flavour - The adapter flavor to find models for\n   * @return An array of model constructors\n   */\n  static models<M extends Model>(flavour: string) {\n    try {\n      const registry = (Model as any).getRegistry() as ModelRegistry<any>;\n      const cache = (\n        registry as unknown as { cache: Record<string, ModelConstructor<any>> }\n      ).cache;\n      const managedModels: ModelConstructor<any>[] = Object.values(cache)\n        .map((m: ModelConstructor<M>) => {\n          let f = Reflect.getMetadata(\n            Adapter.key(PersistenceKeys.ADAPTER),\n            m as ModelConstructor<any>\n          );\n          if (f && f === flavour) return m;\n          if (!f) {\n            const repo = Reflect.getMetadata(\n              Repo.key(DBKeys.REPOSITORY),\n              m as ModelConstructor<any>\n            );\n            if (!repo) return;\n            const repository = (this._baseRepository as any).forModel(m);\n\n            f = Reflect.getMetadata(\n              Adapter.key(PersistenceKeys.ADAPTER),\n              repository\n            );\n            return f;\n          }\n        })\n        .filter((m) => !!m);\n      return managedModels;\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n\n  static decoration(): void {}\n\n  protected proxies?: Record<string, typeof this>;\n\n  /**\n   * @description Returns the client instance for the adapter\n   * @summary This method should be overridden by subclasses to return the client instance for the adapter.\n   * @template CON - The type of the client instance\n   * @return {CON} The client instance for the adapter\n   * @abstract\n   * @function getClient\n   * @memberOf module:core\n   * @instance\n   * @protected\n   */\n  protected abstract getClient(): CONN;\n\n  @final()\n  get client(): CONN {\n    if (!this._client) {\n      this._client = this.getClient();\n    }\n    return this._client;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  for(config: Partial<CONF>, ...args: any[]): typeof this {\n    if (!this.proxies) this.proxies = {};\n    const key = `${this.alias} - ${hashObj(config)}`;\n    if (key in this.proxies) return this.proxies[key] as typeof this;\n\n    let client: any;\n    const proxy = new Proxy(this, {\n      get: (target: typeof this, p: string | symbol, receiver: any) => {\n        if (p === \"_config\") {\n          const originalConf: CONF = Reflect.get(target, p, receiver);\n          return Object.assign({}, originalConf, config);\n        }\n        if (p === \"_client\") {\n          return client;\n        }\n        return Reflect.get(target, p, receiver);\n      },\n      set: (target: any, p: string | symbol, value: any, receiver: any) => {\n        if (p === \"_client\") {\n          client = value;\n          return true;\n        }\n        return Reflect.set(target, p, value, receiver);\n      },\n    });\n    this.proxies[key] = proxy;\n    return proxy;\n  }\n}\n","import { CascadeMetadata } from \"./types\";\n\n/**\n * @description Enumeration of possible sort directions.\n * @summary Defines the available sort directions for ordering query results.\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum OrderDirection {\n  /** Ascending order (A to Z, 0 to 9) */\n  ASC = \"asc\",\n\n  /** Descending order (Z to A, 9 to 0) */\n  DSC = \"desc\",\n}\n\n/**\n * @description Enumeration of cascade operation types.\n * @summary Defines the available cascade behaviors for entity relationships.\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum Cascade {\n  /** Perform cascade operation on related entities */\n  CASCADE = \"cascade\",\n  /** Do not perform cascade operation on related entities */\n  NONE = \"none\",\n}\n\n/**\n * @description Shape of the default cascade configuration object used in repositories.\n * @summary Documents the structure of the cascade configuration with explicit update and delete behaviors.\n * @property {'cascade'|'none'} update - Determines whether updates cascade to related entities.\n * @property {'cascade'|'none'} delete - Determines whether deletes cascade to related entities.\n * @typeDef DefaultCascadeConfig\n * @memberOf module:core\n */\nexport const DefaultCascade: CascadeMetadata = {\n  update: Cascade.CASCADE,\n  delete: Cascade.NONE,\n};\n","import { InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Error thrown when an unsupported operation is attempted\n * @summary This error is thrown when an operation is requested that is not supported by the current\n * persistence adapter or configuration. It extends the BaseError class and sets a 500 status code.\n * @param {string|Error} msg - The error message or an Error object to wrap\n * @class UnsupportedError\n * @example\n * ```typescript\n * // Throwing an UnsupportedError\n * if (!adapter.supportsTransactions()) {\n *   throw new UnsupportedError('Transactions are not supported by this adapter');\n * }\n *\n * // Catching an UnsupportedError\n * try {\n *   await adapter.beginTransaction();\n * } catch (error) {\n *   if (error instanceof UnsupportedError) {\n *     console.error('Operation not supported:', error.message);\n *   }\n * }\n * ```\n */\nexport class UnsupportedError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, UnsupportedError.name, 500);\n  }\n}\n","import { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { sequenceNameForModel } from \"../identity/utils\";\nimport { SequenceOptions } from \"../interfaces/SequenceOptions\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\nimport { UnsupportedError } from \"./errors\";\n\n/**\n * @description Abstract base class for sequence generation\n * @summary Provides a framework for generating sequential values (like primary keys) in the persistence layer.\n * Implementations of this class handle the specifics of how sequences are stored and incremented in different\n * database systems.\n * @param {SequenceOptions} options - Configuration options for the sequence generator\n * @class Sequence\n * @example\n * ```typescript\n * // Example implementation for a specific database\n * class PostgresSequence extends Sequence {\n *   constructor(options: SequenceOptions) {\n *     super(options);\n *   }\n *\n *   async next(): Promise<number> {\n *     // Implementation to get next value from PostgreSQL sequence\n *     const result = await this.options.executor.raw(`SELECT nextval('${this.options.name}')`);\n *     return parseInt(result.rows[0].nextval);\n *   }\n *\n *   async current(): Promise<number> {\n *     // Implementation to get current value from PostgreSQL sequence\n *     const result = await this.options.executor.raw(`SELECT currval('${this.options.name}')`);\n *     return parseInt(result.rows[0].currval);\n *   }\n *\n *   async range(count: number): Promise<number[]> {\n *     // Implementation to get a range of values\n *     const values: number[] = [];\n *     for (let i = 0; i < count; i++) {\n *       values.push(await this.next());\n *     }\n *     return values;\n *   }\n * }\n *\n * // Usage\n * const sequence = new PostgresSequence({\n *   name: 'user_id_seq',\n *   executor: dbExecutor\n * });\n *\n * const nextId = await sequence.next();\n * ```\n */\nexport abstract class Sequence {\n  /**\n   * @description Logger instance for this sequence\n   * @summary Lazily initialized logger for the sequence instance\n   */\n  private logger!: Logger;\n\n  /**\n   * @description Accessor for the logger instance\n   * @summary Gets or initializes the logger for this sequence\n   * @return {Logger} The logger instance\n   */\n  protected get log(): Logger {\n    if (!this.logger) this.logger = Logging.for(this as any);\n    return this.logger;\n  }\n\n  /**\n   * @description Creates a new sequence instance\n   * @summary Protected constructor that initializes the sequence with the provided options\n   */\n  protected constructor(protected readonly options: SequenceOptions) {}\n\n  /**\n   * @description Gets the next value in the sequence\n   * @summary Retrieves the next value from the sequence, incrementing it in the process\n   * @return A promise that resolves to the next value in the sequence\n   */\n  abstract next(): Promise<string | number | bigint>;\n\n  /**\n   * @description Gets the current value of the sequence\n   * @summary Retrieves the current value of the sequence without incrementing it\n   * @return A promise that resolves to the current value in the sequence\n   */\n  abstract current(): Promise<string | number | bigint>;\n\n  /**\n   * @description Gets a range of sequential values\n   * @summary Retrieves multiple sequential values at once, which can be more efficient than calling next() multiple times\n   * @param {number} count - The number of sequential values to retrieve\n   * @return A promise that resolves to an array of sequential values\n   */\n  abstract range(count: number): Promise<(number | string | bigint)[]>;\n\n  /**\n   * @description Gets the primary key sequence name for a model\n   * @summary Utility method that returns the standardized sequence name for a model's primary key\n   * @template M - The model type\n   * @param {M|Constructor<M>} model - The model instance or constructor\n   * @return {string} The sequence name for the model's primary key\n   */\n  static pk<M extends Model>(model: M | Constructor<M>) {\n    return sequenceNameForModel(model, \"pk\");\n  }\n\n  /**\n   * @description Parses a sequence value to the appropriate type\n   * @summary Converts a sequence value to the specified type (Number or BigInt)\n   * @param {\"Number\"|\"BigInt\"|undefined} type - The target type to convert to\n   * @param {string|number|bigint} value - The value to convert\n   * @return {string|number|bigint} The converted value\n   */\n  static parseValue(\n    type: \"Number\" | \"BigInt\" | string | undefined,\n    value: string | number | bigint\n  ): string | number | bigint {\n    switch (type) {\n      case \"Number\":\n        return typeof value === \"string\"\n          ? parseInt(value)\n          : typeof value === \"number\"\n            ? value\n            : BigInt(value);\n      case \"BigInt\":\n        return BigInt(value);\n      case undefined:\n      case \"String\":\n        return value;\n      default:\n        throw new UnsupportedError(\n          `Unsupported sequence type: ${type} for adapter ${this}`\n        );\n    }\n  }\n}\n","/**\n * @description Comparison operators for query conditions\n * @summary Enum defining the available operators for comparing values in database queries\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum Operator {\n  /** Equal comparison (=) */\n  EQUAL = \"EQUAL\",\n  /** Not equal comparison (!=) */\n  DIFFERENT = \"DIFFERENT\",\n  /** Greater than comparison (>) */\n  BIGGER = \"BIGGER\",\n  /** Greater than or equal comparison (>=) */\n  BIGGER_EQ = \"BIGGER_EQ\",\n  /** Less than comparison (<) */\n  SMALLER = \"SMALLER\",\n  /** Less than or equal comparison (<=) */\n  SMALLER_EQ = \"SMALLER_EQ\",\n  // BETWEEN = \"BETWEEN\",\n  /** Negation operator (NOT) */\n  NOT = \"NOT\",\n  /** Inclusion operator (IN) */\n  IN = \"IN\",\n  // IS = \"IS\",\n  /** Regular expression matching */\n  REGEXP = \"REGEXP\",\n}\n\n/**\n * @description Logical operators for combining query conditions\n * @summary Enum defining the available operators for grouping multiple conditions in database queries\n * @enum {string}\n * @readonly\n * @memberOf module:core\n */\nexport enum GroupOperator {\n  /** Logical AND operator - all conditions must be true */\n  AND = \"AND\",\n  /** Logical OR operator - at least one condition must be true */\n  OR = \"OR\",\n}\n","import { InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Error thrown during query operations\n * @summary Represents errors that occur during query building or execution\n * @param {string | Error} msg - The error message or Error object\n * @class QueryError\n * @category Errors\n */\nexport class QueryError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, QueryError.name, 500);\n  }\n}\n\n/**\n * @description Error thrown during pagination operations\n * @summary Represents errors that occur during pagination setup or execution\n * @param {string | Error} msg - The error message or Error object\n * @class PagingError\n * @category Errors\n */\nexport class PagingError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, PagingError.name, 500);\n  }\n}\n","import { AttributeOption, ConditionBuilderOption } from \"./options\";\nimport {\n  ConditionalAsync,\n  Model,\n  ModelErrorDefinition,\n  required,\n} from \"@decaf-ts/decorator-validation\";\nimport { GroupOperator, Operator } from \"./constants\";\nimport { QueryError } from \"./errors\";\n\ntype InferAsync<M> = M extends Model<infer A> ? A : false;\n\n/**\n * @description Represents a logical condition for database queries\n * @summary A class that encapsulates query conditions with support for complex logical operations.\n * This class allows for building and combining query conditions using logical operators (AND, OR, NOT)\n * and comparison operators (equals, not equals, greater than, etc.).\n * @template M - The model type this condition operates on\n * @param {string | Condition<M>} attr1 - The attribute name or a nested condition\n * @param {Operator | GroupOperator} operator - The operator to use for the condition\n * @param {any} comparison - The value to compare against or another condition\n * @class Condition\n * @example\n * // Create a simple condition\n * const nameCondition = Condition.attribute(\"name\").eq(\"John\");\n *\n * // Create a complex condition\n * const complexCondition = Condition.attribute(\"age\").gt(18)\n *   .and(Condition.attribute(\"status\").eq(\"active\"));\n *\n * // Use the builder pattern\n * const userQuery = Condition.builder()\n *   .attribute(\"email\").regexp(\".*@example.com\")\n *   .and(Condition.attribute(\"lastLogin\").gt(new Date(\"2023-01-01\")));\n * @mermaid\n * sequenceDiagram\n *   participant Dev\n *   participant Condition\n *   Dev->>Condition: builder().attribute(\"age\").gt(18)\n *   Condition-->>Dev: Condition(age > 18)\n *   Dev->>Condition: .and(attribute(\"status\").eq(\"active\"))\n *   Condition-->>Dev: Condition((age > 18) AND (status = \"active\"))\n */\nexport class Condition<M extends Model<any>> extends Model<InferAsync<M>> {\n  @required()\n  protected attr1?: string | Condition<M> = undefined;\n  @required()\n  protected operator?: Operator | GroupOperator = undefined;\n  @required()\n  protected comparison?: any = undefined;\n\n  private constructor(\n    attr1: string | Condition<M>,\n    operator: Operator | GroupOperator,\n    comparison: any\n  ) {\n    super();\n    this.attr1 = attr1;\n    this.operator = operator;\n    this.comparison = comparison;\n  }\n\n  /**\n   * @description Combines this condition with another using logical AND\n   * @summary Joins two conditions with an AND operator, requiring both to be true\n   * @param {Condition<M>} condition - The condition to combine with this one\n   * @return {Condition<M>} A new condition representing the AND operation\n   */\n  and(condition: Condition<M>): Condition<M> {\n    return Condition.and(this, condition);\n  }\n\n  /**\n   * @description Combines this condition with another using logical OR\n   * @summary Joins two conditions with an OR operator, requiring at least one to be true\n   * @param {Condition<M>} condition - The condition to combine with this one\n   * @return {Condition<M>} A new condition representing the OR operation\n   */\n  or(condition: Condition<M>): Condition<M> {\n    return Condition.or(this, condition);\n  }\n\n  /**\n   * @description Creates a negation condition\n   * @summary Excludes a value from the result by applying a NOT operator\n   * @param {any} val - The value to negate\n   * @return {Condition<M>} A new condition representing the NOT operation\n   */\n  not(val: any): Condition<M> {\n    return new Condition(this, Operator.NOT, val);\n  }\n\n  /**\n   * @description Validates the condition and checks for errors\n   * @summary Extends the base validation to ensure the condition is properly formed\n   * @param {...string[]} exceptions - Fields to exclude from validation\n   * @return {ModelErrorDefinition | undefined} Error definition if validation fails, undefined otherwise\n   */\n  override hasErrors(\n    ...exceptions: string[]\n  ): ConditionalAsync<InferAsync<M>, ModelErrorDefinition | undefined> {\n    const conditionCheck = (): ModelErrorDefinition | undefined => {\n      const invalidOpMessage = `Invalid operator ${this.operator}}`;\n\n      if (typeof this.attr1 === \"string\") {\n        if (this.comparison instanceof Condition)\n          return {\n            comparison: {\n              condition:\n                \"Both sides of the comparison must be of the same type\",\n            },\n          } as ModelErrorDefinition;\n        if (Object.values(Operator).indexOf(this.operator as Operator) === -1)\n          return {\n            operator: {\n              condition: invalidOpMessage,\n            },\n          } as ModelErrorDefinition;\n      }\n\n      if (this.attr1 instanceof Condition) {\n        if (\n          !(this.comparison instanceof Condition) &&\n          this.operator !== Operator.NOT\n        )\n          return {\n            comparison: {\n              condition: invalidOpMessage,\n            },\n          } as ModelErrorDefinition;\n        if (\n          Object.values(GroupOperator).indexOf(\n            this.operator as GroupOperator\n          ) === -1 &&\n          this.operator !== Operator.NOT\n        )\n          return {\n            operator: {\n              condition: invalidOpMessage,\n            },\n          } as ModelErrorDefinition;\n      }\n    };\n\n    const errors = super.hasErrors(...exceptions);\n    if (!this.isAsync())\n      return (\n        (errors as ModelErrorDefinition | undefined) ??\n        (conditionCheck() as any)\n      );\n\n    return (async () => {\n      const resolved = await Promise.resolve(\n        errors as unknown as Promise<ModelErrorDefinition | undefined>\n      );\n      return resolved ?? conditionCheck();\n    })() as ConditionalAsync<InferAsync<M>, ModelErrorDefinition | undefined>;\n  }\n\n  /**\n   * @description Creates a new condition that combines two conditions with logical AND\n   * @summary Static method that joins two conditions with an AND operator, requiring both to be true\n   * @template M - The model type this condition operates on\n   * @param {Condition<M>} condition1 - The first condition\n   * @param {Condition<M>} condition2 - The second condition\n   * @return {Condition<M>} A new condition representing the AND operation\n   */\n  static and<M extends Model>(\n    condition1: Condition<M>,\n    condition2: Condition<M>\n  ): Condition<M> {\n    return Condition.group(condition1, GroupOperator.AND, condition2);\n  }\n\n  /**\n   * @description Creates a new condition that combines two conditions with logical OR\n   * @summary Static method that joins two conditions with an OR operator, requiring at least one to be true\n   * @template M - The model type this condition operates on\n   * @param {Condition<M>} condition1 - The first condition\n   * @param {Condition<M>} condition2 - The second condition\n   * @return {Condition<M>} A new condition representing the OR operation\n   */\n  static or<M extends Model>(\n    condition1: Condition<M>,\n    condition2: Condition<M>\n  ): Condition<M> {\n    return Condition.group(condition1, GroupOperator.OR, condition2);\n  }\n\n  /**\n   * @description Creates a new condition that groups two conditions with a specified operator\n   * @summary Private static method that combines two conditions using the specified group operator\n   * @template M - The model type this condition operates on\n   * @param {Condition<M>} condition1 - The first condition\n   * @param {GroupOperator} operator - The group operator to use (AND, OR)\n   * @param {Condition<M>} condition2 - The second condition\n   * @return {Condition<M>} A new condition representing the grouped operation\n   */\n  private static group<M extends Model>(\n    condition1: Condition<M>,\n    operator: GroupOperator,\n    condition2: Condition<M>\n  ): Condition<M> {\n    return new Condition(condition1, operator, condition2);\n  }\n\n  /**\n   * @description Creates a condition builder for a specific model attribute\n   * @summary Static method that initializes a condition builder with the specified attribute\n   * @template M - The model type this condition operates on\n   * @param attr - The model attribute to build a condition for\n   * @return {AttributeOption<M>} A condition builder initialized with the attribute\n   */\n  static attribute<M extends Model>(attr: keyof M) {\n    return new Condition.Builder<M>().attribute(attr);\n  }\n\n  /**\n   * @description Alias for the attribute method\n   * @summary Shorthand method that initializes a condition builder with the specified attribute\n   * @template M - The model type this condition operates on\n   * @param attr - The model attribute to build a condition for\n   * @return {AttributeOption<M>} A condition builder initialized with the attribute\n   */\n  static attr<M extends Model>(attr: keyof M) {\n    return this.attribute(attr);\n  }\n\n  /**\n   * @description Provides a fluent API to build query conditions\n   * @summary A builder class that simplifies the creation of database query conditions\n   * with a chainable interface for setting attributes and operators\n   * @template M - The model type this condition builder operates on\n   * @class ConditionBuilder\n   */\n  private static Builder = class ConditionBuilder<M extends Model>\n    implements ConditionBuilderOption<M>, AttributeOption<M>\n  {\n    attr1?: keyof M | Condition<M> = undefined;\n    operator?: Operator | GroupOperator = undefined;\n    comparison?: any = undefined;\n\n    /**\n     * @description Sets the attribute for the condition\n     * @summary Specifies which model attribute the condition will operate on\n     * @param attr - The model attribute to use in the condition\n     * @return {AttributeOption<M>} This builder instance for method chaining\n     */\n    attribute(attr: keyof M): AttributeOption<M> {\n      this.attr1 = attr;\n      return this;\n    }\n\n    /**\n     * @description Alias for the attribute method\n     * @summary Shorthand method to specify which model attribute the condition will operate on\n     * @param attr - The model attribute to use in the condition\n     * @return {AttributeOption<M>} This builder instance for method chaining\n     */\n    attr(attr: keyof M) {\n      return this.attribute(attr);\n    }\n\n    /**\n     * @description Creates an equality condition\n     * @summary Builds a condition that checks if the attribute equals the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the equality comparison\n     */\n    eq(val: any) {\n      return this.setOp(Operator.EQUAL, val);\n    }\n\n    /**\n     * @description Creates an inequality condition\n     * @summary Builds a condition that checks if the attribute is different from the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the inequality comparison\n     */\n    dif(val: any) {\n      return this.setOp(Operator.DIFFERENT, val);\n    }\n\n    /**\n     * @description Creates a greater than condition\n     * @summary Builds a condition that checks if the attribute is greater than the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the greater than comparison\n     */\n    gt(val: any) {\n      return this.setOp(Operator.BIGGER, val);\n    }\n\n    /**\n     * @description Creates a less than condition\n     * @summary Builds a condition that checks if the attribute is less than the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the less than comparison\n     */\n    lt(val: any) {\n      return this.setOp(Operator.SMALLER, val);\n    }\n\n    /**\n     * @description Creates a greater than or equal to condition\n     * @summary Builds a condition that checks if the attribute is greater than or equal to the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the greater than or equal comparison\n     */\n    gte(val: any) {\n      return this.setOp(Operator.BIGGER_EQ, val);\n    }\n\n    /**\n     * @description Creates a less than or equal to condition\n     * @summary Builds a condition that checks if the attribute is less than or equal to the specified value\n     * @param {any} val - The value to compare the attribute against\n     * @return {Condition<M>} A new condition representing the less than or equal comparison\n     */\n    lte(val: any) {\n      return this.setOp(Operator.SMALLER_EQ, val);\n    }\n\n    /**\n     * @description Creates an inclusion condition\n     * @summary Builds a condition that checks if the attribute value is included in the specified array\n     * @param {any[]} arr - The array of values to check against\n     * @return {Condition<M>} A new condition representing the inclusion comparison\n     */\n    in(arr: any[]) {\n      return this.setOp(Operator.IN, arr);\n    }\n\n    /**\n     * @description Creates a regular expression condition\n     * @summary Builds a condition that checks if the attribute matches the specified regular expression pattern\n     * @param {any} val - The regular expression pattern to match against\n     * @return {Condition<M>} A new condition representing the regular expression comparison\n     */\n    regexp(val: any) {\n      return this.setOp(Operator.REGEXP, new RegExp(val).source);\n    }\n\n    /**\n     * @description Sets the operator and comparison value for the condition\n     * @summary Private method that configures the condition with the specified operator and value\n     * @param {Operator} op - The operator to use for the condition\n     * @param {any} val - The value to compare against\n     * @return {Condition<M>} A new condition with the specified operator and value\n     */\n    private setOp(op: Operator, val: any) {\n      this.operator = op;\n      this.comparison = val;\n      return this.build();\n    }\n\n    /**\n     * @description Constructs a Condition instance from the builder's state\n     * @summary Finalizes the condition building process by creating a new Condition instance\n     * @throws {QueryError} If the condition cannot be built due to invalid parameters\n     * @return {Condition<M>} A new condition instance with the configured attributes\n     */\n    private build(): Condition<M> {\n      try {\n        return new Condition(\n          this.attr1 as string | Condition<M>,\n          this.operator as Operator,\n          this.comparison as any\n        );\n      } catch (e: any) {\n        throw new QueryError(e);\n      }\n    }\n  };\n\n  /**\n   * @description Creates a new condition builder\n   * @summary Factory method that returns a new instance of the condition builder\n   * @template M - The model type this condition builder will operate on\n   * @return {ConditionBuilderOption<M>} A new condition builder instance\n   */\n  static builder<M extends Model>(): ConditionBuilderOption<M> {\n    return new Condition.Builder<M>();\n  }\n}\n","import { apply, metadata } from \"@decaf-ts/reflection\";\nimport { PersistenceKeys } from \"./constants\";\nimport { Adapter } from \"./Adapter\";\n\n/**\n * @description Specifies which persistence adapter flavor a model should use\n * @summary This decorator applies metadata to a model class to indicate which persistence adapter flavor\n * should be used when performing database operations on instances of the model. The flavor is a string\n * identifier that corresponds to a registered adapter configuration.\n * @param {string} flavour - The identifier of the adapter flavor to use\n * @return {Function} A decorator function that can be applied to a model class\n * @function uses\n * @category Class Decorators\n */\nexport function uses(flavour: string) {\n  return function uses(original: any) {\n    return apply(metadata(Adapter.key(PersistenceKeys.ADAPTER), flavour))(\n      original\n    );\n  };\n}\n","import {\n  BulkCrudOperationKeys,\n  Context,\n  DBKeys,\n  DefaultSeparator,\n  enforceDBDecorators,\n  findPrimaryKey,\n  InternalError,\n  IRepository,\n  OperationKeys,\n  Repository as Rep,\n  RepositoryFlags,\n  ValidationError,\n  wrapMethodWithContext,\n} from \"@decaf-ts/db-decorators\";\nimport { Observable } from \"../interfaces/Observable\";\nimport { type Observer } from \"../interfaces/Observer\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { OrderDirection } from \"./constants\";\nimport { SequenceOptions } from \"../interfaces/SequenceOptions\";\nimport { Queriable } from \"../interfaces/Queriable\";\nimport { Reflection } from \"@decaf-ts/reflection\";\nimport { IndexMetadata } from \"./types\";\nimport { Sequence } from \"../persistence/Sequence\";\nimport { Condition } from \"../query/Condition\";\nimport { WhereOption } from \"../query/options\";\nimport { OrderBySelector, SelectSelector } from \"../query/selectors\";\nimport { getColumnName, getTableName } from \"../identity/utils\";\nimport { uses } from \"../persistence/decorators\";\nimport { Logger } from \"@decaf-ts/logging\";\nimport { ObserverHandler } from \"../persistence/ObserverHandler\";\nimport { final } from \"../utils\";\nimport {\n  EventIds,\n  InferredAdapterConfig,\n  type ObserverFilter,\n} from \"../persistence\";\n\n/**\n * @description Type alias for Repository class with simplified generic parameters.\n * @summary Provides a more concise way to reference the Repository class with its generic parameters.\n * @template M - The model type that extends Model.\n * @template F - The repository flags type.\n * @template C - The context type.\n * @template Q - The query type.\n * @template A - The adapter type.\n * @typedef Repo\n * @memberOf module:core\n */\nexport type Repo<\n  M extends Model<boolean>,\n  F extends RepositoryFlags = any,\n  C extends Context<F> = any,\n  Q = any,\n  A extends Adapter<any, any, Q, F, C> = any,\n> = Repository<M, Q, A, F, C>;\n\n/**\n * @description Core repository implementation for database operations on models on a table by table way.\n * @summary Provides CRUD operations, querying capabilities, and observer pattern implementation for model persistence.\n * @template M - The model type that extends Model.\n * @template Q - The query type used by the adapter.\n * @template A - The adapter type for database operations.\n * @template F - The repository flags type.\n * @template C - The context type for operations.\n * @param {A} [adapter] - Optional adapter instance for database operations.\n * @param {Constructor<M>} [clazz] - Optional constructor for the model class.\n * @param {...any[]} [args] - Additional arguments for repository initialization.\n * @class Repository\n * @example\n * // Creating a repository for User model\n * const userRepo = Repository.forModel(User);\n *\n * // Using the repository for CRUD operations\n * const user = await userRepo.create(new User({ name: 'John' }));\n * const retrievedUser = await userRepo.read(user.id);\n * user.name = 'Jane';\n * await userRepo.update(user);\n * await userRepo.delete(user.id);\n *\n * // Querying with conditions\n * const users = await userRepo\n *   .select()\n *   .where({ name: 'Jane' })\n *   .orderBy('createdAt', OrderDirection.DSC)\n *   .limit(10)\n *   .execute();\n * @mermaid\n * sequenceDiagram\n *   participant C as Client Code\n *   participant R as Repository\n *   participant A as Adapter\n *   participant DB as Database\n *   participant O as Observers\n *\n *   C->>+R: create(model)\n *   R->>R: createPrefix(model)\n *   R->>+A: prepare(model)\n *   A-->>-R: prepared data\n *   R->>+A: create(table, id, record)\n *   A->>+DB: Insert Operation\n *   DB-->>-A: Result\n *   A-->>-R: record\n *   R->>+A: revert(record)\n *   A-->>-R: model instance\n *   R->>R: createSuffix(model)\n *   R->>+O: updateObservers(table, CREATE, id)\n *   O-->>-R: Notification complete\n *   R-->>-C: created model\n */\nexport class Repository<\n    M extends Model<boolean>,\n    Q,\n    A extends Adapter<any, any, Q, F, C>,\n    F extends RepositoryFlags = RepositoryFlags,\n    C extends Context<F> = Context<F>,\n  >\n  extends Rep<M, F, C>\n  implements Observable, Observer, Queriable<M>, IRepository<M, F, C>\n{\n  private static _cache: Record<\n    string,\n    Constructor<Repo<Model>> | Repo<Model>\n  > = {};\n\n  protected observers: Observer[] = [];\n\n  protected observerHandler?: ObserverHandler;\n\n  private readonly _adapter!: A;\n  private _tableName!: string;\n  protected _overrides?: Partial<F>;\n\n  private logger!: Logger;\n\n  /**\n   * @description Logger instance for this repository.\n   * @summary Provides access to the logger for this repository instance.\n   * @return {Logger} The logger instance.\n   */\n  get log(): Logger {\n    if (!this.logger)\n      this.logger = (\n        this.adapter[\"log\" as keyof typeof this.adapter] as Logger\n      ).for(this.toString());\n    return this.logger;\n  }\n\n  /**\n   * @description Adapter for database operations.\n   * @summary Provides access to the adapter instance for this repository.\n   * @template A - The adapter type.\n   * @return {A} The adapter instance.\n   * @throws {InternalError} If no adapter is found.\n   */\n  protected get adapter(): A {\n    if (!this._adapter)\n      throw new InternalError(\n        `No adapter found for this repository. did you use the @uses decorator or pass it in the constructor?`\n      );\n    return this._adapter;\n  }\n\n  /**\n   * @description Table name for this repository's model.\n   * @summary Gets the database table name associated with this repository's model.\n   * @return {string} The table name.\n   */\n  protected get tableName(): string {\n    if (!this._tableName) this._tableName = Repository.table(this.class);\n    return this._tableName;\n  }\n\n  /**\n   * @description Primary key properties for this repository's model.\n   * @summary Gets the sequence options containing primary key information.\n   * @return {SequenceOptions} The primary key properties.\n   */\n  protected override get pkProps(): SequenceOptions {\n    return super.pkProps;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  constructor(adapter?: A, clazz?: Constructor<M>, ...args: any[]) {\n    super(clazz);\n    if (adapter) this._adapter = adapter;\n    if (clazz) {\n      Repository.register(clazz, this, this.adapter.alias);\n      if (adapter) {\n        const flavour = Reflect.getMetadata(\n          Adapter.key(PersistenceKeys.ADAPTER),\n          clazz\n        );\n        if (flavour && flavour !== adapter.flavour)\n          throw new InternalError(\"Incompatible flavours\");\n        uses(adapter.flavour)(clazz);\n      }\n    }\n    [this.createAll, this.readAll, this.updateAll, this.deleteAll].forEach(\n      (m) => {\n        const name = m.name;\n        wrapMethodWithContext(\n          this,\n          (this as any)[name + \"Prefix\"],\n          m,\n          (this as any)[name + \"Suffix\"]\n        );\n      }\n    );\n  }\n\n  /**\n   * @description Creates a proxy with overridden repository flags.\n   * @summary Returns a proxy of this repository with the specified flags overridden.\n   * @param {Partial<F>} flags - The flags to override.\n   * @return {Repository} A proxy of this repository with overridden flags.\n   */\n  override(flags: Partial<F>): Repository<M, Q, A, F, C> {\n    this.log\n      .for(this.override)\n      .debug(`Overriding repository flags with ${JSON.stringify(flags)}`);\n    return new Proxy(this, {\n      get: (target: typeof this, p: string | symbol, receiver: any) => {\n        const result = Reflect.get(target, p, receiver);\n        if (p !== \"_overrides\") return result;\n        return Object.assign({}, result, flags);\n      },\n    });\n  }\n\n  /**\n   * @description Creates a new instance of the Repository class with a specific adapter and arguments.\n   *\n   * @template A - The type of the adapter.\n   * @template Q - The type of the query builder.\n   * @template F - The type of the filter.\n   * @template C - The type of the context.\n   *\n   * @param {Partial<InferredAdapterConfig<A>>} conf - adapter configurations to override.\n   * @param [args] - Additional arguments to be passed to the new instance.\n   *\n   * @return A new instance of the Repository class with the specified adapter and arguments.\n   */\n  for(\n    conf: Partial<InferredAdapterConfig<A>>,\n    ...args: any[]\n  ): Repository<M, Q, A, F, C> {\n    return new Proxy(this, {\n      get: (target: any, p: string | symbol, receiver: any) => {\n        if (p === \"adapter\") {\n          return this.adapter.for(conf, ...args);\n        }\n        return Reflect.get(target, p, receiver);\n      },\n    });\n  }\n\n  /**\n   * @description Creates a new observer handler.\n   * @summary Factory method for creating an observer handler instance.\n   * @return {ObserverHandler} A new observer handler instance.\n   */\n  protected ObserverHandler(): ObserverHandler {\n    return new ObserverHandler();\n  }\n\n  /**\n   * @description Prepares a model for creation.\n   * @summary Validates the model and prepares it for creation in the database.\n   * @template M - The model type.\n   * @param {M} model - The model to create.\n   * @param {...any[]} args - Additional arguments.\n   * @return The prepared 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<M, C, F>(\n      OperationKeys.CREATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\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 = await Promise.resolve(\n      model.hasErrors(\n        ...(contextArgs.context.get(\"ignoredValidationProperties\") || [])\n      )\n    );\n    if (errors) throw new ValidationError(errors.toString());\n\n    return [model, ...contextArgs.args];\n  }\n\n  /**\n   * @description Creates a model in the database.\n   * @summary Persists a model instance to the database.\n   * @param {M} model - The model to create.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M>} The created model with updated properties.\n   */\n  async create(model: M, ...args: any[]): Promise<M> {\n    // eslint-disable-next-line prefer-const\n    let { record, id, transient } = this.adapter.prepare(model, this.pk);\n    record = await this.adapter.create(this.tableName, id, record, ...args);\n    let c: C | undefined = undefined;\n    if (args.length) c = args[args.length - 1] as C;\n    return this.adapter.revert<M>(\n      record,\n      this.class,\n      this.pk,\n      id,\n      c && c.get(\"rebuildWithTransient\") ? transient : undefined\n    );\n  }\n\n  /**\n   * @description Post-creation hook.\n   * @summary Executes after a model is created to perform additional operations.\n   * @param {M} model - The created model.\n   * @param {C} context - The operation context.\n   * @return {Promise<M>} The processed model.\n   */\n  override async createSuffix(model: M, context: C): Promise<M> {\n    return super.createSuffix(model, context);\n  }\n\n  /**\n   * @description Creates multiple models in the database.\n   * @summary Persists multiple model instances to the database in a batch operation.\n   * @param {M[]} models - The models to create.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M[]>} The created models with updated properties.\n   */\n  override async createAll(models: M[], ...args: any[]): Promise<M[]> {\n    if (!models.length) return models;\n    const prepared = models.map((m) => this.adapter.prepare(m, this.pk));\n    const ids = prepared.map((p) => p.id);\n    let records = prepared.map((p) => p.record);\n    records = await this.adapter.createAll(\n      this.tableName,\n      ids as (string | number)[],\n      records,\n      ...args\n    );\n    return records.map((r, i) =>\n      this.adapter.revert(r, this.class, this.pk, ids[i] as string | number)\n    );\n  }\n\n  /**\n   * @description Prepares multiple models for creation.\n   * @summary Validates multiple models and prepares them for creation in the database.\n   * @param {M[]} models - The models to create.\n   * @param {...any[]} args - Additional arguments.\n   * @return The prepared models and context arguments.\n   * @throws {ValidationError} If any model fails validation.\n   */\n  protected override async createAllPrefix(models: M[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    if (!models.length) return [models, ...contextArgs.args];\n    const opts = Repository.getSequenceOptions(models[0]);\n    let ids: (string | number | bigint | undefined)[] = [];\n    if (opts.type) {\n      if (!opts.name) opts.name = Sequence.pk(models[0]);\n      ids = await (await this.adapter.Sequence(opts)).range(models.length);\n    } else {\n      ids = models.map((m, i) => {\n        if (typeof m[this.pk] === \"undefined\")\n          throw new InternalError(\n            `Primary key is not defined for model in position ${i}`\n          );\n        return m[this.pk] as string;\n      });\n    }\n\n    models = await Promise.all(\n      models.map(async (m, i) => {\n        m = new this.class(m);\n        if (opts.type) {\n          m[this.pk] = (\n            opts.type !== \"String\"\n              ? ids[i]\n              : opts.generated\n                ? ids[i]\n                : `${m[this.pk]}`.toString()\n          ) as M[keyof M];\n        }\n\n        await enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.CREATE,\n          OperationKeys.ON\n        );\n        return m;\n      })\n    );\n\n    const ignoredProps =\n      contextArgs.context.get(\"ignoredValidationProperties\") || [];\n\n    const errors = await Promise.all(\n      models.map((m) => Promise.resolve(m.hasErrors(...ignoredProps)))\n    );\n\n    const errorMessages = errors.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\n    if (errorMessages) throw new ValidationError(errorMessages);\n    return [models, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepares for reading a model by ID.\n   * @summary Prepares the context and enforces decorators before reading a model.\n   * @param {string} key - The primary key of the model to read.\n   * @param {...any[]} args - Additional arguments.\n   * @return The key and context arguments.\n   */\n  protected override async readPrefix(key: string, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.READ,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    const model: M = new this.class();\n    model[this.pk] = key as M[keyof M];\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.READ,\n      OperationKeys.ON\n    );\n    return [key, ...contextArgs.args];\n  }\n\n  /**\n   * @description Reads a model from the database by ID.\n   * @summary Retrieves a model instance from the database using its primary key.\n   * @param {string|number|bigint} id - The primary key of the model to read.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M>} The retrieved model instance.\n   */\n  async read(id: string | number | bigint, ...args: any[]): Promise<M> {\n    const m = await this.adapter.read(this.tableName, id, ...args);\n    return this.adapter.revert<M>(m, this.class, this.pk, id);\n  }\n\n  /**\n   * @description Prepares for reading multiple models by IDs.\n   * @summary Prepares the context and enforces decorators before reading multiple models.\n   * @param {string[]|number[]} keys - The primary keys of the models to read.\n   * @param {...any[]} args - Additional arguments.\n   * @return The keys and context arguments.\n   */\n  protected override async readAllPrefix(\n    keys: string[] | number[],\n    ...args: any[]\n  ) {\n    const contextArgs = await Context.args(\n      OperationKeys.READ,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    await Promise.all(\n      keys.map(async (k) => {\n        const m = new this.class();\n        m[this.pk] = k as M[keyof M];\n        return enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.READ,\n          OperationKeys.ON\n        );\n      })\n    );\n    return [keys, ...contextArgs.args];\n  }\n\n  /**\n   * @description Reads multiple models from the database by IDs.\n   * @summary Retrieves multiple model instances from the database using their primary keys.\n   * @param {string[]|number[]} keys - The primary keys of the models to read.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M[]>} The retrieved model instances.\n   */\n  override async readAll(\n    keys: string[] | number[],\n    ...args: any[]\n  ): Promise<M[]> {\n    const records = await this.adapter.readAll(this.tableName, keys, ...args);\n    return records.map((r, i) =>\n      this.adapter.revert(r, this.class, this.pk, keys[i])\n    );\n  }\n\n  /**\n   * @description Updates a model in the database.\n   * @summary Persists changes to an existing model instance in the database.\n   * @param {M} model - The model to update.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M>} The updated model with refreshed properties.\n   */\n  async update(model: M, ...args: any[]): Promise<M> {\n    // eslint-disable-next-line prefer-const\n    let { record, id, transient } = this.adapter.prepare(model, this.pk);\n    record = await this.adapter.update(this.tableName, id, record, ...args);\n    return this.adapter.revert<M>(record, this.class, this.pk, id, transient);\n  }\n\n  /**\n   * @description Prepares a model for update.\n   * @summary Validates the model and prepares it for update in the database.\n   * @param {M} model - The model to update.\n   * @param {...any[]} args - Additional arguments.\n   * @return The prepared model and context arguments.\n   * @throws {InternalError} If the model has no 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      this.adapter,\n      this._overrides || {}\n    );\n    const pk = model[this.pk] as string;\n    if (!pk)\n      throw new InternalError(\n        `No value for the Id is defined under the property ${this.pk as string}`\n      );\n    const oldModel = await this.read(pk, ...contextArgs.args);\n    model = this.merge(oldModel, model);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.UPDATE,\n      OperationKeys.ON,\n      oldModel\n    );\n\n    const errors = await Promise.resolve(\n      model.hasErrors(\n        oldModel,\n        ...Repository.relations(this.class),\n        ...(contextArgs.context.get(\"ignoredValidationProperties\") || [])\n      )\n    );\n    if (errors) throw new ValidationError(errors.toString());\n    if (Repository.getMetadata(oldModel)) {\n      if (!Repository.getMetadata(model))\n        Repository.setMetadata(model, Repository.getMetadata(oldModel));\n    }\n    return [model, ...contextArgs.args];\n  }\n\n  /**\n   * @description Updates multiple models in the database.\n   * @summary Persists changes to multiple existing model instances in the database in a batch operation.\n   * @param {M[]} models - The models to update.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M[]>} The updated models with refreshed properties.\n   */\n  override async updateAll(models: M[], ...args: any[]): Promise<M[]> {\n    const records = models.map((m) => this.adapter.prepare(m, this.pk));\n    const updated = await this.adapter.updateAll(\n      this.tableName,\n      records.map((r) => r.id),\n      records.map((r) => r.record),\n      ...args\n    );\n    return updated.map((u, i) =>\n      this.adapter.revert(u, this.class, this.pk, records[i].id)\n    );\n  }\n\n  /**\n   * @description Prepares multiple models for update.\n   * @summary Validates multiple models and prepares them for update in the database.\n   * @param {M[]} models - The models to update.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<any[]>} The prepared models and context arguments.\n   * @throws {InternalError} If any model has no primary key value.\n   * @throws {ValidationError} If any model fails validation.\n   */\n  protected override async updateAllPrefix(\n    models: M[],\n    ...args: any[]\n  ): Promise<any[]> {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    const ids = models.map((m) => {\n      const id = m[this.pk] as string;\n      if (!id) throw new InternalError(\"missing id on update operation\");\n      return id;\n    });\n    const oldModels = await this.readAll(ids, ...contextArgs.args);\n    models = models.map((m, i) => {\n      m = this.merge(oldModels[i], m);\n      if (Repository.getMetadata(oldModels[i])) {\n        if (!Repository.getMetadata(m))\n          Repository.setMetadata(m, Repository.getMetadata(oldModels[i]));\n      }\n      return m;\n    });\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 ignoredProps =\n      contextArgs.context.get(\"ignoredValidationProperties\") || [];\n\n    const errors = await Promise.all(\n      models.map((m, i) =>\n        Promise.resolve(m.hasErrors(oldModels[i], m, ...ignoredProps))\n      )\n    );\n\n    const errorMessages = errors.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\n    if (errorMessages) throw new ValidationError(errorMessages);\n\n    models.forEach((m, i) => {\n      if (Repository.getMetadata(oldModels[i])) {\n        if (!Repository.getMetadata(m))\n          Repository.setMetadata(m, Repository.getMetadata(oldModels[i]));\n      }\n    });\n    return [models, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepares for deleting a model by ID.\n   * @summary Prepares the context and enforces decorators before deleting a model.\n   * @param {any} key - The primary key of the model to delete.\n   * @param {...any[]} args - Additional arguments.\n   * @return The key and context arguments.\n   */\n  protected override async deletePrefix(key: any, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.DELETE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    const model = await this.read(key, ...contextArgs.args);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.DELETE,\n      OperationKeys.ON\n    );\n    return [key, ...contextArgs.args];\n  }\n\n  /**\n   * @description Deletes a model from the database by ID.\n   * @summary Removes a model instance from the database using its primary key.\n   * @param {string|number|bigint} id - The primary key of the model to delete.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M>} The deleted model instance.\n   */\n  async delete(id: string | number | bigint, ...args: any[]): Promise<M> {\n    const m = await this.adapter.delete(this.tableName, id, ...args);\n    return this.adapter.revert<M>(m, this.class, this.pk, id);\n  }\n\n  /**\n   * @description Prepares for deleting multiple models by IDs.\n   * @summary Prepares the context and enforces decorators before deleting multiple models.\n   * @param {string[]|number[]} keys - The primary keys of the models to delete.\n   * @param {...any[]} args - Additional arguments.\n   * @return The keys and context arguments.\n   */\n  protected override async deleteAllPrefix(\n    keys: string[] | number[],\n    ...args: any[]\n  ) {\n    const contextArgs = await Context.args(\n      OperationKeys.DELETE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    const models = await this.readAll(keys, ...contextArgs.args);\n    await Promise.all(\n      models.map(async (m) => {\n        return enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.DELETE,\n          OperationKeys.ON\n        );\n      })\n    );\n    return [keys, ...contextArgs.args];\n  }\n\n  /**\n   * @description Deletes multiple models from the database by IDs.\n   * @summary Removes multiple model instances from the database using their primary keys.\n   * @param {string[]|number[]} keys - The primary keys of the models to delete.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<M[]>} The deleted model instances.\n   */\n  override async deleteAll(\n    keys: string[] | number[],\n    ...args: any[]\n  ): Promise<M[]> {\n    const results = await this.adapter.deleteAll(this.tableName, keys, ...args);\n    return results.map((r, i) =>\n      this.adapter.revert(r, this.class, this.pk, keys[i])\n    );\n  }\n  /**\n   * @description Creates a select query without specifying fields.\n   * @summary Starts building a query that will return all fields of the model.\n   * @template S - The array type of select selectors.\n   * @return A query builder for the model.\n   */\n  select<\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    S extends readonly SelectSelector<M>[],\n  >(): WhereOption<M, M[]>;\n\n  /**\n   * @description Creates a select query with specific fields.\n   * @summary Starts building a query that will return only the specified fields of the model.\n   * @template S - The array type of select selectors.\n   * @param selector - The fields to select.\n   * @return A query builder for the selected fields.\n   */\n  select<S extends readonly SelectSelector<M>[]>(\n    selector: readonly [...S]\n  ): WhereOption<M, Pick<M, S[number]>[]>;\n\n  /**\n   * @description Implementation of the select method.\n   * @summary Creates a query builder for the model with optional field selection.\n   * @template S - The array type of select selectors.\n   * @param [selector] - Optional fields to select.\n   * @return A query builder.\n   */\n  select<S extends readonly SelectSelector<M>[]>(\n    selector?: readonly [...S]\n  ): WhereOption<M, M[]> | WhereOption<M, Pick<M, S[number]>[]> {\n    return this.adapter\n      .Statement<M>()\n      .select(selector as readonly [...S])\n      .from(this.class);\n  }\n\n  /**\n   * @description Executes a query with the specified conditions and options.\n   * @summary Provides a simplified way to query the database with common query parameters.\n   * @param {Condition<M>} condition - The condition to filter records.\n   * @param orderBy - The field to order results by.\n   * @param {OrderDirection} [order=OrderDirection.ASC] - The sort direction.\n   * @param {number} [limit] - Optional maximum number of results to return.\n   * @param {number} [skip] - Optional number of results to skip.\n   * @return {Promise<M[]>} The query results as model instances.\n   */\n  async query(\n    condition: Condition<M>,\n    orderBy: keyof M,\n    order: OrderDirection = OrderDirection.ASC,\n    limit?: number,\n    skip?: number\n  ): Promise<M[]> {\n    const sort: OrderBySelector<M> = [orderBy, order as OrderDirection];\n    const query = this.select().where(condition).orderBy(sort);\n    if (limit) query.limit(limit);\n    if (skip) query.offset(skip);\n    return query.execute();\n  }\n\n  attr(prop: keyof M) {\n    return Condition.attr<M>(prop);\n  }\n\n  /**\n   * @description Registers an observer for this repository.\n   * @summary Adds an observer that will be notified of changes to models in this repository.\n   * @param {Observer} observer - The observer to register.\n   * @param {ObserverFilter} [filter] - Optional filter to limit which events the observer receives.\n   * @return {void}\n   * @see {Observable#observe}\n   */\n  @final()\n  observe(observer: Observer, filter?: ObserverFilter): void {\n    if (!this.observerHandler)\n      Object.defineProperty(this, \"observerHandler\", {\n        value: this.ObserverHandler(),\n        writable: false,\n      });\n    const log = this.log.for(this.observe);\n    const tableName = Repository.table(this.class);\n    this.adapter.observe(this, (table: string) => tableName === table);\n    log.verbose(\n      `now observing ${this.adapter} filtering on table === ${tableName}`\n    );\n    this.observerHandler!.observe(observer, filter);\n    log.verbose(`Registered new observer ${observer.toString()}`);\n  }\n\n  /**\n   * @description Unregisters an observer from this repository.\n   * @summary Removes an observer so it will no longer receive notifications of changes.\n   * @param {Observer} observer - The observer to unregister.\n   * @return {void}\n   * @throws {InternalError} If the observer handler is not initialized.\n   * @see {Observable#unObserve}\n   */\n  @final()\n  unObserve(observer: Observer): void {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    this.observerHandler.unObserve(observer);\n    this.log\n      .for(this.unObserve)\n      .verbose(`Observer ${observer.toString()} removed`);\n    if (!this.observerHandler.count()) {\n      this.log.verbose(\n        `No more observers registered for ${this.adapter}, unsubscribing`\n      );\n      this.adapter.unObserve(this);\n      this.log.verbose(`No longer observing adapter ${this.adapter.flavour}`);\n    }\n  }\n\n  /**\n   * @description Notifies all observers of an event.\n   * @summary Updates all registered observers with information about a database event.\n   * @param {string} table - The table name where the event occurred.\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of event that occurred.\n   * @param {EventIds} id - The ID or IDs of the affected records.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<void>} A promise that resolves when all observers have been notified.\n   * @throws {InternalError} If the observer handler is not initialized.\n   */\n  async updateObservers(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ): Promise<void> {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    this.log\n      .for(this.updateObservers)\n      .verbose(\n        `Updating ${this.observerHandler.count()} observers for ${this}`\n      );\n    await this.observerHandler.updateObservers(\n      this.log,\n      table,\n      event,\n      Array.isArray(id)\n        ? id.map((i) => Sequence.parseValue(this.pkProps.type, i) as string)\n        : (Sequence.parseValue(this.pkProps.type, id) as string),\n      ...args\n    );\n  }\n\n  /**\n   * @description Alias for updateObservers.\n   * @summary Notifies all observers of an event (alias for updateObservers).\n   * @param {string} table - The table name where the event occurred.\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of event that occurred.\n   * @param {EventIds} id - The ID or IDs of the affected records.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<void>} A promise that resolves when all observers have been notified.\n   */\n  async refresh(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ) {\n    return this.updateObservers(table, event, id, ...args);\n  }\n\n  /**\n   * @description Creates or retrieves a repository for a model.\n   * @summary Factory method that returns a repository instance for the specified model.\n   * @template M - The model type that extends Model.\n   * @template R - The repository type that extends Repo<M>.\n   * @param {Constructor<M>} model - The model constructor.\n   * @param {string} [alias] - Optional default adapter flavour if not specified on the model.\n   * @param {...any[]} [args] - Additional arguments to pass to the repository constructor.\n   * @return {R} A repository instance for the model.\n   * @throws {InternalError} If no adapter is registered for the flavour.\n   */\n  static forModel<M extends Model, R extends Repo<M>>(\n    model: Constructor<M>,\n    alias?: string,\n    ...args: any[]\n  ): R {\n    let repo: R | Constructor<R> | undefined;\n\n    const _alias: string | undefined =\n      alias ||\n      Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), model) ||\n      Adapter.currentFlavour;\n    try {\n      repo = this.get(model, _alias) as Constructor<R> | R;\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: any) {\n      repo = undefined;\n    }\n\n    if (repo instanceof Repository) return repo as R;\n\n    const flavour: string | undefined =\n      alias ||\n      Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), model) ||\n      (repo &&\n        Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), repo)) ||\n      Adapter.currentFlavour;\n    const adapter: Adapter<any, any, any, any> | undefined = flavour\n      ? Adapter.get(flavour)\n      : undefined;\n\n    if (!adapter)\n      throw new InternalError(\n        `No registered persistence adapter found flavour ${flavour}`\n      );\n\n    repo = repo || (adapter.repository() as Constructor<R>);\n    return new repo(adapter, model, ...args) as R;\n  }\n\n  /**\n   * @description Retrieves a repository for a model from the cache.\n   * @summary Gets a repository constructor or instance for the specified model from the internal cache.\n   * @template M - The model type that extends Model.\n   * @param {Constructor<M>} model - The model constructor.\n   * @param {string} [alias] - The adapter alias.\n   * @return {Constructor<Repo<M>> | Repo<M>} The repository constructor or instance.\n   * @throws {InternalError} If no repository is registered for the model.\n   */\n  private static get<M extends Model>(\n    model: Constructor<M>,\n    alias?: string\n  ): Constructor<Repo<M>> | Repo<M> {\n    const name: string = Repository.table(model);\n    let registryName: string = name;\n    if (alias) {\n      registryName = [name, alias].join(DefaultSeparator);\n    }\n    if (registryName in this._cache)\n      return this._cache[registryName] as unknown as\n        | Constructor<Repo<M>>\n        | Repo<M>;\n    if (name in this._cache)\n      return this._cache[name] as unknown as Constructor<Repo<M>> | Repo<M>;\n    throw new InternalError(\n      `Could not find repository registered under ${name}`\n    );\n  }\n\n  /**\n   * @description Registers a repository for a model.\n   * @summary Associates a repository constructor or instance with a model in the internal cache.\n   * @template M - The model type that extends Model.\n   * @param {Constructor<M>} model - The model constructor.\n   * @param {Constructor<Repo<M>> | Repo<M>} repo - The repository constructor or instance.\n   * @param {string} [alias] the adapter alias/flavour.\n   * @throws {InternalError} If a repository is already registered for the model.\n   */\n  static register<M extends Model>(\n    model: Constructor<M>,\n    repo: Constructor<Repo<M>> | Repo<M>,\n    alias?: string\n  ) {\n    let name = Repository.table(model);\n    if (alias) {\n      name = [name, alias].join(DefaultSeparator);\n    }\n    if (name in this._cache) {\n      if (this._cache[name] instanceof Repository)\n        throw new InternalError(`${name} already has a registered instance`);\n    }\n    this._cache[name] = repo as any;\n  }\n\n  /**\n   * @description Sets metadata on a model instance.\n   * @summary Attaches metadata to a model instance using a non-enumerable property.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   * @param {any} metadata - The metadata to attach to the model.\n   */\n  static setMetadata<M extends Model>(model: M, metadata: any) {\n    Object.defineProperty(model, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: true,\n      writable: false,\n      value: metadata,\n    });\n  }\n\n  /**\n   * @description Gets metadata from a model instance.\n   * @summary Retrieves previously attached metadata from a model instance.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   * @return {any} The metadata or undefined if not found.\n   */\n  static getMetadata<M extends Model>(model: M) {\n    const descriptor = Object.getOwnPropertyDescriptor(\n      model,\n      PersistenceKeys.METADATA\n    );\n    return descriptor ? descriptor.value : undefined;\n  }\n\n  /**\n   * @description Removes metadata from a model instance.\n   * @summary Deletes the metadata property from a model instance.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   */\n  static removeMetadata<M extends Model>(model: M) {\n    const descriptor = Object.getOwnPropertyDescriptor(\n      model,\n      PersistenceKeys.METADATA\n    );\n    if (descriptor) delete (model as any)[PersistenceKeys.METADATA];\n  }\n\n  /**\n   * @description Gets sequence options for a model's primary key.\n   * @summary Retrieves the sequence configuration for a model's primary key from metadata.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   * @return {SequenceOptions} The sequence options for the model's primary key.\n   * @throws {InternalError} If no sequence options are defined for the model.\n   */\n  static getSequenceOptions<M extends Model>(model: M) {\n    const pk = findPrimaryKey(model).id;\n    const metadata = Reflect.getMetadata(\n      Repository.key(DBKeys.ID),\n      model,\n      pk as string\n    );\n    if (!metadata)\n      throw new InternalError(\n        \"No sequence options defined for model. did you use the @pk decorator?\"\n      );\n    return metadata as SequenceOptions;\n  }\n\n  /**\n   * @description Gets all indexes defined on a model.\n   * @summary Retrieves all index metadata from a model's property decorators.\n   * @template M - The model type that extends Model.\n   * @param {M | Constructor<M>} model - The model instance or constructor.\n   * @return {Record<string, Record<string, IndexMetadata>>} A nested record of property names to index metadata.\n   */\n  static indexes<M extends Model>(model: M | Constructor<M>) {\n    const indexDecorators = Reflection.getAllPropertyDecorators(\n      model instanceof Model ? model : new model(),\n      DBKeys.REFLECT\n    );\n    return Object.entries(indexDecorators || {}).reduce(\n      (accum: Record<string, Record<string, IndexMetadata>>, [k, val]) => {\n        const decs = val.filter((v) => v.key.startsWith(PersistenceKeys.INDEX));\n        if (decs && decs.length) {\n          for (const dec of decs) {\n            const { key, props } = dec;\n            accum[k] = accum[k] || {};\n            accum[k][key] = props as IndexMetadata;\n          }\n        }\n        return accum;\n      },\n      {}\n    );\n  }\n\n  /**\n   * @description Gets all relation properties defined on a model.\n   * @summary Retrieves the names of all properties marked as relations in the model hierarchy.\n   * @template M - The model type that extends Model.\n   * @param {M | Constructor<M>} model - The model instance or constructor.\n   * @return {string[]} An array of property names that are relations.\n   */\n  static relations<M extends Model>(model: M | Constructor<M>): string[] {\n    const result: string[] = [];\n    let prototype =\n      model instanceof Model\n        ? Object.getPrototypeOf(model)\n        : (model as any).prototype;\n    while (prototype != null) {\n      const props: string[] = prototype[PersistenceKeys.RELATIONS];\n      if (props) {\n        result.push(...props);\n      }\n      prototype = Object.getPrototypeOf(prototype);\n    }\n    return result;\n  }\n\n  /**\n   * @description Gets the table name for a model.\n   * @summary Retrieves the database table name associated with a model.\n   * @template M - The model type that extends Model.\n   * @param {M | Constructor<M>} model - The model instance or constructor.\n   * @return {string} The table name for the model.\n   */\n  static table<M extends Model>(model: M | Constructor<M>): string {\n    return getTableName(model);\n  }\n\n  /**\n   * @description Gets the column name for a model attribute.\n   * @summary Retrieves the database column name for a model property.\n   * @template M - The model type that extends Model.\n   * @param {M} model - The model instance.\n   * @param {string} attribute - The attribute/property name.\n   * @return {string} The column name for the attribute.\n   */\n  static column<M extends Model>(model: M, attribute: string): string {\n    return getColumnName(model, attribute);\n  }\n}\n\nif (Adapter) Adapter[\"_baseRepository\"] = Repository;\n","import { InternalError } from \"@decaf-ts/db-decorators\";\nimport { Constructor, sf } from \"@decaf-ts/decorator-validation\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { getTableName } from \"../identity/utils\";\n\n/**\n * @description Generates a unique injectable name for a repository.\n * @summary Creates a standardized injectable token for repositories using the adapter flavour and model table name.\n * This helps the DI system register and resolve repository instances consistently across adapters.\n * @template T The model type that extends Model.\n * @param {Constructor<T> | T} model The model constructor or instance from which to derive the table name.\n * @param {string} [flavour] Optional adapter flavour/alias. If omitted, it is read from model metadata.\n * @return {string} A namespaced injectable token for the repository (e.g., \"db:repo:ram:users\").\n * @throws {InternalError} If the flavour cannot be determined from arguments or metadata.\n * @function generateInjectableNameForRepository\n * @mermaid\n * sequenceDiagram\n *   participant C as Caller\n *   participant U as generateInjectableNameForRepository\n *   participant R as Reflect Metadata\n *   participant A as Adapter\n *   participant S as String Formatter\n *   C->>U: call(model, flavour?)\n *   alt flavour provided\n *     U-->>U: use provided flavour\n *   else flavour not provided\n *     U->>A: Adapter.key(ADAPTER)\n *     U->>R: getMetadata(key, model|model.ctor)\n *     alt metadata present\n *       R-->>U: flavour\n *     else missing\n *       U-->>C: throw InternalError\n *     end\n *   end\n *   U->>S: sf(INJECTABLE, flavour, Repository.table(model))\n *   S-->>C: token string\n * @memberOf module:core\n */\nexport function generateInjectableNameForRepository<T extends Model>(\n  model: Constructor<T> | T,\n  flavour?: string\n): string {\n  if (!flavour) {\n    const key = Adapter.key(PersistenceKeys.ADAPTER);\n    flavour = Reflect.getMetadata(\n      key,\n      model instanceof Model ? model.constructor : model\n    );\n    if (!flavour)\n      throw new InternalError(\n        `Could not retrieve flavour from model ${model instanceof Model ? model.constructor.name : model.name}`\n      );\n  }\n  return sf(PersistenceKeys.INJECTABLE, flavour, getTableName(model));\n}\n","import {\n  InjectableRegistryImp,\n  Injectables,\n} from \"@decaf-ts/injectable-decorators\";\nimport { Repository } from \"./Repository\";\nimport {\n  Constructor,\n  Model,\n  ModelConstructor,\n} from \"@decaf-ts/decorator-validation\";\nimport { generateInjectableNameForRepository } from \"./utils\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\n\n/**\n * @description Registry for injectable repositories with auto-resolution.\n * @summary Provides an InjectableRegistry implementation that resolves repositories by model name or constructor. If a repository\n * is not explicitly registered, it attempts to infer the correct repository using model metadata and the active or specified adapter flavour.\n * @param {void} [constructor] No constructor parameters required; the superclass handles internal state.\n * @class InjectablesRegistry\n * @example\n * // Basic usage: retrieve a repository by model name\n * const registry = new InjectablesRegistry();\n * const userRepo = registry.get<UserRepository>('User');\n * // If UserRepository is registered, it will be returned. Otherwise, a repository will be created if a User model exists.\n *\n * // Retrieve by constructor and specify adapter flavour\n * const repoByCtor = registry.get<UserRepository>(UserModel, 'ram');\n *\n * // Retrieve by symbol (e.g., injectable token)\n * const token = Symbol.for('UserRepository');\n * const byToken = registry.get<UserRepository>(token);\n * @mermaid\n * sequenceDiagram\n *   participant C as Consumer\n *   participant R as InjectablesRegistry\n *   participant B as BaseRegistry\n *   participant M as Model\n *   participant A as Adapter\n *   participant RP as Repository\n *   C->>R: get(name, flavour?)\n *   activate R\n *   R->>B: super.get(name)\n *   alt Found in base registry\n *     B-->>R: injectable\n *     R-->>C: injectable\n *   else Not found\n *     R->>M: Model.get(name)\n *     alt Model found\n *       R->>A: resolve flavour (from arg/metadata/current)\n *       R->>RP: Repository.forModel(modelCtor, alias)\n *       alt Repository instance\n *         RP-->>R: repository instance\n *         R-->>C: repository instance\n *       else Repository ctor\n *         R->>A: Adapter.get(resolvedFlavour) or Adapter.current\n *         A-->>R: adapter instance\n *         R->>RP: new repoCtor(adapter, modelCtor)\n *         R-->>C: repository instance\n *       end\n *     else Model not found\n *       R-->>C: undefined\n *     end\n *   end\n */\nexport class InjectablesRegistry extends InjectableRegistryImp {\n  private logger?: Logger;\n\n  protected get log(): Logger {\n    if (!this.logger) this.logger = Logging.for(this as any);\n    return this.logger;\n  }\n\n  constructor() {\n    super();\n  }\n\n  /**\n   * @description Retrieve an injectable with repository auto-resolution.\n   * @summary Attempts to get an injectable from the base registry; if not found and the name refers to a known model, it\n   * resolves the appropriate repository using the specified flavour or model metadata, falling back to the current adapter when needed.\n   * @template T The injectable type to be returned.\n   * @param {string | symbol | Constructor<T>} name Token, model name, or constructor associated with the injectable or model.\n   * @param {string} [flavour] Optional adapter flavour (e.g., \"ram\"). If omitted, derives from metadata or current adapter.\n   * @return {T | undefined} The located or auto-created injectable instance; otherwise undefined if it cannot be resolved.\n   * @mermaid\n   * sequenceDiagram\n   *   participant G as get(name, flavour?)\n   *   participant BR as BaseRegistry\n   *   participant M as Model\n   *   participant A as Adapter\n   *   participant RP as Repository\n   *   G->>BR: super.get(name)\n   *   alt Found\n   *     BR-->>G: injectable\n   *   else Not found\n   *     G->>M: derive modelCtor from name\n   *     alt modelCtor resolved\n   *       G->>A: resolve flavour (arg | metadata | current)\n   *       G->>RP: Repository.forModel(modelCtor, alias)\n   *       alt returns instance\n   *         RP-->>G: Repository instance\n   *       else returns ctor\n   *         G->>A: Adapter.get(flavour) | Adapter.current\n   *         A-->>G: adapter instance\n   *         G->>RP: new repoCtor(adapter, modelCtor)\n   *       end\n   *     else no modelCtor\n   *       G-->>G: return undefined\n   *     end\n   *   end\n   */\n  override get<T>(\n    name: symbol | Constructor<T> | string,\n    flavour?: string\n  ): T | undefined {\n    const log = this.log.for(this.get);\n    // First, try base registry, but guard against thrown errors\n    let injectable: T | undefined;\n    try {\n      injectable = super.get(name as any);\n    } catch {\n      // do nothing. we handle it later\n    }\n\n    if (!injectable) {\n      let modelCtor: Constructor<any> | undefined;\n      if (typeof name === \"function\") modelCtor = name as Constructor<any>;\n      else if (typeof name === \"symbol\" || typeof name === \"string\") {\n        modelCtor = Model.get(name.toString()) as ModelConstructor<any>;\n      }\n\n      if (!modelCtor) return undefined;\n\n      // Resolve flavour from metadata if not provided\n      const metaKey = Adapter.key(PersistenceKeys.ADAPTER);\n      const resolvedFlavour =\n        flavour ||\n        (Reflect.getMetadata(metaKey, modelCtor) as string | undefined);\n\n      try {\n        // Determine an alias to use: prefer a directly registered adapter; otherwise, if the current adapter\n        // has the same flavour, use its alias to satisfy Repository.forModel/Adapter.get lookups.\n        let aliasToUse = resolvedFlavour;\n        try {\n          if (resolvedFlavour) Adapter.get(resolvedFlavour);\n        } catch {\n          const current = Adapter.current as any;\n          if (current && current.flavour === resolvedFlavour)\n            aliasToUse = current.alias;\n        }\n\n        injectable = Repository.forModel(\n          modelCtor as Constructor<any>,\n          aliasToUse\n        ) as T;\n        if (injectable instanceof Repository) return injectable as T;\n\n        // Otherwise, register the resolved injectable name for later retrieval\n        const f =\n          resolvedFlavour ||\n          (Reflect.getMetadata(metaKey, (injectable as any).constructor) as\n            | string\n            | undefined) ||\n          (Reflect.getMetadata(metaKey, modelCtor) as string | undefined);\n        Injectables.register(\n          injectable,\n          generateInjectableNameForRepository(\n            modelCtor as ModelConstructor<any>,\n            f as string\n          )\n        );\n      } catch (e: unknown) {\n        log.debug(\n          `No registered repository or adapter found. falling back to default adapter. Error: ${(e as Error)?.message || JSON.stringify(e)}`\n        );\n        const repoCtor = (Repository as any)[\"get\"](modelCtor, resolvedFlavour);\n        if (typeof repoCtor === \"function\") {\n          const adapter = resolvedFlavour\n            ? (Adapter.get(resolvedFlavour) as any)\n            : (Adapter.current as any);\n          if (!adapter) return undefined;\n          const instance = new repoCtor(adapter, modelCtor);\n          return instance as T;\n        }\n      }\n    }\n\n    return injectable as T | undefined;\n  }\n}\n","import {\n  InternalError,\n  OperationKeys,\n  BulkCrudOperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { ModelConstructor } from \"@decaf-ts/decorator-validation\";\nimport { Observer } from \"../interfaces\";\nimport { Adapter } from \"./Adapter\";\nimport { UnsupportedError } from \"./errors\";\nimport { AdapterDispatch, EventIds } from \"./types\";\nimport { LoggedClass } from \"@decaf-ts/logging\";\n\n/**\n * @description Dispatches database operation events to observers\n * @summary The Dispatch class implements the Observable interface and is responsible for intercepting\n * database operations from an Adapter and notifying observers when changes occur. It uses proxies to\n * wrap the adapter's CRUD methods and automatically trigger observer updates after operations complete.\n * @template Y - The native database driver type\n * @param {void} - No constructor parameters\n * @class Dispatch\n * @example\n * ```typescript\n * // Creating and using a Dispatch instance\n * const dispatch = new Dispatch<PostgresDriver>();\n *\n * // Connect it to an adapter\n * const adapter = new PostgresAdapter(connection);\n * dispatch.observe(adapter);\n *\n * // Now any CRUD operations on the adapter will automatically\n * // trigger observer notifications\n * await adapter.create('users', 123, userModel);\n * // Observers will be notified about the creation\n *\n * // When done, you can disconnect\n * dispatch.unObserve(adapter);\n * ```\n */\nexport class Dispatch extends LoggedClass implements AdapterDispatch {\n  /**\n   * @description The adapter being observed\n   * @summary Reference to the database adapter whose operations are being monitored\n   */\n  protected adapter?: Adapter<any, any, any, any, any>;\n\n  /**\n   * @description List of model constructors\n   * @summary Array of model constructors that are registered with the adapter\n   */\n  protected models!: ModelConstructor<any>[];\n\n  /**\n   * @description Creates a new Dispatch instance\n   * @summary Initializes a new Dispatch instance without any adapter\n   */\n  constructor() {\n    super();\n  }\n\n  /**\n   * @description Initializes the dispatch by proxying adapter methods\n   * @summary Sets up proxies on the adapter's CRUD methods to intercept operations and notify observers.\n   * This method is called automatically when an adapter is observed.\n   * @return {Promise<void>} A promise that resolves when initialization is complete\n   * @mermaid\n   * sequenceDiagram\n   *   participant Dispatch\n   *   participant Adapter\n   *   participant Proxy\n   *\n   *   Dispatch->>Dispatch: initialize()\n   *   Dispatch->>Dispatch: Check if adapter exists\n   *   alt No adapter\n   *     Dispatch-->>Dispatch: Throw InternalError\n   *   end\n   *\n   *   loop For each CRUD method\n   *     Dispatch->>Adapter: Check if method exists\n   *     alt Method doesn't exist\n   *       Dispatch-->>Dispatch: Throw InternalError\n   *     end\n   *\n   *     Dispatch->>Adapter: Get property descriptor\n   *     loop While descriptor not found\n   *       Dispatch->>Adapter: Check prototype chain\n   *     end\n   *\n   *     alt Descriptor not found or not writable\n   *       Dispatch->>Dispatch: Log error and continue\n   *     else Descriptor found and writable\n   *       Dispatch->>Proxy: Create proxy for method\n   *       Dispatch->>Adapter: Replace method with proxy\n   *     end\n   *   end\n   */\n  protected async initialize(): Promise<void> {\n    if (!this.adapter) {\n      // Gracefully skip initialization when no adapter is observed yet.\n      // Some tests or setups may construct a Dispatch before calling observe().\n      // Instead of throwing, we no-op so that later observe() can proceed.\n      this.log.verbose(\n        `No adapter observed for dispatch; skipping initialization`\n      );\n      return;\n    }\n    const adapter = this.adapter as Adapter<any, any, any, any>;\n    (\n      [\n        OperationKeys.CREATE,\n        OperationKeys.UPDATE,\n        OperationKeys.DELETE,\n        BulkCrudOperationKeys.CREATE_ALL,\n        BulkCrudOperationKeys.UPDATE_ALL,\n        BulkCrudOperationKeys.DELETE_ALL,\n      ] as (keyof Adapter<any, any, any, any>)[]\n    ).forEach((method) => {\n      if (!adapter[method])\n        throw new InternalError(\n          `Method ${method} not found in ${adapter.alias} adapter to bind Observables Dispatch`\n        );\n\n      let descriptor = Object.getOwnPropertyDescriptor(adapter, method);\n      let proto: any = adapter;\n      while (!descriptor && proto !== Object.prototype) {\n        proto = Object.getPrototypeOf(proto);\n        descriptor = Object.getOwnPropertyDescriptor(proto, method);\n      }\n\n      if (!descriptor || !descriptor.writable) {\n        this.log.error(\n          `Could not find method ${method} to bind Observables Dispatch`\n        );\n        return;\n      }\n      function bulkToSingle(method: string) {\n        switch (method) {\n          case BulkCrudOperationKeys.CREATE_ALL:\n            return OperationKeys.CREATE;\n          case BulkCrudOperationKeys.UPDATE_ALL:\n            return OperationKeys.UPDATE;\n          case BulkCrudOperationKeys.DELETE_ALL:\n            return OperationKeys.DELETE;\n          default:\n            return method;\n        }\n      }\n      // @ts-expect-error because there are read only properties\n      adapter[method] = new Proxy(adapter[method], {\n        apply: async (target: any, thisArg, argArray: any[]) => {\n          const [tableName, ids] = argArray;\n          const result = await target.apply(thisArg, argArray);\n          this.updateObservers(tableName, bulkToSingle(method), ids as EventIds)\n            .then(() => {\n              this.log.verbose(\n                `Observer refresh dispatched by ${method} for ${tableName}`\n              );\n              this.log.debug(`pks: ${ids}`);\n            })\n            .catch((e: unknown) =>\n              this.log.error(\n                `Failed to dispatch observer refresh for ${method} on ${tableName}: ${e}`\n              )\n            );\n          return result;\n        },\n      });\n    });\n  }\n\n  /**\n   * @description Closes the dispatch\n   * @summary Performs any necessary cleanup when the dispatch is no longer needed\n   * @return {Promise<void>} A promise that resolves when closing is complete\n   */\n  async close(): Promise<void> {\n    // to nothing in this instance but may be required for closing connections\n  }\n\n  /**\n   * @description Starts observing an adapter\n   * @summary Connects this dispatch to an adapter to monitor its operations\n   * @param {Adapter<any, any, any, any>} observer - The adapter to observe\n   * @return {void}\n   */\n  observe(observer: Adapter<any, any, any, any>): void {\n    if (!(observer instanceof Adapter))\n      throw new UnsupportedError(\"Only Adapters can be observed by dispatch\");\n    this.adapter = observer;\n    this.models = Adapter.models(this.adapter.alias);\n    this.initialize().then(() =>\n      this.log.verbose(\n        `Dispatch initialized for ${this.adapter!.alias} adapter`\n      )\n    );\n  }\n\n  /**\n   * @description Stops observing an adapter\n   * @summary Disconnects this dispatch from an adapter\n   * @param {Observer} observer - The adapter to stop observing\n   * @return {void}\n   */\n  unObserve(observer: Observer): void {\n    if (this.adapter !== observer)\n      throw new UnsupportedError(\n        \"Only the adapter that was used to observe can be unobserved\"\n      );\n    this.adapter = undefined;\n  }\n\n  /**\n   * @description Updates observers about a database event\n   * @summary Notifies observers about a change in the database\n   * @param {string} table - The name of the table where the change occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {EventIds} id - The identifier(s) of the affected record(s)\n   * @return {Promise<void>} A promise that resolves when all observers have been notified\n   */\n  async updateObservers(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds\n  ): Promise<void> {\n    if (!this.adapter) {\n      this.log.verbose(\n        `No adapter observed for dispatch; skipping observer update for ${table}:${event}`\n      );\n      return;\n    }\n    try {\n      await this.adapter.refresh(table, event, id);\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to refresh dispatch: ${e}`);\n    }\n  }\n}\n\nif (Adapter) Adapter[\"_baseDispatch\"] = Dispatch;\n","import { Metadata } from \"@decaf-ts/decoration\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { OperationKeys } from \"@decaf-ts/db-decorators\";\nimport { PersistenceKeys } from \"../persistence/index\";\n\n(Metadata as any).validationExceptions = function <M extends Model>(\n  this: Metadata,\n  model: Constructor<M>,\n  op: OperationKeys\n): string[] {\n  const noValidation: Record<string, OperationKeys[]> | undefined =\n    Metadata.get(model, PersistenceKeys.NO_VALIDATE);\n  if (!noValidation) return [];\n\n  return Object.entries(noValidation)\n    .filter(([, val]) => val.includes(op))\n    .map(([key]) => key);\n}.bind(Metadata);\n","import { inject, injectable } from \"@decaf-ts/injectable-decorators\";\nimport { DBKeys, IRepository } from \"@decaf-ts/db-decorators\";\nimport { metadata } from \"@decaf-ts/reflection\";\nimport { Constructor, Model, ModelKeys } from \"@decaf-ts/decorator-validation\";\nimport { Repository } from \"./Repository\";\nimport { Adapter, PersistenceKeys } from \"../persistence\";\n\n/**\n * @description Repository decorator for model classes.\n * @summary Creates and registers a repository for a model class. Can be used as both a property decorator and a class decorator.\n * @template T - The model type that extends Model.\n * @param {Constructor<T>} model - The constructor of the model class.\n * @param {string} [flavour] - the required adapter's flavour/alias. If not provided, it will be retrieved from the model metadata..\n * @return {any} - The decorator function.\n * @function repository\n * @mermaid\n * sequenceDiagram\n *   participant C as Client Code\n *   participant D as Decorator\n *   participant R as Repository\n *   participant M as Metadata\n *\n *   C->>D: Apply @repository(Model)\n *   alt Property Decorator\n *     D->>D: Check if propertyKey exists\n *     D->>+C: Return inject(name) decorator\n *   else Class Decorator\n *     D->>M: Set repository metadata on model\n *     D->>R: Register model with Repository\n *     D->>+C: Return injectable decorator with config\n *     C->>C: Define DBKeys.CLASS property\n *   end\n * @category Decorators\n */\nexport function repository<T extends Model>(\n  model: Constructor<T>,\n  flavour?: string\n): any {\n  return ((original: any, propertyKey?: any) => {\n    if (propertyKey) {\n      return inject(model[ModelKeys.ANCHOR as keyof typeof model] || model)(\n        original,\n        propertyKey\n      );\n    }\n\n    metadata(Repository.key(DBKeys.REPOSITORY), original.name)(model);\n    flavour =\n      flavour ||\n      Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), original);\n    Repository.register(\n      model[ModelKeys.ANCHOR as keyof typeof model] || model,\n      original,\n      flavour\n    );\n    return injectable(model[ModelKeys.ANCHOR as keyof typeof model] || model, {\n      callback: (instance: IRepository<T>) => {\n        Object.defineProperty(instance, DBKeys.CLASS, {\n          enumerable: false,\n          configurable: false,\n          writable: false,\n          value: model,\n        });\n        return instance;\n      },\n    })(original);\n  }) as any;\n}\n","import { InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Error thrown when observer communication fails.\n * @summary Represents a failure in observer communication between repositories.\n * @param {string|Error} msg - The error message or Error object.\n * @class ObserverError\n * @category Errors\n * @example\n * try {\n *   // Some repository observer operation\n * } catch (error) {\n *   if (error instanceof ObserverError) {\n *     console.error('Observer communication failed:', error.message);\n *   }\n * }\n */\nexport class ObserverError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, ObserverError.name, 500);\n  }\n}\n","/**\n * @description Interface for sequence configuration options\n * @summary Defines the configuration options for creating and managing sequences\n * @interface SequenceOptions\n * @memberOf module:core\n */\nexport interface SequenceOptions<\n  TYPE = \"Number\" | \"BigInt\" | string | undefined,\n> {\n  /**\n   * @description Optional name for the sequence\n   * @summary A unique identifier for the sequence\n   */\n  name?: string;\n\n  generated?: boolean;\n\n  /**\n   * @description The data type of the sequence\n   * @summary Specifies whether the sequence generates Number or BigInt values\n   */\n  type: TYPE;\n\n  /**\n   * @description The initial value of the sequence\n   * @summary The value that the sequence starts with\n   */\n  startWith: number;\n\n  /**\n   * @description The increment value for each step in the sequence\n   * @summary The amount by which the sequence increases with each call\n   */\n  incrementBy: number;\n\n  /**\n   * @description Optional minimum value for the sequence\n   * @summary The lowest value that the sequence can generate\n   */\n  minValue?: number;\n\n  /**\n   * @description Optional maximum value for the sequence\n   * @summary The highest value that the sequence can generate\n   */\n  maxValue?: number;\n\n  /**\n   * @description Whether the sequence should cycle when reaching its limits\n   * @summary If true, the sequence will restart from minValue when reaching maxValue\n   */\n  cycle: boolean;\n}\n\n/**\n * @description Default options for sequences\n * @summary Provides a standard configuration for number sequences starting at 0 and incrementing by 1\n * @const NoneSequenceOptions\n * @memberOf module:core\n */\nexport const NoneSequenceOptions: SequenceOptions = {\n  type: undefined,\n  generated: false,\n  startWith: 0,\n  incrementBy: 1,\n  cycle: false,\n};\n\n/**\n * @description Default options for sequences\n * @summary Provides a standard configuration for number sequences starting at 0 and incrementing by 1\n * @const DefaultSequenceOptions\n * @memberOf module:core\n */\nexport const DefaultSequenceOptions: SequenceOptions = NoneSequenceOptions;\n\n/**\n * @description Predefined options for numeric sequences\n * @summary Configuration for standard number sequences starting at 0 and incrementing by 1\n * @const NumericSequence\n * @memberOf module:core\n */\nexport const NumericSequence: SequenceOptions = {\n  type: \"Number\",\n  generated: true,\n  startWith: 0,\n  incrementBy: 1,\n  cycle: false,\n};\n\n/**\n * @description Predefined options for BigInt sequences\n * @summary Configuration for BigInt sequences starting at 0 and incrementing by 1\n * @const BigIntSequence\n * @memberOf module:core\n */\nexport const BigIntSequence: SequenceOptions = Object.assign(\n  {},\n  NumericSequence,\n  {\n    type: \"BigInt\",\n  }\n);\n","import {\n  Constructor,\n  Model,\n  ModelConstructor,\n  Validation,\n  ValidationKeys,\n} from \"@decaf-ts/decorator-validation\";\nimport { Repo, Repository } from \"../repository/Repository\";\nimport { RelationsMetadata } from \"./types\";\nimport {\n  findPrimaryKey,\n  InternalError,\n  NotFoundError,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { Cascade } from \"../repository/constants\";\nimport { Context } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Creates or updates a model instance\n * @summary Determines whether to create a new model or update an existing one based on the presence of a primary key\n * @template M - The model type extending Model\n * @template F - The repository flags type\n * @param {M} model - The model instance to create or update\n * @param {Context<F>} context - The context for the operation\n * @param {Repo<M, F, Context<F>>} [repository] - Optional repository to use for the operation\n * @return {Promise<M>} A promise that resolves to the created or updated model\n * @function createOrUpdate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant createOrUpdate\n *   participant Repository\n *   participant Model\n *\n *   Caller->>createOrUpdate: model, context, repository?\n *   alt repository not provided\n *     createOrUpdate->>Model: get(model.constructor.name)\n *     Model-->>createOrUpdate: constructor\n *     createOrUpdate->>Repository: forModel(constructor)\n *     Repository-->>createOrUpdate: repository\n *   end\n *\n *   alt primary key undefined\n *     createOrUpdate->>Repository: create(model, context)\n *     Repository-->>createOrUpdate: created model\n *   else primary key defined\n *     createOrUpdate->>Repository: update(model, context)\n *     alt update successful\n *       Repository-->>createOrUpdate: updated model\n *     else NotFoundError\n *       createOrUpdate->>Repository: create(model, context)\n *       Repository-->>createOrUpdate: created model\n *     end\n *   end\n *\n *   createOrUpdate-->>Caller: model\n */\nexport async function createOrUpdate<\n  M extends Model,\n  F extends RepositoryFlags,\n>(\n  model: M,\n  context: Context<F>,\n  alias?: string,\n  repository?: Repo<M, F, Context<F>>\n): Promise<M> {\n  if (!repository) {\n    const constructor = Model.get(model.constructor.name);\n    if (!constructor)\n      throw new InternalError(`Could not find model ${model.constructor.name}`);\n    repository = Repository.forModel<M, Repo<M>>(\n      constructor as unknown as ModelConstructor<M>,\n      alias\n    );\n  }\n  if (typeof model[repository.pk] === \"undefined\")\n    return repository.create(model, context);\n  else {\n    try {\n      return repository.update(model, context);\n    } catch (e: any) {\n      if (!(e instanceof NotFoundError)) throw e;\n      return repository.create(model, context);\n    }\n  }\n}\n\n/**\n * @description Handles one-to-one relationship creation\n * @summary Processes a one-to-one relationship when creating a model, either by referencing an existing model or creating a new one\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param {string} key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToOneOnCreate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToOneOnCreate\n *   participant repositoryFromTypeMetadata\n *   participant Model\n *   participant Repository\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToOneOnCreate: this, context, data, key, model\n *   oneToOneOnCreate->>oneToOneOnCreate: check if propertyValue exists\n *\n *   alt propertyValue is not an object\n *     oneToOneOnCreate->>repositoryFromTypeMetadata: model, key\n *     repositoryFromTypeMetadata-->>oneToOneOnCreate: innerRepo\n *     oneToOneOnCreate->>innerRepo: read(propertyValue)\n *     innerRepo-->>oneToOneOnCreate: read\n *     oneToOneOnCreate->>cacheModelForPopulate: context, model, key, propertyValue, read\n *     oneToOneOnCreate->>oneToOneOnCreate: set model[key] = propertyValue\n *   else propertyValue is an object\n *     oneToOneOnCreate->>Model: get(data.class)\n *     Model-->>oneToOneOnCreate: constructor\n *     oneToOneOnCreate->>Repository: forModel(constructor)\n *     Repository-->>oneToOneOnCreate: repo\n *     oneToOneOnCreate->>repo: create(propertyValue)\n *     repo-->>oneToOneOnCreate: created\n *     oneToOneOnCreate->>findPrimaryKey: created\n *     findPrimaryKey-->>oneToOneOnCreate: pk\n *     oneToOneOnCreate->>cacheModelForPopulate: context, model, key, created[pk], created\n *     oneToOneOnCreate->>oneToOneOnCreate: set model[key] = created[pk]\n *   end\n *\n *   oneToOneOnCreate-->>Caller: void\n */\nexport async function oneToOneOnCreate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const propertyValue: any = model[key];\n  if (!propertyValue) return;\n\n  if (typeof propertyValue !== \"object\") {\n    const innerRepo = repositoryFromTypeMetadata(\n      model,\n      key,\n      this.adapter.alias\n    );\n    const read = await innerRepo.read(propertyValue);\n    await cacheModelForPopulate(context, model, key, propertyValue, read);\n    (model as any)[key] = propertyValue;\n    return;\n  }\n\n  data.class =\n    typeof data.class === \"string\" ? data.class : (data.class as any)().name;\n\n  const constructor = Model.get(data.class as string);\n  if (!constructor)\n    throw new InternalError(`Could not find model ${data.class}`);\n  const repo: Repo<any> = Repository.forModel(constructor, this.adapter.alias);\n  const created = await repo.create(propertyValue);\n  const pk = findPrimaryKey(created).id;\n  await cacheModelForPopulate(context, model, key, created[pk], created);\n  (model as any)[key] = created[pk];\n}\n\n/**\n * @description Handles one-to-one relationship updates\n * @summary Processes a one-to-one relationship when updating a model, either by referencing an existing model or updating the related model\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToOneOnUpdate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToOneOnUpdate\n *   participant repositoryFromTypeMetadata\n *   participant createOrUpdate\n *   participant findPrimaryKey\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToOneOnUpdate: this, context, data, key, model\n *   oneToOneOnUpdate->>oneToOneOnUpdate: check if propertyValue exists\n *   oneToOneOnUpdate->>oneToOneOnUpdate: check if cascade.update is CASCADE\n *\n *   alt propertyValue is not an object\n *     oneToOneOnUpdate->>repositoryFromTypeMetadata: model, key\n *     repositoryFromTypeMetadata-->>oneToOneOnUpdate: innerRepo\n *     oneToOneOnUpdate->>innerRepo: read(propertyValue)\n *     innerRepo-->>oneToOneOnUpdate: read\n *     oneToOneOnUpdate->>cacheModelForPopulate: context, model, key, propertyValue, read\n *     oneToOneOnUpdate->>oneToOneOnUpdate: set model[key] = propertyValue\n *   else propertyValue is an object\n *     oneToOneOnUpdate->>createOrUpdate: model[key], context\n *     createOrUpdate-->>oneToOneOnUpdate: updated\n *     oneToOneOnUpdate->>findPrimaryKey: updated\n *     findPrimaryKey-->>oneToOneOnUpdate: pk\n *     oneToOneOnUpdate->>cacheModelForPopulate: context, model, key, updated[pk], updated\n *     oneToOneOnUpdate->>oneToOneOnUpdate: set model[key] = updated[pk]\n *   end\n *\n *   oneToOneOnUpdate-->>Caller: void\n */\nexport async function oneToOneOnUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const propertyValue: any = model[key];\n  if (!propertyValue) return;\n  if (data.cascade.update !== Cascade.CASCADE) return;\n\n  if (typeof propertyValue !== \"object\") {\n    const innerRepo = repositoryFromTypeMetadata(\n      model,\n      key,\n      this.adapter.alias\n    );\n    const read = await innerRepo.read(propertyValue);\n    await cacheModelForPopulate(context, model, key, propertyValue, read);\n    (model as any)[key] = propertyValue;\n    return;\n  }\n\n  const updated = await createOrUpdate(\n    model[key] as M,\n    context,\n    this.adapter.alias\n  );\n  const pk = findPrimaryKey(updated).id;\n  await cacheModelForPopulate(\n    context,\n    model,\n    key,\n    updated[pk] as string,\n    updated\n  );\n  model[key] = updated[pk];\n}\n\n/**\n * @description Handles one-to-one relationship deletion\n * @summary Processes a one-to-one relationship when deleting a model, deleting the related model if cascade is enabled\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToOneOnDelete\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToOneOnDelete\n *   participant repositoryFromTypeMetadata\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToOneOnDelete: this, context, data, key, model\n *   oneToOneOnDelete->>oneToOneOnDelete: check if propertyValue exists\n *   oneToOneOnDelete->>oneToOneOnDelete: check if cascade.update is CASCADE\n *\n *   oneToOneOnDelete->>repositoryFromTypeMetadata: model, key\n *   repositoryFromTypeMetadata-->>oneToOneOnDelete: innerRepo\n *\n *   alt propertyValue is not a Model instance\n *     oneToOneOnDelete->>innerRepo: delete(model[key], context)\n *     innerRepo-->>oneToOneOnDelete: deleted\n *   else propertyValue is a Model instance\n *     oneToOneOnDelete->>innerRepo: delete(model[key][innerRepo.pk], context)\n *     innerRepo-->>oneToOneOnDelete: deleted\n *   end\n *\n *   oneToOneOnDelete->>cacheModelForPopulate: context, model, key, deleted[innerRepo.pk], deleted\n *   oneToOneOnDelete-->>Caller: void\n */\nexport async function oneToOneOnDelete<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const propertyValue: any = model[key];\n  if (!propertyValue) return;\n  if (data.cascade.update !== Cascade.CASCADE) return;\n  const innerRepo: Repo<M> = repositoryFromTypeMetadata(\n    model,\n    key,\n    this.adapter.alias\n  );\n  let deleted: M;\n  if (!(propertyValue instanceof Model))\n    deleted = await innerRepo.delete(model[key] as string);\n  else\n    deleted = await innerRepo.delete(\n      (model[key] as M)[innerRepo.pk as keyof M] as string\n    );\n  await cacheModelForPopulate(\n    context,\n    model,\n    key,\n    deleted[innerRepo.pk] as string,\n    deleted\n  );\n}\n\n/**\n * @description Handles one-to-many relationship creation\n * @summary Processes a one-to-many relationship when creating a model, either by referencing existing models or creating new ones\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToManyOnCreate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToManyOnCreate\n *   participant repositoryFromTypeMetadata\n *   participant createOrUpdate\n *   participant findPrimaryKey\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToManyOnCreate: this, context, data, key, model\n *   oneToManyOnCreate->>oneToManyOnCreate: check if propertyValues exists and has length\n *   oneToManyOnCreate->>oneToManyOnCreate: check if all elements have same type\n *   oneToManyOnCreate->>oneToManyOnCreate: create uniqueValues set\n *\n *   alt arrayType is not \"object\"\n *     oneToManyOnCreate->>repositoryFromTypeMetadata: model, key\n *     repositoryFromTypeMetadata-->>oneToManyOnCreate: repo\n *     loop for each id in uniqueValues\n *       oneToManyOnCreate->>repo: read(id)\n *       repo-->>oneToManyOnCreate: read\n *       oneToManyOnCreate->>cacheModelForPopulate: context, model, key, id, read\n *     end\n *     oneToManyOnCreate->>oneToManyOnCreate: set model[key] = [...uniqueValues]\n *   else arrayType is \"object\"\n *     oneToManyOnCreate->>findPrimaryKey: propertyValues[0]\n *     findPrimaryKey-->>oneToManyOnCreate: pkName\n *     oneToManyOnCreate->>oneToManyOnCreate: create result set\n *     loop for each m in propertyValues\n *       oneToManyOnCreate->>createOrUpdate: m, context\n *       createOrUpdate-->>oneToManyOnCreate: record\n *       oneToManyOnCreate->>cacheModelForPopulate: context, model, key, record[pkName], record\n *       oneToManyOnCreate->>oneToManyOnCreate: add record[pkName] to result\n *     end\n *     oneToManyOnCreate->>oneToManyOnCreate: set model[key] = [...result]\n *   end\n *\n *   oneToManyOnCreate-->>Caller: void\n */\nexport async function oneToManyOnCreate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const propertyValues: any = model[key];\n  if (!propertyValues || !propertyValues.length) return;\n  const arrayType = typeof propertyValues[0];\n  if (!propertyValues.every((item: any) => typeof item === arrayType))\n    throw new InternalError(\n      `Invalid operation. All elements of property ${key as string} must match the same type.`\n    );\n  const uniqueValues = new Set([...propertyValues]);\n  if (arrayType !== \"object\") {\n    const repo = repositoryFromTypeMetadata(model, key, this.adapter.alias);\n    for (const id of uniqueValues) {\n      const read = await repo.read(id);\n      await cacheModelForPopulate(context, model, key, id, read);\n    }\n    (model as any)[key] = [...uniqueValues];\n    return;\n  }\n\n  const pkName = findPrimaryKey(propertyValues[0]).id;\n\n  const result: Set<string> = new Set();\n\n  for (const m of propertyValues) {\n    const record = await createOrUpdate(m, context, this.adapter.alias);\n    await cacheModelForPopulate(context, model, key, record[pkName], record);\n    result.add(record[pkName]);\n  }\n\n  (model as any)[key] = [...result];\n}\n\n/**\n * @description Handles one-to-many relationship updates\n * @summary Processes a one-to-many relationship when updating a model, delegating to oneToManyOnCreate if cascade update is enabled\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToManyOnUpdate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToManyOnUpdate\n *   participant oneToManyOnCreate\n *\n *   Caller->>oneToManyOnUpdate: this, context, data, key, model\n *   oneToManyOnUpdate->>oneToManyOnUpdate: check if cascade.update is CASCADE\n *\n *   alt cascade.update is CASCADE\n *     oneToManyOnUpdate->>oneToManyOnCreate: apply(this, [context, data, key, model])\n *     oneToManyOnCreate-->>oneToManyOnUpdate: void\n *   end\n *\n *   oneToManyOnUpdate-->>Caller: void\n */\nexport async function oneToManyOnUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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  const { cascade } = data;\n  if (cascade.update !== Cascade.CASCADE) return;\n  return oneToManyOnCreate.apply(this as any, [\n    context,\n    data,\n    key as keyof Model,\n    model,\n  ]);\n}\n\n/**\n * @description Handles one-to-many relationship deletion\n * @summary Processes a one-to-many relationship when deleting a model, deleting all related models if cascade delete is enabled\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function oneToManyOnDelete\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant oneToManyOnDelete\n *   participant Repository\n *   participant repositoryFromTypeMetadata\n *   participant cacheModelForPopulate\n *\n *   Caller->>oneToManyOnDelete: this, context, data, key, model\n *   oneToManyOnDelete->>oneToManyOnDelete: check if cascade.delete is CASCADE\n *   oneToManyOnDelete->>oneToManyOnDelete: check if values exists and has length\n *   oneToManyOnDelete->>oneToManyOnDelete: check if all elements have same type\n *\n *   alt isInstantiated (arrayType is \"object\")\n *     oneToManyOnDelete->>Repository: forModel(values[0])\n *     Repository-->>oneToManyOnDelete: repo\n *   else not instantiated\n *     oneToManyOnDelete->>repositoryFromTypeMetadata: model, key\n *     repositoryFromTypeMetadata-->>oneToManyOnDelete: repo\n *   end\n *\n *   oneToManyOnDelete->>oneToManyOnDelete: create uniqueValues set\n *\n *   loop for each id in uniqueValues\n *     oneToManyOnDelete->>repo: delete(id, context)\n *     repo-->>oneToManyOnDelete: deleted\n *     oneToManyOnDelete->>cacheModelForPopulate: context, model, key, id, deleted\n *   end\n *\n *   oneToManyOnDelete->>oneToManyOnDelete: set model[key] = [...uniqueValues]\n *   oneToManyOnDelete-->>Caller: void\n */\nexport async function oneToManyOnDelete<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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.cascade.delete !== Cascade.CASCADE) return;\n  const values = model[key] as any;\n  if (!values || !values.length) return;\n  const arrayType = typeof values[0];\n  const areAllSameType = values.every((item: any) => typeof item === arrayType);\n  if (!areAllSameType)\n    throw new InternalError(\n      `Invalid operation. All elements of property ${key as string} must match the same type.`\n    );\n  const isInstantiated = arrayType === \"object\";\n  const repo = isInstantiated\n    ? Repository.forModel(values[0], this.adapter.alias)\n    : repositoryFromTypeMetadata(model, key, this.adapter.alias);\n\n  const uniqueValues = new Set([\n    ...(isInstantiated\n      ? values.map((v: Record<string, any>) => v[repo.pk as string])\n      : values),\n  ]);\n\n  for (const id of uniqueValues.values()) {\n    const deleted = await repo.delete(id);\n    await cacheModelForPopulate(context, model, key, id, deleted);\n  }\n  (model as any)[key] = [...uniqueValues];\n}\n\n/**\n * @description Generates a key for caching populated model relationships\n * @summary Creates a unique key for storing and retrieving populated model relationships in the cache\n * @param {string} tableName - The name of the table or model\n * @param {string} fieldName - The name of the field or property\n * @param {string|number} id - The identifier of the related model\n * @return {string} A dot-separated string that uniquely identifies the relationship\n * @function getPopulateKey\n * @memberOf module:core\n */\nexport function getPopulateKey(\n  tableName: string,\n  fieldName: string,\n  id: string | number\n) {\n  return [PersistenceKeys.POPULATE, tableName, fieldName, id].join(\".\");\n}\n\n/**\n * @description Caches a model for later population\n * @summary Stores a model in the context cache for efficient retrieval during relationship population\n * @template M - The model type extending Model\n * @template F - The repository flags type\n * @param {Context<F>} context - The context for the operation\n * @param {M} parentModel - The parent model that contains the relationship\n * @param propertyKey - The property key of the relationship\n * @param {string | number} pkValue - The primary key value of the related model\n * @param {any} cacheValue - The model instance to cache\n * @return {Promise<any>} A promise that resolves with the result of the cache operation\n * @function cacheModelForPopulate\n * @memberOf module:core\n */\nexport async function cacheModelForPopulate<\n  M extends Model,\n  F extends RepositoryFlags,\n>(\n  context: Context<F>,\n  parentModel: M,\n  propertyKey: keyof M | string,\n  pkValue: string | number,\n  cacheValue: any\n) {\n  const cacheKey = getPopulateKey(\n    parentModel.constructor.name,\n    propertyKey as string,\n    pkValue\n  );\n  return context.accumulate({ [cacheKey]: cacheValue });\n}\n\n/**\n * @description Populates a model's relationship\n * @summary Retrieves and attaches related models to a model's relationship property\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The relations metadata\n * @param key - The property key of the relationship\n * @param {M} model - The model instance\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function populate\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant populate\n *   participant fetchPopulateValues\n *   participant getPopulateKey\n *   participant Context\n *   participant repositoryFromTypeMetadata\n *\n *   Caller->>populate: this, context, data, key, model\n *   populate->>populate: check if data.populate is true\n *   populate->>populate: get nested value and check if it exists\n *\n *   populate->>fetchPopulateValues: context, model, key, isArr ? nested : [nested]\n *\n *   fetchPopulateValues->>fetchPopulateValues: initialize variables\n *\n *   loop for each proKeyValue in propKeyValues\n *     fetchPopulateValues->>getPopulateKey: model.constructor.name, propName, proKeyValue\n *     getPopulateKey-->>fetchPopulateValues: cacheKey\n *\n *     alt try to get from cache\n *       fetchPopulateValues->>Context: get(cacheKey)\n *       Context-->>fetchPopulateValues: val\n *     else catch error\n *       fetchPopulateValues->>repositoryFromTypeMetadata: model, propName\n *       repositoryFromTypeMetadata-->>fetchPopulateValues: repo\n *       fetchPopulateValues->>repo: read(proKeyValue)\n *       repo-->>fetchPopulateValues: val\n *     end\n *\n *     fetchPopulateValues->>fetchPopulateValues: add val to results\n *   end\n *\n *   fetchPopulateValues-->>populate: results\n *   populate->>populate: set model[key] = isArr ? res : res[0]\n *   populate-->>Caller: void\n */\nexport async function populate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\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.populate) return;\n  const nested: any = model[key];\n  const isArr = Array.isArray(nested);\n  if (typeof nested === \"undefined\" || (isArr && nested.length === 0)) return;\n\n  async function fetchPopulateValues(\n    c: Context<F>,\n    model: M,\n    propName: string,\n    propKeyValues: any[],\n    alias?: string\n  ) {\n    let cacheKey: string;\n    let val: any;\n    const results: M[] = [];\n    for (const proKeyValue of propKeyValues) {\n      cacheKey = getPopulateKey(model.constructor.name, propName, proKeyValue);\n      try {\n        val = await c.get(cacheKey as any);\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: any) {\n        const repo = repositoryFromTypeMetadata(model, propName, alias);\n        if (!repo) throw new InternalError(\"Could not find repo\");\n        val = await repo.read(proKeyValue);\n      }\n      results.push(val);\n    }\n    return results;\n  }\n  const res = await fetchPopulateValues(\n    context,\n    model,\n    key as string,\n    isArr ? nested : [nested],\n    this.adapter.alias\n  );\n  (model as any)[key] = isArr ? res : res[0];\n}\n\n/**\n * @description List of common JavaScript types\n * @summary An array of strings representing common JavaScript types that are not custom model types\n * @const commomTypes\n * @memberOf module:core\n */\nconst commomTypes = [\n  \"array\",\n  \"string\",\n  \"number\",\n  \"boolean\",\n  \"symbol\",\n  \"function\",\n  \"object\",\n  \"undefined\",\n  \"null\",\n  \"bigint\",\n];\n\n/**\n * @description Retrieves a repository for a model property based on its type metadata\n * @summary Examines a model property's type metadata to determine the appropriate repository for related models\n * @template M - The model type extending Model\n * @param {any} model - The model instance containing the property\n * @param propertyKey - The property key to examine\n * @return {Repo<M>} A repository for the model type associated with the property\n * @function repositoryFromTypeMetadata\n * @memberOf module:core\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant repositoryFromTypeMetadata\n *   participant Reflect\n *   participant Validation\n *   participant Model\n *   participant Repository\n *\n *   Caller->>repositoryFromTypeMetadata: model, propertyKey\n *\n *   repositoryFromTypeMetadata->>Validation: key(Array.isArray(model[propertyKey]) ? ValidationKeys.LIST : ValidationKeys.TYPE)\n *   Validation-->>repositoryFromTypeMetadata: validationKey\n *\n *   repositoryFromTypeMetadata->>Reflect: getMetadata(validationKey, model, propertyKey)\n *   Reflect-->>repositoryFromTypeMetadata: types\n *\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: determine customTypes based on property type\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: check if types and customTypes exist\n *\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: create allowedTypes array\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: find constructorName not in commomTypes\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: check if constructorName exists\n *\n *   repositoryFromTypeMetadata->>Model: get(constructorName)\n *   Model-->>repositoryFromTypeMetadata: constructor\n *   repositoryFromTypeMetadata->>repositoryFromTypeMetadata: check if constructor exists\n *\n *   repositoryFromTypeMetadata->>Repository: forModel(constructor)\n *   Repository-->>repositoryFromTypeMetadata: repo\n *\n *   repositoryFromTypeMetadata-->>Caller: repo\n */\nexport function repositoryFromTypeMetadata<M extends Model>(\n  model: any,\n  propertyKey: string | keyof M,\n  alias?: string\n): Repo<M> {\n  const types = Reflect.getMetadata(\n    Validation.key(\n      Array.isArray(model[propertyKey])\n        ? ValidationKeys.LIST\n        : ValidationKeys.TYPE\n    ),\n    model,\n    propertyKey as string\n  );\n  const customTypes: any = Array.isArray(model[propertyKey])\n    ? types.clazz\n    : types.customTypes;\n  if (!types || !customTypes)\n    throw new InternalError(\n      `Failed to find types decorators for property ${propertyKey as string}`\n    );\n\n  const allowedTypes: string[] = (\n    Array.isArray(customTypes) ? [...customTypes] : [customTypes]\n  ).map((t) => (typeof t === \"function\" ? t() : t));\n  const constructorName = allowedTypes.find(\n    (t) => !commomTypes.includes(`${t}`.toLowerCase())\n  );\n  if (!constructorName)\n    throw new InternalError(\n      `Property key ${propertyKey as string} does not have a valid constructor type`\n    );\n  const constructor: Constructor<M> | undefined = Model.get(constructorName);\n  if (!constructor)\n    throw new InternalError(`No registered model found for ${constructorName}`);\n\n  return Repository.forModel(constructor, alias);\n}\n","import {\n  afterAny,\n  ConflictError,\n  Context,\n  onCreate,\n  onCreateUpdate,\n  onDelete,\n  onUpdate,\n  OperationKeys,\n  RepositoryFlags,\n  timestamp,\n} from \"@decaf-ts/db-decorators\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport {\n  apply as newApply,\n  Metadata,\n  metadata as newMetadata,\n} from \"@decaf-ts/decoration\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { CascadeMetadata, IndexMetadata } from \"../repository/types\";\nimport { DefaultCascade, OrderDirection } from \"../repository/constants\";\nimport {\n  Constructor,\n  Decoration,\n  list,\n  Model,\n  prop,\n  propMetadata,\n  type,\n} from \"@decaf-ts/decorator-validation\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Repo, Repository } from \"../repository/Repository\";\nimport { Condition } from \"../query/Condition\";\nimport {\n  JoinColumnOptions,\n  JoinTableMultipleColumnsOptions,\n  JoinTableOptions,\n  RelationsMetadata,\n} from \"./types\";\nimport {\n  oneToManyOnCreate,\n  oneToManyOnDelete,\n  oneToManyOnUpdate,\n  oneToOneOnCreate,\n  oneToOneOnDelete,\n  oneToOneOnUpdate,\n  populate as pop,\n} from \"./construction\";\nimport { AuthorizationError } from \"../utils\";\n\n/**\n * @description Specifies the database table name for a model\n * @summary Decorator that sets the table name for a model class in the database\n * @param {string} opts - The name of the table in the database\n * @return {Function} A decorator function that can be applied to a class\n * @function table\n * @category Class Decorators\n */\nexport function table<OPTS = string>(opts?: OPTS) {\n  return function table(target: any) {\n    const key = Adapter.key(PersistenceKeys.TABLE);\n    return Decoration.for(key)\n      .define({\n        decorator: metadata,\n        args: [key, opts || target.name.toLowerCase()],\n      })\n      .apply()(target);\n  };\n}\n\n/**\n * @description Specifies the database column name for a model property\n * @summary Decorator that maps a model property to a specific column name in the database\n * @param {string} columnName - The name of the column in the database\n * @return {Function} A decorator function that can be applied to a class property\n * @function column\n * @category Property Decorators\n */\nexport function column<OPTS = string>(columnName?: OPTS) {\n  const key = Adapter.key(PersistenceKeys.COLUMN);\n  return Decoration.for(key)\n    .define({\n      decorator: function column(k, c) {\n        return function column(obj: any, attr: any) {\n          return propMetadata(k, c || attr)(obj, attr);\n        };\n      },\n      args: [key, columnName],\n    })\n    .apply();\n}\n\n/**\n * @description Creates an index on a model property for improved query performance\n * @summary Decorator that marks a property to be indexed in the database, optionally with specific directions and compositions\n * @param {OrderDirection[]} [directions] - Optional array of sort directions for the index\n * @param {string[]} [compositions] - Optional array of property names to create a composite index\n * @return {Function} A decorator function that can be applied to a class property\n * @function index\n * @category Property Decorators\n */\nexport function index(): ReturnType<typeof propMetadata>;\nexport function index(name: string): ReturnType<typeof propMetadata>;\nexport function index(\n  directions: OrderDirection[]\n): ReturnType<typeof propMetadata>;\nexport function index(\n  directions: OrderDirection[],\n  name: string\n): ReturnType<typeof propMetadata>;\nexport function index(compositions: string[]): ReturnType<typeof propMetadata>;\nexport function index(\n  compositions: string[],\n  name: string\n): ReturnType<typeof propMetadata>;\nexport function index(\n  directions?: OrderDirection[] | string[] | string,\n  compositions?: string[] | string,\n  name?: string\n) {\n  function index(\n    directions?: OrderDirection[] | string[] | string,\n    compositions?: string[] | string,\n    name?: string\n  ) {\n    if (typeof directions === \"string\") {\n      name = directions;\n      directions = undefined;\n      compositions = undefined;\n    }\n    if (typeof compositions === \"string\") {\n      name = compositions;\n      compositions = undefined;\n    }\n    if (!compositions && directions) {\n      if (\n        directions.find(\n          (d) => ![OrderDirection.ASC, OrderDirection.DSC].includes(d as any)\n        )\n      ) {\n        compositions = directions as string[];\n        directions = undefined;\n      }\n    }\n\n    return propMetadata(\n      Repository.key(\n        `${PersistenceKeys.INDEX}${compositions && compositions.length ? `.${compositions.join(\".\")}` : \"\"}`\n      ),\n      {\n        directions: directions,\n        compositions: compositions,\n        name: name,\n      } as IndexMetadata\n    );\n  }\n\n  return Decoration.for(PersistenceKeys.INDEX)\n    .define({\n      decorator: index,\n      args: [directions, compositions, name],\n    })\n    .apply();\n}\n\n/**\n * @description Enforces uniqueness constraint during model creation and update\n * @summary Internal function used by the unique decorator to check if a property value already exists in the database\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The metadata type\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The metadata for the property\n * @param key - The property key to check for uniqueness\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the check is complete or rejects with a ConflictError\n * @function uniqueOnCreateUpdate\n * @memberOf module:core\n */\nexport async function uniqueOnCreateUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends object,\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 (!(model as any)[key]) return;\n  const existing = await this.select()\n    .where(Condition.attribute(key).eq(model[key]))\n    .execute();\n  if (existing.length)\n    throw new ConflictError(\n      `model already exists with property ${key as string} equal to ${JSON.stringify((model as any)[key], undefined, 2)}`\n    );\n}\n\n/**\n * @description Tags a property as unique\n * @summary Decorator that ensures a property value is unique across all instances of a model in the database\n * @return {Function} A decorator function that can be applied to a class property\n * @function unique\n * @category Property Decorators\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @unique()\n *   @required()\n *   username!: string;\n * }\n * ```\n */\nexport function unique() {\n  const key = Repository.key(PersistenceKeys.UNIQUE);\n  return Decoration.for(key)\n    .define(onCreateUpdate(uniqueOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\n/**\n * @description Handles user identification for ownership tracking\n * @summary Internal function used by the createdBy and updatedBy decorators to set ownership information\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The metadata for the property\n * @param key - The property key to store the user identifier\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that rejects with an AuthorizationError if user identification is not supported\n * @function createdByOnCreateUpdate\n * @memberOf module:core\n */\nexport async function createdByOnCreateUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  this: R,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  context: Context<F>,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  data: V,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  key: keyof M,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  model: M\n): Promise<void> {\n  throw new AuthorizationError(\n    \"This adapter does not support user identification\"\n  );\n}\n\n/**\n * @description Tracks the creator of a model instance\n * @summary Decorator that marks a property to store the identifier of the user who created the model instance\n * @return {Function} A decorator function that can be applied to a class property\n * @function createdBy\n * @category Property Decorators\n * @example\n * ```typescript\n * class Document extends BaseModel {\n *   @createdBy()\n *   creator!: string;\n * }\n * ```\n */\nexport function createdBy() {\n  const key = Repository.key(PersistenceKeys.CREATED_BY);\n  return Decoration.for(key)\n    .define(onCreate(createdByOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\n/**\n * @description Tracks the last updater of a model instance\n * @summary Decorator that marks a property to store the identifier of the user who last updated the model instance\n * @return {Function} A decorator function that can be applied to a class property\n * @function updatedBy\n * @category Property Decorators\n * @example\n * ```typescript\n * class Document extends BaseModel {\n *   @updatedBy()\n *   lastEditor!: string;\n * }\n * ```\n */\nexport function updatedBy() {\n  const key = Repository.key(PersistenceKeys.UPDATED_BY);\n  return Decoration.for(key)\n    .define(onCreateUpdate(createdByOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\nexport function createdAt() {\n  return timestamp([OperationKeys.CREATE]);\n}\n\nexport function updatedAt() {\n  return timestamp();\n}\n\n/**\n * @description Defines a one-to-one relationship between models\n * @summary Decorator that establishes a one-to-one relationship between the current model and another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function oneToOne\n * @category Property Decorators\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @oneToOne(Profile)\n *   profile!: string | Profile;\n * }\n *\n * class Profile extends BaseModel {\n *   @required()\n *   bio!: string;\n * }\n * ```\n * @see oneToMany\n * @see manyToOne\n */\nexport function oneToOne<M extends Model>(\n  clazz: Constructor<M> | (() => Constructor<M>),\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true,\n  joinColumnOpts?: JoinColumnOptions,\n  fk?: string\n) {\n  const key = Repository.key(PersistenceKeys.ONE_TO_ONE);\n  // Model.register(clazz as Constructor<M>);\n\n  function oneToOneDec(\n    clazz: Constructor<M> | (() => Constructor<M>),\n    cascade: CascadeMetadata,\n    populate: boolean,\n    joinColumnOpts?: JoinColumnOptions,\n    fk?: string\n  ) {\n    const meta: RelationsMetadata = {\n      class: clazz.name ? clazz.name : (clazz as any),\n      cascade: cascade,\n      populate: populate,\n    };\n    if (joinColumnOpts) meta.joinTable = joinColumnOpts;\n    if (fk) meta.name = fk;\n    return apply(\n      prop(PersistenceKeys.RELATIONS),\n      type([\n        clazz.name ? clazz.name : (clazz as any),\n        String.name,\n        Number.name,\n        BigInt.name,\n      ]),\n      onCreate(oneToOneOnCreate, meta),\n      onUpdate(oneToOneOnUpdate, meta),\n      onDelete(oneToOneOnDelete, meta),\n      afterAny(pop, meta),\n      propMetadata(key, meta)\n    );\n  }\n\n  return Decoration.for(key)\n    .define({\n      decorator: oneToOneDec,\n      args: [clazz, cascadeOptions, populate, joinColumnOpts, fk],\n    })\n    .apply();\n}\n\n/**\n * @description Defines a one-to-many relationship between models\n * @summary Decorator that establishes a one-to-many relationship between the current model and multiple instances of another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function oneToMany\n * @category Property Decorators\n * @example\n * ```typescript\n * class Author extends BaseModel {\n *   @required()\n *   name!: string;\n *\n *   @oneToMany(Book)\n *   books!: string[] | Book[];\n * }\n *\n * class Book extends BaseModel {\n *   @required()\n *   title!: string;\n * }\n * ```\n * @see oneToOne\n * @see manyToOne\n */\nexport function oneToMany<M extends Model>(\n  clazz: Constructor<M> | (() => Constructor<M>),\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true,\n  joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n  fk?: string\n) {\n  const key = Repository.key(PersistenceKeys.ONE_TO_MANY);\n\n  function oneToManyDec(\n    clazz: Constructor<M> | (() => Constructor<M>),\n    cascade: CascadeMetadata,\n    populate: boolean,\n    joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n    fk?: string\n  ) {\n    const metadata: RelationsMetadata = {\n      class: clazz.name ? clazz.name : (clazz as any),\n      cascade: cascade,\n      populate: populate,\n    };\n    if (joinTableOpts) metadata.joinTable = joinTableOpts;\n    if (fk) metadata.name = fk;\n    return apply(\n      prop(PersistenceKeys.RELATIONS),\n      list([\n        clazz as Constructor<M>,\n        String,\n        Number,\n        // @ts-expect-error Bigint is not a constructor\n        BigInt,\n      ]),\n      onCreate(oneToManyOnCreate, metadata),\n      onUpdate(oneToManyOnUpdate, metadata),\n      onDelete(oneToManyOnDelete, metadata),\n      afterAny(pop, metadata),\n      propMetadata(key, metadata)\n    );\n  }\n\n  return Decoration.for(key)\n    .define({\n      decorator: oneToManyDec,\n      args: [clazz, cascadeOptions, populate, joinTableOpts, fk],\n    })\n    .apply();\n}\n\n/**\n * @description Defines a many-to-one relationship between models\n * @summary Decorator that establishes a many-to-one relationship between multiple instances of the current model and another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function manyToOne\n * @category Property Decorators\n * @example\n * ```typescript\n * class Book extends BaseModel {\n *   @required()\n *   title!: string;\n *\n *   @manyToOne(Author)\n *   author!: string | Author;\n * }\n *\n * class Author extends BaseModel {\n *   @required()\n *   name!: string;\n * }\n * ```\n * @see oneToMany\n * @see oneToOne\n */\nexport function manyToOne<M extends Model>(\n  clazz: Constructor<M> | (() => Constructor<M>),\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate = true,\n  joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n  fk?: string\n) {\n  // Model.register(clazz as Constructor<M>);\n  const key = Repository.key(PersistenceKeys.MANY_TO_ONE);\n\n  function manyToOneDec(\n    clazz: Constructor<M> | (() => Constructor<M>),\n    cascade: CascadeMetadata,\n    populate: boolean,\n    joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n    fk?: string\n  ) {\n    const clazzName = () =>\n      (clazz?.name ? clazz : (clazz as () => Constructor<M>)()).name;\n\n    const metadata: RelationsMetadata = {\n      class: clazz?.name ? clazz.name : (clazz as any),\n      cascade: cascade,\n      populate: populate,\n    };\n    if (joinTableOpts) metadata.joinTable = joinTableOpts;\n    if (fk) metadata.name = fk;\n    return apply(\n      prop(PersistenceKeys.RELATIONS),\n      type([clazzName, String.name, Number.name, BigInt.name]),\n      // onCreate(oneToManyOnCreate, metadata),\n      // onUpdate(oneToManyOnUpdate, metadata),\n      // onDelete(oneToManyOnDelete, metadata),\n      // afterAny(pop, metadata),\n      propMetadata(key, metadata)\n    );\n  }\n\n  return Decoration.for(key)\n    .define({\n      decorator: manyToOneDec,\n      args: [clazz, cascadeOptions, populate, joinTableOpts, fk],\n    })\n    .apply();\n}\n\n/**\n * @description Defines a many-to-one relationship between models\n * @summary Decorator that establishes a many-to-one relationship between multiple instances of the current model and another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function manyToOne\n * @category Property Decorators\n * @example\n * ```typescript\n * class Book extends BaseModel {\n *   @required()\n *   title!: string;\n *\n *   @manyToOne(Author)\n *   author!: string | Author;\n * }\n *\n * class Author extends BaseModel {\n *   @required()\n *   name!: string;\n * }\n * ```\n * @see oneToMany\n * @see oneToOne\n */\nexport function manyToMany<M extends Model>(\n  clazz: Constructor<M> | (() => Constructor<M>),\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate = true,\n  joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n  fk?: string\n) {\n  // Model.register(clazz as Constructor<M>);\n  const key = Repository.key(PersistenceKeys.MANY_TO_MANY);\n\n  function manyToManyDec(\n    clazz: Constructor<M> | (() => Constructor<M>),\n    cascade: CascadeMetadata,\n    populate: boolean,\n    joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n    fk?: string\n  ) {\n    const metadata: RelationsMetadata = {\n      class: clazz.name ? clazz.name : (clazz as any),\n      cascade: cascade,\n      populate: populate,\n    };\n    if (joinTableOpts) metadata.joinTable = joinTableOpts;\n    if (fk) metadata.name = fk;\n    return apply(\n      prop(PersistenceKeys.RELATIONS),\n      list([\n        clazz.name ? clazz.name : (clazz as any),\n        String.name,\n        Number.name,\n        BigInt.name,\n      ]),\n      // onCreate(oneToManyOnCreate, metadata),\n      // onUpdate(oneToManyOnUpdate, metadata),\n      // onDelete(oneToManyOnDelete, metadata),\n      // afterAll(populate, metadata),\n      propMetadata(key, metadata)\n    );\n  }\n  return Decoration.for(key)\n    .define({\n      decorator: manyToManyDec,\n      args: [clazz, cascadeOptions, populate, joinTableOpts, fk],\n    })\n    .apply();\n}\n\nexport function noValidateOn(...ops: OperationKeys[]) {\n  return function noValidateOn(target: any, propertyKey?: any) {\n    const currentMeta =\n      Metadata.get(\n        target,\n        Metadata.key(PersistenceKeys.NO_VALIDATE, propertyKey)\n      ) || [];\n    const newMeta = [...new Set([...currentMeta, ...ops])];\n    return newApply(\n      newMetadata(\n        Metadata.key(PersistenceKeys.NO_VALIDATE, propertyKey),\n        newMeta\n      )\n    )(target, propertyKey);\n  };\n}\n\nexport function noValidateOnCreate() {\n  return noValidateOn(OperationKeys.CREATE);\n}\n\nexport function noValidateOnUpdate() {\n  return noValidateOn(OperationKeys.UPDATE);\n}\n\nexport function noValidateOnCreateUpdate() {\n  return noValidateOn(OperationKeys.UPDATE, OperationKeys.CREATE);\n}\n","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  GroupSort,\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\nconst defaultPkPriority = 60; // Default priority for primary key to run latter than other properties\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, groupsort?: GroupSort) {\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, groupsort),\n        propMetadata(DBKeys.ID, attr)\n      )(obj, attr);\n    };\n  }\n  return Decoration.for(key)\n    .define({\n      decorator: pkDec,\n      args: [opts, { priority: defaultPkPriority }],\n    })\n    .apply();\n}\n","import { ModelArg, Model } from \"@decaf-ts/decorator-validation\";\nimport { createdAt, updatedAt } from \"./decorators\";\n\n/**\n * @description Base model class for all domain models\n * @summary An abstract base class that extends the Model class from decorator-validation and adds timestamp functionality.\n * All domain models in the application should extend this class to inherit common properties and behaviors.\n * @param {ModelArg<BaseModel>} arg - Optional initialization data for the model\n * @class BaseModel\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @required()\n *   username!: string;\n *   \n *   @email()\n *   email!: string;\n *   \n *   constructor(data?: ModelArg<User>) {\n *     super(data);\n *   }\n * }\n * \n * const user = new User({ username: 'john', email: 'john@example.com' });\n * ```\n */\nexport abstract class BaseModel extends Model {\n  /**\n   * @description Creation timestamp for the model\n   * @summary Automatically set to the current date and time when the model is created\n   */\n  @createdAt()\n  createdOn!: Date;\n\n  /**\n   * @description Last update timestamp for the model\n   * @summary Automatically updated to the current date and time whenever the model is modified\n   */\n  @updatedAt()\n  updatedOn!: Date;\n\n  protected constructor(arg?: ModelArg<BaseModel>) {\n    super(arg);\n  }\n}\n","import { PagingError } from \"./errors\";\nimport { Adapter } from \"../persistence\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\n\n/**\n * @description Handles pagination for database queries\n * @summary Provides functionality for navigating through paginated query results\n *\n * This abstract class manages the state and navigation of paginated database query results.\n * It tracks the current page, total pages, and record count, and provides methods for\n * moving between pages.\n *\n * @template M - The model type this paginator operates on\n * @template R - The return type of the paginated query (defaults to M[])\n * @template Q - The query type (defaults to any)\n * @param {Adapter<any, Q, any, any>} adapter - The database adapter to use for executing queries\n * @param {Q} query - The query to paginate\n * @param {number} size - The number of records per page\n * @param {Constructor<M>} clazz - The constructor for the model type\n * @class Paginator\n * @example\n * // Create a paginator for a user query\n * const userQuery = db.select().from(User);\n * const paginator = await userQuery.paginate(10); // 10 users per page\n *\n * // Get the first page of results\n * const firstPage = await paginator.page(1);\n *\n * // Navigate to the next page\n * const secondPage = await paginator.next();\n *\n * // Get information about the pagination\n * console.log(`Page ${paginator.current} of ${paginator.total}, ${paginator.count} total records`);\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Paginator\n *   participant Adapter\n *   participant Database\n *\n *   Client->>Paginator: new Paginator(adapter, query, size, clazz)\n *   Client->>Paginator: page(1)\n *   Paginator->>Paginator: validatePage(1)\n *   Paginator->>Paginator: prepare(query)\n *   Paginator->>Adapter: execute query with pagination\n *   Adapter->>Database: execute query\n *   Database-->>Adapter: return results\n *   Adapter-->>Paginator: return results\n *   Paginator-->>Client: return page results\n *\n *   Client->>Paginator: next()\n *   Paginator->>Paginator: page(current + 1)\n *   Paginator->>Paginator: validatePage(current + 1)\n *   Paginator->>Adapter: execute query with pagination\n *   Adapter->>Database: execute query\n *   Database-->>Adapter: return results\n *   Adapter-->>Paginator: return results\n *   Paginator-->>Client: return page results\n */\nexport abstract class Paginator<M extends Model, R = M[], Q = any> {\n  protected _currentPage!: number;\n  protected _totalPages!: number;\n  protected _recordCount!: number;\n  protected limit!: number;\n\n  private _statement?: Q;\n\n  get current() {\n    return this._currentPage;\n  }\n\n  get total() {\n    return this._totalPages;\n  }\n\n  get count(): number {\n    return this._recordCount;\n  }\n\n  protected get statement() {\n    if (!this._statement) this._statement = this.prepare(this.query);\n    return this._statement;\n  }\n\n  protected constructor(\n    protected readonly adapter: Adapter<any, any, Q, any, any>,\n    protected readonly query: Q,\n    readonly size: number,\n    protected readonly clazz: Constructor<M>\n  ) {}\n\n  protected abstract prepare(rawStatement: Q): Q;\n\n  async next() {\n    return this.page(this.current + 1);\n  }\n\n  async previous() {\n    return this.page(this.current - 1);\n  }\n\n  protected validatePage(page: number) {\n    if (page < 1 || !Number.isInteger(page))\n      throw new PagingError(\n        \"Page number cannot be under 1 and must be an integer\"\n      );\n    if (typeof this._totalPages !== \"undefined\" && page > this._totalPages)\n      throw new PagingError(\n        `Only ${this._totalPages} are available. Cannot go to page ${page}`\n      );\n    return page;\n  }\n\n  abstract page(page?: number): Promise<R[]>;\n}\n","import { type Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport type { Executor, RawExecutor } from \"../interfaces\";\nimport type {\n  FromSelector,\n  GroupBySelector,\n  OrderBySelector,\n  SelectSelector,\n} from \"./selectors\";\nimport { Condition } from \"./Condition\";\nimport { findPrimaryKey, InternalError } from \"@decaf-ts/db-decorators\";\nimport { final } from \"../utils/decorators\";\nimport type {\n  CountOption,\n  DistinctOption,\n  LimitOption,\n  MaxOption,\n  MinOption,\n  OffsetOption,\n  OrderAndGroupOption,\n  SelectOption,\n  WhereOption,\n} from \"./options\";\nimport { Paginatable } from \"../interfaces/Paginatable\";\nimport { Paginator } from \"./Paginator\";\nimport { Adapter } from \"../persistence\";\nimport { QueryError } from \"./errors\";\nimport { Logger } from \"@decaf-ts/logging\";\nimport { LoggedClass } from \"@decaf-ts/logging\";\n\n/**\n * @description Base class for database query statements\n * @summary Provides a foundation for building and executing database queries\n *\n * This abstract class implements the query builder pattern for constructing\n * database queries. It supports various query operations like select, from,\n * where, orderBy, groupBy, limit, and offset. It also provides methods for\n * executing queries and handling pagination.\n *\n * @template Q - The query type specific to the database adapter\n * @template M - The model type this statement operates on\n * @template R - The return type of the query\n * @param {Adapter<any, Q, any, any>} adapter - The database adapter to use for executing queries\n * @class Statement\n * @example\n * // Create a statement to query users\n * const statement = new SQLStatement(adapter);\n * const users = await statement\n *   .select()\n *   .from(User)\n *   .where(Condition.attribute(\"status\").eq(\"active\"))\n *   .orderBy([\"createdAt\", \"DESC\"])\n *   .limit(10)\n *   .execute();\n *\n * // Use pagination\n * const paginator = await statement\n *   .select()\n *   .from(User)\n *   .paginate(20); // 20 users per page\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Statement\n *   participant Adapter\n *   participant Database\n *\n *   Client->>Statement: select()\n *   Client->>Statement: from(Model)\n *   Client->>Statement: where(condition)\n *   Client->>Statement: orderBy([field, direction])\n *   Client->>Statement: limit(value)\n *   Client->>Statement: execute()\n *   Statement->>Statement: build()\n *   Statement->>Adapter: raw(query)\n *   Adapter->>Database: execute query\n *   Database-->>Adapter: return results\n *   Adapter-->>Statement: return processed results\n *   Statement-->>Client: return final results\n */\nexport abstract class Statement<Q, M extends Model, R>\n  extends LoggedClass\n  implements Executor<R>, RawExecutor<Q>, Paginatable<M, R, Q>\n{\n  protected readonly selectSelector?: SelectSelector<M>[];\n  protected distinctSelector?: SelectSelector<M>;\n  protected maxSelector?: SelectSelector<M>;\n  protected minSelector?: SelectSelector<M>;\n  protected countSelector?: SelectSelector<M>;\n  protected fromSelector!: Constructor<M>;\n  protected whereCondition?: Condition<M>;\n  protected orderBySelector?: OrderBySelector<M>;\n  protected groupBySelector?: GroupBySelector<M>;\n  protected limitSelector?: number;\n  protected offsetSelector?: number;\n\n  protected constructor(protected adapter: Adapter<any, any, Q, any, any>) {\n    super();\n  }\n\n  protected override get log(): Logger {\n    return (this.adapter as any).log.for(Statement);\n  }\n\n  select<\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    S extends readonly SelectSelector<M>[],\n  >(): SelectOption<M, M[]>;\n  select<S extends readonly SelectSelector<M>[]>(\n    selector: readonly [...S]\n  ): SelectOption<M, Pick<M, S[number]>[]>;\n\n  @final()\n  select<S extends readonly SelectSelector<M>[]>(\n    selector?: readonly [...S]\n  ): SelectOption<M, M[]> | SelectOption<M, Pick<M, S[number]>[]> {\n    Object.defineProperty(this, \"selectSelector\", {\n      value: selector,\n      writable: false,\n    });\n    return this as SelectOption<M, M[]> | SelectOption<M, Pick<M, S[number]>[]>;\n  }\n\n  @final()\n  distinct<S extends SelectSelector<M>>(\n    selector: S\n  ): DistinctOption<M, M[S][]> {\n    this.distinctSelector = selector;\n    return this as DistinctOption<M, M[S][]>;\n  }\n\n  @final()\n  max<S extends SelectSelector<M>>(selector: S): MaxOption<M, M[S]> {\n    this.maxSelector = selector;\n    return this as MaxOption<M, M[S]>;\n  }\n\n  @final()\n  min<S extends SelectSelector<M>>(selector: S): MinOption<M, M[S]> {\n    this.minSelector = selector;\n    return this as MinOption<M, M[S]>;\n  }\n\n  @final()\n  count<S extends SelectSelector<M>>(selector?: S): CountOption<M, number> {\n    this.countSelector = selector;\n    return this as CountOption<M, number>;\n  }\n\n  @final()\n  public from(selector: FromSelector<M>): WhereOption<M, R> {\n    this.fromSelector = (\n      typeof selector === \"string\" ? Model.get(selector) : selector\n    ) as Constructor<M>;\n    if (!this.fromSelector)\n      throw new QueryError(`Could not find selector model: ${selector}`);\n    return this;\n  }\n\n  @final()\n  public where(condition: Condition<M>): OrderAndGroupOption<M, R> {\n    this.whereCondition = condition;\n    return this;\n  }\n\n  @final()\n  public orderBy(\n    selector: OrderBySelector<M>\n  ): LimitOption<M, R> & OffsetOption<R> {\n    this.orderBySelector = selector;\n    return this;\n  }\n\n  @final()\n  public groupBy(selector: GroupBySelector<M>): LimitOption<M, R> {\n    this.groupBySelector = selector;\n    return this;\n  }\n\n  @final()\n  public limit(value: number): OffsetOption<R> {\n    this.limitSelector = value;\n    return this;\n  }\n\n  @final()\n  public offset(value: number): Executor<R> {\n    this.offsetSelector = value;\n    return this;\n  }\n\n  @final()\n  async execute(): Promise<R> {\n    try {\n      const query: Q = this.build();\n      return (await this.raw(query)) as R;\n    } catch (e: unknown) {\n      throw new InternalError(e as Error);\n    }\n  }\n\n  async raw<R>(rawInput: Q): Promise<R> {\n    const results = await this.adapter.raw<R>(rawInput);\n    if (!this.selectSelector) return results;\n    const pkAttr = findPrimaryKey(\n      new (this.fromSelector as Constructor<M>)()\n    ).id;\n\n    const processor = function recordProcessor(\n      this: Statement<Q, M, R>,\n      r: any\n    ) {\n      const id = r[pkAttr];\n      return this.adapter.revert(\n        r,\n        this.fromSelector as Constructor<any>,\n        pkAttr,\n        id\n      ) as any;\n    }.bind(this as any);\n\n    if (Array.isArray(results)) return results.map(processor) as R;\n    return processor(results) as R;\n  }\n\n  protected abstract build(): Q;\n  protected abstract parseCondition(condition: Condition<M>, ...args: any[]): Q;\n  abstract paginate(size: number): Promise<Paginator<M, R, Q>>;\n}\n","import { Condition } from \"./Condition\";\nimport { OrderBySelector } from \"./selectors\";\n\n/**\n * @description\n * Options for configuring query building behavior.\n *\n * @summary\n * The `QueryOptions` type defines flags that determine whether certain clauses\n * (limit, offset, order by) are permitted, as well as whether violations\n * should throw an error during query construction.\n *\n * @memberOf module:query\n */\nexport type QueryOptions = {\n  allowLimit?: boolean;\n  allowOffset?: boolean;\n  allowOrderBy?: boolean;\n  throws?: boolean;\n};\n\n/**\n * @description\n * Structured query object representing parsed query clauses.\n *\n * @summary\n * The `QueryAssist` interface defines the standard structure returned\n * by query builders. It includes actions such as find, optional clauses\n * like select, groupBy, and orderBy, and pagination controls (limit, offset).\n *\n * @template T The entity or record type that conditions may apply to.\n *\n * @interface QueryAssist\n * @memberOf module:query\n */\nexport interface QueryAssist {\n  action: \"find\";\n  select: undefined | string[];\n  where: Condition<any>;\n  groupBy?: string[];\n  orderBy?: OrderBySelector<any>[];\n  limit: number | undefined;\n  offset: number | undefined;\n}\n\n/**\n * @description\n * Enumeration of supported query clauses for building method-based queries.\n *\n * @summary\n * The `QueryClause` enum defines string literals that represent\n * different segments of a query (e.g., `findBy`, `Select`, `And`, `Or`).\n *\n * @enum QueryClause\n * @memberOf module:query\n */\nexport enum QueryClause {\n  FIND_BY = \"findBy\",\n  SELECT = \"Select\",\n  AND = \"And\",\n  OR = \"Or\",\n  GROUP_BY = \"GroupBy\",\n  ORDER_BY = \"OrderBy\",\n  THEN = \"Then\",\n  THEN_BY = \"ThenBy\",\n}\n\n/**\n * @description\n * Function signature for parsing operators in query building.\n *\n * @summary\n * The `OperatorParser` type represents a function that takes a field name\n * and arguments, then produces a `Condition` object that can be used in a query.\n *\n * @template T The type of the condition result.\n *\n * @param field {string} - The name of the field being parsed.\n * @param args {any[]} - Additional arguments for operator evaluation.\n *\n * @return {Condition<any>} A condition object representing the parsed operator.\n *\n * @memberOf module:query\n */\nexport type OperatorParser = (field: string, ...args: any) => Condition<any>;\n\n/**\n * @description\n * Descriptor for fields and their associated operators in query parsing.\n *\n * @summary\n * The `FilterDescriptor` interface defines the structure used when parsing\n * method segments into filterable fields and associated operators.\n *\n * @interface FilterDescriptor\n * @memberOf module:query\n */\nexport interface FilterDescriptor {\n  field: string;\n  operator?: string;\n}\n","import { Condition } from \"./Condition\";\nimport { OperatorParser } from \"./types\";\n\n/**\n * @description\n * Map of supported operators to their corresponding parser functions.\n *\n * @summary\n * The `OperatorsMap` defines a collection of operator names as keys\n * (such as `Equals`, `LessThan`, `Between`, etc.), each mapped to a\n * function that constructs a `Condition` object for that operator.\n * These functions translate query clauses into concrete condition\n * builders, enabling dynamic query construction from method names.\n *\n * @template T The type of the field values used in conditions.\n *\n * @param f {string} - The field name the condition applies to.\n * @param v1 {any} - The value to compare the field against or the lower bound value for range-based operators.\n * @param v2 {any} - The upper bound value for range-based operators.\n *\n * @return {Condition<any>} A condition object representing the operator applied to the field.\n *\n * @function OperatorsMap\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client as Caller\n *   participant Map as OperatorsMap\n *   participant Parser as OperatorParser\n *   participant Cond as Condition\n *\n *   Client->>Map: Request operator parser (\"Between\", field, v1, v2)\n *   Map->>Parser: Call corresponding operator function\n *   Parser->>Cond: Condition.attribute(field)\n *   Cond-->>Parser: Condition instance\n *   Parser->>Cond: Apply gte(v1)\n *   Parser->>Cond: Apply and(lte(v2))\n *   Parser-->>Client: Return built Condition\n *\n * @memberOf module:query\n */\nexport const OperatorsMap: Record<string, OperatorParser> = {\n  Equals: (f, v) => Condition.attribute(f as any).eq(v),\n  Diff: (f, v) => Condition.attribute(f as any).dif(v),\n  LessThan: (f, v) => Condition.attribute(f as any).lt(v),\n  LessThanEqual: (f, v) => Condition.attribute(f as any).lte(v),\n  GreaterThan: (f, v) => Condition.attribute(f as any).gt(v),\n  GreaterThanEqual: (f, v) => Condition.attribute(f as any).gte(v),\n  Between: (f, v1, v2) =>\n    Condition.attribute(f as any)\n      .gte(v1)\n      .and(Condition.attribute(f as any).lte(v2)),\n  In: (f, v) => Condition.attribute(f as any).in(v),\n  Matches: (f, v) => Condition.attribute(f as any).regexp(v),\n};\n","import { Condition, OrderBySelector } from \"../query\";\nimport { FilterDescriptor, QueryAssist, QueryClause } from \"./types\";\nimport { OperatorsMap } from \"./utils\";\n\nconst lowerFirst = (str: string): string =>\n  str.charAt(0).toLowerCase() + str.slice(1);\n\nexport type OrderLimitOffsetExtract = {\n  orderBy?: OrderBySelector<any>[];\n  limit?: number;\n  offset?: number;\n};\n\n/**\n * @description\n * Utility class to build query objects from repository method names.\n *\n * @summary\n * The `MethodQueryBuilder` class parses method names that follow a specific naming convention\n * (e.g., `findByNameAndAgeOrderByCountryAsc`) and converts them into structured query objects\n * (`QueryAssist`). It extracts clauses such as `select`, `where`, `groupBy`, `orderBy`, `limit`,\n * and `offset`, ensuring that developers can declare repository queries using expressive method names.\n *\n * @param methodName {string} - The repository method name to parse and convert into a query.\n * @param values {any[]} - The values corresponding to method parameters used for query conditions.\n *\n * @return {QueryAssist} A structured query object describing the parsed action, select, where,\n * groupBy, orderBy, limit, and offset clauses.\n *\n * @class\n *\n * @example\n * ```ts\n * const query = MethodQueryBuilder.build(\n *   \"findByNameAndAgeOrderByCountryAsc\",\n *   \"John\",\n *   25,\n *   [[\"country\", \"ASC\"]]\n * );\n *\n * console.log(query);\n * // {\n * //   action: \"find\",\n * //   select: undefined,\n * //   where: { ... },\n * //   groupBy: undefined,\n * //   orderBy: [[\"country\", \"ASC\"]],\n * //   limit: undefined,\n * //   offset: undefined\n * // }\n * ```\n *\n * @mermaid\n * sequenceDiagram\n *   participant Repo as Repository Method\n *   participant MQB as MethodQueryBuilder\n *   participant Query as QueryAssist\n *\n *   Repo->>MQB: build(methodName, ...values)\n *   MQB->>MQB: extractCore(methodName)\n *   MQB->>MQB: extractSelect(methodName)\n *   MQB->>MQB: extractGroupBy(methodName)\n *   MQB->>MQB: buildWhere(core, values)\n *   MQB->>MQB: extractOrderLimitOffset(core, values)\n *   MQB->>Query: return structured QueryAssist object\n */\nexport class MethodQueryBuilder {\n  /**\n   * @description\n   * Builds a `QueryAssist` object by parsing a repository method name and values.\n   *\n   * @summary\n   * The method validates the method name, extracts clauses (core, select, groupBy, where,\n   * orderBy, limit, and offset), and assembles them into a structured query object\n   * that can be executed against a data source.\n   *\n   * @param methodName {string} - The repository method name that encodes query information.\n   * @param values {any[]} - The values corresponding to conditions and extra clauses.\n   *\n   * @return {QueryAssist} A structured query object representing the parsed query.\n   */\n  static build(methodName: string, ...values: any[]): QueryAssist {\n    if (!methodName.startsWith(QueryClause.FIND_BY)) {\n      throw new Error(`Unsupported method ${methodName}`);\n    }\n\n    const core = this.extractCore(methodName);\n    const select = this.extractSelect(methodName);\n    const groupBy = this.extractGroupBy(methodName);\n    // const orderBy = this.extractOrderBy(methodName);\n    const where = this.buildWhere(core, values);\n    const { orderBy, limit, offset } = this.extractOrderLimitOffset(\n      core,\n      values\n    );\n\n    return {\n      action: \"find\",\n      select: select,\n      where,\n      groupBy,\n      orderBy,\n      limit,\n      offset,\n    };\n  }\n\n  /**\n   * @description\n   * Extracts the core part of the method name after `findBy` and before any special clauses.\n   *\n   * @summary\n   * Removes prefixes and detects delimiters (`Then`, `OrderBy`, `GroupBy`, `Limit`, `Offset`)\n   * to isolate the main conditional part of the query.\n   *\n   * @param methodName {string} - The method name to parse.\n   *\n   * @return {string} The extracted core string used for building conditions.\n   */\n  private static extractCore(methodName: string): string {\n    const afterFindBy = methodName.substring(QueryClause.FIND_BY.length);\n    const regex = /(Then[A-Z]|OrderBy|GroupBy|Limit|Offset)/;\n    const match = afterFindBy.match(regex);\n    return match ? afterFindBy.substring(0, match.index) : afterFindBy;\n  }\n\n  /**\n   * @description\n   * Extracts the select clause from a method name.\n   *\n   * @summary\n   * Detects the `Select` keyword in the method name, isolates the fields following it,\n   * and returns them as an array of lowercase-first strings.\n   *\n   * @param methodName {string} - The method name to parse.\n   *\n   * @return {string[] | undefined} An array of selected fields or `undefined` if no select clause exists.\n   */\n  private static extractSelect(methodName: string): string[] | undefined {\n    const selectIndex = methodName.indexOf(QueryClause.SELECT);\n    if (selectIndex === -1) return undefined;\n\n    const afterSelect = methodName.substring(\n      selectIndex + QueryClause.SELECT.length\n    );\n\n    // Search for next Then, GroupBy, OrderBy...\n    const match = afterSelect.match(/(Then[A-Z]|OrderBy|GroupBy|Limit|Offset)/);\n\n    const selectPart = match\n      ? afterSelect.substring(0, match.index)\n      : afterSelect;\n\n    return selectPart.split(QueryClause.AND).map(lowerFirst).filter(Boolean);\n  }\n\n  /**\n   * @description\n   * Extracts the group by clause from a method name.\n   *\n   * @summary\n   * Detects the `GroupBy` keyword in the method name, isolates the fields following it,\n   * and returns them as an array of lowercase-first strings.\n   *\n   * @param methodName {string} - The method name to parse.\n   *\n   * @return {string[] | undefined} An array of group by fields or `undefined` if no group by clause exists.\n   */\n  private static extractGroupBy(methodName: string): string[] | undefined {\n    const groupByIndex = methodName.indexOf(QueryClause.GROUP_BY);\n    if (groupByIndex === -1) return undefined;\n\n    const after = methodName.substring(\n      groupByIndex + QueryClause.GROUP_BY.length\n    );\n    const groupByPart = after.split(QueryClause.ORDER_BY)[0];\n    return groupByPart\n      .split(QueryClause.THEN_BY)\n      .map(lowerFirst)\n      .filter(Boolean);\n  }\n\n  // private static extractOrderBy(\n  //   methodName: string\n  // ): OrderBySelector<any>[] | undefined {\n  //   const orderByIndex = methodName.indexOf(QueryClause.ORDER_BY);\n  //   if (orderByIndex === -1) return undefined;\n  //\n  //   const after = methodName.substring(\n  //     orderByIndex + QueryClause.ORDER_BY.length\n  //   );\n  //   const orderParts = after.split(\"ThenBy\");\n  //\n  //   return orderParts.map((part) => {\n  //     const match = part.match(/(.*?)(Asc|Desc|Dsc)$/);\n  //     if (!match) throw new Error(`Invalid OrderBy part: ${part}`);\n  //     const [, field, dir] = match;\n  //     return [\n  //       lowerFirst(field),\n  //       dir.toLowerCase() === \"dsc\"\n  //         ? OrderDirection.DSC\n  //         : (dir.toLowerCase() as OrderDirection),\n  //     ];\n  //   });\n  // }\n\n  /**\n   * @description\n   * Builds the `where` condition object based on the parsed core string and parameter values.\n   *\n   * @summary\n   * Splits the core string by logical operators (`And`, `Or`), parses each token into a field\n   * and operator, and combines them into a `Condition` object using the provided values.\n   *\n   * @param core {string} - The extracted core string from the method name.\n   * @param values {any[]} - The values corresponding to the conditions.\n   *\n   * @return {Condition<any>} A structured condition object representing the query's where clause.\n   */\n  private static buildWhere(core: string, values: any[]): Condition<any> {\n    const parts = core.split(/OrderBy|GroupBy/)[0] || \"\";\n    const conditions = parts.split(/And|Or/);\n\n    const operators = core.match(/And|Or/g) || [];\n\n    let where: Condition<any> | undefined;\n\n    conditions.forEach((token, idx) => {\n      const { field, operator } = this.parseFieldAndOperator(token);\n      const parser = operator ? OperatorsMap[operator] : OperatorsMap.Equals;\n      if (!parser) throw new Error(`Unsupported operator ${operator}`);\n\n      const conditionValue = values[idx];\n      if (typeof conditionValue === \"undefined\") {\n        throw new Error(`Invalid value for field ${field}`);\n      }\n\n      const condition = parser(field, conditionValue);\n      where =\n        idx === 0\n          ? condition\n          : operators[idx - 1] === QueryClause.AND\n            ? where!.and(condition)\n            : where!.or(condition);\n    });\n\n    if (!where) throw new Error(\"No conditions found in method name\");\n    return where;\n  }\n\n  /**\n   * @description\n   * Parses a field name and operator from a string token.\n   *\n   * @summary\n   * Identifies the operator suffix (if present) and returns a descriptor containing the field\n   * name in lowercase-first format along with the operator.\n   *\n   * @param str {string} - The token string to parse.\n   *\n   * @return {FilterDescriptor} An object containing the field name and operator.\n   */\n  private static parseFieldAndOperator(str: string): FilterDescriptor {\n    for (const operator of Object.keys(OperatorsMap)) {\n      if (str.endsWith(operator)) {\n        const field = str.slice(0, -operator.length);\n        return { field: lowerFirst(field), operator };\n      }\n    }\n    return { field: lowerFirst(str) };\n  }\n\n  /**\n   * @description\n   * Extracts `orderBy`, `limit`, and `offset` clauses from method arguments.\n   *\n   * @summary\n   * Determines the number of condition arguments, then checks the remaining arguments\n   * to resolve sorting, limiting, and pagination.\n   *\n   * @param core {string} - The extracted core string from the method name.\n   * @param values {any[]} - The values corresponding to method arguments, including conditions and extras.\n   *\n   * @return {OrderLimitOffsetExtract} An object containing orderBy, limit, and offset values if present.\n   */\n  private static extractOrderLimitOffset(\n    core: string,\n    values: any[]\n  ): OrderLimitOffsetExtract {\n    const conditionCount = core.split(/And|Or/).length;\n    const extraArgs = values.slice(conditionCount);\n\n    let orderBy: OrderBySelector<any>[] | undefined;\n    let limit: number | undefined;\n    let offset: number | undefined;\n\n    if (extraArgs.length >= 1 && Array.isArray(extraArgs[0]))\n      orderBy = extraArgs[0] as OrderBySelector<any>[];\n\n    if (extraArgs.length >= 2 && typeof extraArgs[1] === \"number\")\n      limit = extraArgs[1];\n\n    if (extraArgs.length >= 3 && typeof extraArgs[2] === \"number\")\n      offset = extraArgs[2];\n\n    return { orderBy, limit, offset };\n  }\n}\n","import { QueryOptions } from \"./types\";\nimport { MethodQueryBuilder } from \"./MethodQueryBuilder\";\nimport { QueryError } from \"./errors\";\n\nexport function query(options: QueryOptions = {}) {\n  return (\n    target: object,\n    propertyKey?: any,\n    descriptor?: TypedPropertyDescriptor<any>\n  ): any => {\n    // const originalMethod = descriptor.value;\n    const methodName = propertyKey.toString();\n    (descriptor as TypedPropertyDescriptor<any>).value = function (\n      ...args: any[]\n    ) {\n      const { select, where, groupBy, orderBy, limit, offset } =\n        MethodQueryBuilder.build(methodName, ...args);\n\n      let stmt = (this as any).select(select) as any;\n      if (where) stmt = stmt.where(where);\n      // if (orderBy) stmt = stmt.orderBy(orderBy[0]);\n      if (groupBy) {\n        // group by not implemented yet\n        /* stmt = stmt.groupBy(groupBy); */\n      }\n\n      // allow limit and offset by default\n      const { allowLimit, allowOffset, allowOrderBy, throws } = {\n        allowLimit: true,\n        allowOrderBy: true,\n        allowOffset: true,\n        throws: true,\n        ...options,\n      } as QueryOptions;\n\n      const params = [\n        // keep the order to ensure the expected behavior\n        { key: \"orderBy\", value: (orderBy || [])[0], allowed: allowOrderBy }, // orderBy only supports one sentence\n        { key: \"limit\", value: limit, allowed: allowLimit },\n        { key: \"offset\", value: offset, allowed: allowOffset },\n      ];\n\n      for (const param of params) {\n        if (param.value !== undefined) {\n          if (!param.allowed && throws) {\n            throw new QueryError(\n              `${param.key[0].toUpperCase() + param.key.slice(1)} is not allowed for this query`\n            );\n          } else if (param.allowed) {\n            stmt = stmt[param.key](param.value);\n          }\n        }\n      }\n\n      return stmt.execute();\n    };\n  };\n}\n","import { RawRamQuery } from \"./types\";\nimport { Paginator } from \"../query\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { Adapter } from \"../persistence\";\n\n/**\n * @description RAM-specific paginator implementation\n * @summary Extends the base Paginator class to provide pagination functionality for RAM adapter queries.\n * This class handles the pagination of query results from the in-memory storage, allowing\n * for efficient retrieval of large result sets in smaller chunks.\n * @template M - The model type being paginated\n * @template R - The result type returned by the paginator\n * @class RamPaginator\n * @category Ram\n * @example\n * ```typescript\n * // Create a query for User model\n * const query: RawRamQuery<User> = {\n *   select: undefined, // Select all fields\n *   from: User,\n *   where: (user) => user.active === true\n * };\n *\n * // Create a paginator with page size of 10\n * const paginator = new RamPaginator<User, User>(adapter, query, 10, User);\n *\n * // Get the first page of results\n * const firstPage = await paginator.page(1);\n *\n * // Get the next page\n * const secondPage = await paginator.page(2);\n * ```\n */\nexport class RamPaginator<M extends Model, R> extends Paginator<\n  M,\n  R,\n  RawRamQuery<M>\n> {\n  constructor(\n    adapter: Adapter<any, RawRamQuery<M>, any, any>,\n    query: RawRamQuery<M>,\n    size: number,\n    clazz: Constructor<M>\n  ) {\n    super(adapter, query, size, clazz);\n  }\n\n  /**\n   * @description Prepares a RAM query for pagination\n   * @summary Modifies the raw query statement to include pagination parameters.\n   * This protected method sets the limit parameter on the query to match the page size.\n   * @param {RawRamQuery<M>} rawStatement - The original query statement\n   * @return {RawRamQuery<M>} The modified query with pagination parameters\n   */\n  protected prepare(rawStatement: RawRamQuery<M>): RawRamQuery<M> {\n    const query: RawRamQuery<any> = Object.assign({}, rawStatement);\n    query.limit = this.size;\n    return query;\n  }\n\n  /**\n   * @description Retrieves a specific page of results\n   * @summary Executes the query with pagination parameters to retrieve a specific page of results.\n   * This method calculates the appropriate skip value based on the page number and page size,\n   * executes the query, and updates the current page tracking.\n   * @param {number} [page=1] - The page number to retrieve (1-based)\n   * @return {Promise<R[]>} A promise that resolves to an array of results for the requested page\n   */\n  async page(page: number = 1): Promise<R[]> {\n    const statement = this.prepare(this.statement);\n    if (!this._recordCount || !this._totalPages) {\n        this._totalPages = this._recordCount = 0;\n        const results: R[] = await this.adapter.raw({ ...statement, limit: undefined }) || [];\n        this._recordCount = results.length;\n        if (this._recordCount > 0) {\n            const size = statement?.limit || this.size;\n            this._totalPages = Math.ceil(this._recordCount / size);\n        }\n    }\n\n    page = this.validatePage(page);\n    statement.skip = (page - 1) * this.size;\n    const results: any[] = await this.adapter.raw(statement);\n    this._currentPage = page;\n    return results;\n  }\n}\n","import {\n  Condition,\n  GroupOperator,\n  Operator,\n  Paginator,\n  QueryError,\n} from \"../query\";\nimport { RawRamQuery } from \"./types\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { RamPaginator } from \"./RamPaginator\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport { Statement } from \"../query/Statement\";\nimport { Reflection } from \"@decaf-ts/reflection\";\nimport { RamAdapter } from \"./RamAdapter\";\n\n/**\n * @description RAM-specific query statement builder\n * @summary Extends the base Statement class to provide query building functionality for the RAM adapter.\n * This class translates high-level query operations into predicates that can filter and sort\n * in-memory data structures.\n * @template M - The model type being queried\n * @template R - The result type returned by the query\n * @param {RamAdapter} adapter - The RAM adapter instance to use for executing queries\n * @class RamStatement\n * @category Ram\n * @example\n * ```typescript\n * // Create a statement for querying User models\n * const statement = new RamStatement<User, User>(ramAdapter);\n *\n * // Build a query to find active users with age > 18\n * const results = await statement\n *   .from(User)\n *   .where(Condition.and(\n *     Condition.eq('active', true),\n *     Condition.gt('age', 18)\n *   ))\n *   .orderBy('lastName', 'asc')\n *   .limit(10)\n *   .execute();\n * ```\n */\nexport class RamStatement<M extends Model, R> extends Statement<\n  RawRamQuery<M>,\n  M,\n  R\n> {\n  constructor(adapter: RamAdapter) {\n    super(adapter as any);\n  }\n\n  /**\n   * @description Creates a sort comparator function\n   * @summary Generates a function that compares two model instances based on the orderBy criteria.\n   * This method handles different data types (string, number, date) and sort directions (asc, desc).\n   * @return {function(Model, Model): number} A comparator function for sorting model instances\n   */\n  private getSort() {\n    return (el1: Model, el2: Model) => {\n      if (!this.orderBySelector)\n        throw new InternalError(\n          \"orderBySelector not set. Should be impossible\"\n        );\n      const selector = this.orderBySelector;\n      const [key, direction] = selector;\n      const type = Reflection.getTypeFromDecorator(el1, key as string);\n      if (!type)\n        throw new QueryError(`type not compatible with sorting: ${type}`);\n\n      switch (type) {\n        case \"string\":\n        case \"String\":\n          return (\n            (direction === \"asc\" ? 1 : -1) *\n            (el1[key as keyof Model] as unknown as string).localeCompare(\n              el2[key as keyof Model] as unknown as string\n            )\n          );\n        case \"number\":\n        case \"Number\":\n          return (\n            (direction === \"asc\" ? 1 : -1) *\n            ((el1[key as keyof Model] as unknown as number) -\n              (el2[key as keyof Model] as unknown as number))\n          );\n        case \"object\":\n        case \"Object\":\n          if (\n            el1[key as keyof Model] instanceof Date &&\n            el2[key as keyof Model] instanceof Date\n          )\n            return (\n              (direction === \"asc\" ? 1 : -1) *\n              ((el1[key as keyof Model] as unknown as Date).valueOf() -\n                (el2[key as keyof Model] as unknown as Date).valueOf())\n            );\n          throw new QueryError(`Sorting not supported for not date classes`);\n        default:\n          throw new QueryError(`sorting not supported for type ${type}`);\n      }\n    };\n  }\n\n  /**\n   * @description Builds a RAM query from the statement\n   * @summary Converts the statement's selectors and conditions into a RawRamQuery object\n   * that can be executed by the RAM adapter. This method assembles all query components\n   * (select, from, where, limit, offset, sort) into the final query structure.\n   * @return {RawRamQuery<M>} The constructed RAM query object\n   */\n  protected build(): RawRamQuery<M> {\n    const result: RawRamQuery<M> = {\n      select: this.selectSelector,\n      from: this.fromSelector,\n      where: this.whereCondition\n        ? this.parseCondition(this.whereCondition).where\n        : // eslint-disable-next-line @typescript-eslint/no-unused-vars\n          (el: M) => {\n            return true;\n          },\n      limit: this.limitSelector,\n      skip: this.offsetSelector,\n    };\n    if (this.orderBySelector) result.sort = this.getSort();\n    return result;\n  }\n\n  /**\n   * @description Creates a paginator for the query\n   * @summary Builds the query and wraps it in a RamPaginator to enable pagination of results.\n   * This allows retrieving large result sets in smaller chunks.\n   * @param {number} size - The page size (number of results per page)\n   * @return {Promise<Paginator<M, R, RawRamQuery<M>>>} A promise that resolves to a paginator for the query\n   */\n  async paginate(size: number): Promise<Paginator<M, R, RawRamQuery<M>>> {\n    try {\n      const query = this.build();\n      return new RamPaginator<M, R>(\n        this.adapter,\n        query,\n        size,\n        this.fromSelector\n      );\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n\n  /**\n   * @description Parses a condition into a RAM query predicate\n   * @summary Converts a Condition object into a predicate function that can be used\n   * to filter model instances in memory. This method handles both simple conditions\n   * (equals, greater than, etc.) and complex conditions with logical operators (AND, OR).\n   * @template M - The model type for the condition\n   * @param {Condition<M>} condition - The condition to parse\n   * @return {RawRamQuery<M>} A RAM query object with a where predicate function\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamStatement\n   *   participant SimpleCondition\n   *   participant ComplexCondition\n   *\n   *   Caller->>RamStatement: parseCondition(condition)\n   *   alt Simple condition (eq, gt, lt, etc.)\n   *     RamStatement->>SimpleCondition: Extract attr1, operator, comparison\n   *     SimpleCondition-->>RamStatement: Return predicate function\n   *   else Logical operator (AND, OR)\n   *     RamStatement->>ComplexCondition: Extract nested conditions\n   *     RamStatement->>RamStatement: parseCondition(leftCondition)\n   *     RamStatement->>RamStatement: parseCondition(rightCondition)\n   *     ComplexCondition-->>RamStatement: Combine predicates with logical operator\n   *   end\n   *   RamStatement-->>Caller: Return query with where predicate\n   */\n  parseCondition<M extends Model>(condition: Condition<M>): RawRamQuery<M> {\n    return {\n      where: (m: Model) => {\n        const { attr1, operator, comparison } = condition as unknown as {\n          attr1: string | Condition<M>;\n          operator: Operator | GroupOperator;\n          comparison: any;\n        };\n\n        if (\n          [GroupOperator.AND, GroupOperator.OR, Operator.NOT].indexOf(\n            operator as GroupOperator\n          ) === -1\n        ) {\n          switch (operator) {\n            case Operator.BIGGER:\n              return m[attr1 as keyof Model] > comparison;\n            case Operator.BIGGER_EQ:\n              return m[attr1 as keyof Model] >= comparison;\n            case Operator.DIFFERENT:\n              return m[attr1 as keyof Model] !== comparison;\n            case Operator.EQUAL:\n              return m[attr1 as keyof Model] === comparison;\n            case Operator.REGEXP:\n              if (typeof m[attr1 as keyof Model] !== \"string\")\n                throw new QueryError(\n                  `Invalid regexp comparison on a non string attribute: ${m[attr1 as keyof Model]}`\n                );\n              return !!(m[attr1 as keyof Model] as unknown as string).match(\n                new RegExp(comparison, \"g\")\n              );\n            case Operator.SMALLER:\n              return m[attr1 as keyof Model] < comparison;\n            case Operator.SMALLER_EQ:\n              return m[attr1 as keyof Model] <= comparison;\n            default:\n              throw new InternalError(\n                `Invalid operator for standard comparisons: ${operator}`\n              );\n          }\n        } else if (operator === Operator.NOT) {\n          throw new InternalError(\"Not implemented\");\n        } else {\n          const op1: RawRamQuery<any> = this.parseCondition(\n            attr1 as Condition<M>\n          );\n          const op2: RawRamQuery<any> = this.parseCondition(\n            comparison as Condition<M>\n          );\n          switch (operator) {\n            case GroupOperator.AND:\n              return op1.where(m) && op2.where(m);\n            case GroupOperator.OR:\n              return op1.where(m) || op2.where(m);\n            default:\n              throw new InternalError(\n                `Invalid operator for And/Or comparisons: ${operator}`\n              );\n          }\n        }\n      },\n    } as RawRamQuery<any>;\n  }\n}\n","import { Context } from \"@decaf-ts/db-decorators\";\nimport { RamFlags } from \"./types\";\n\n/**\n * @description Context class for RAM adapter operations\n * @summary Provides a specialized context for RAM adapter operations, extending the base Context with RAM-specific flags. This context is used to pass operation parameters and user information.\n * @class RamContext\n * @category Ram\n * @example\n * ```typescript\n * // Create a new RAM context\n * const context = new RamContext();\n * // Optionally set a flag\n * context.set('UUID', '123e4567-e89b-12d3-a456-426614174000');\n * // Access a flag from the context\n * const uuid = context.get('UUID');\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant RamContext\n *   participant BaseContext as Context\n *   Caller->>RamContext: new RamContext()\n *   RamContext->>BaseContext: super()\n *   RamContext-->>Caller: instance\n */\nexport class RamContext extends Context<RamFlags> {\n  constructor() {\n    super();\n  }\n}\n","import { model, required } from \"@decaf-ts/decorator-validation\";\nimport type { ModelArg } from \"@decaf-ts/decorator-validation\";\nimport { BaseModel, index, table } from \"../../model\";\nimport { pk } from \"../../identity\";\n\n/**\n * @description RAM sequence model for auto-incrementing values\n * @summary A model class that represents a sequence in the RAM adapter. It stores the current value\n * of a sequence that can be used for generating sequential identifiers for entities.\n * The sequence is identified by its ID and maintains the current value.\n * @param {ModelArg<Sequence>} seq - Initial sequence data\n * @class Sequence\n * @category Ram\n * @example\n * ```typescript\n * // Create a new sequence\n * const orderSequence = new Sequence({ id: 'order_seq', current: 1 });\n *\n * // Use the sequence to get the next value\n * const nextOrderId = parseInt(orderSequence.current.toString()) + 1;\n * orderSequence.current = nextOrderId;\n * ```\n */\n@table(\"__RamSequence\")\n@model()\nexport class RamSequenceModel extends BaseModel {\n  /**\n   * @description Primary key identifier for the sequence\n   */\n  @pk()\n  id!: string;\n\n  /**\n   * @description Current value of the sequence\n   * Used to generate the next sequential value\n   */\n  @required()\n  @index()\n  current!: string | number;\n\n  constructor(seq?: ModelArg<RamSequenceModel>) {\n    super(seq);\n  }\n}\n","import { RamSequenceModel } from \"./model/RamSequenceModel\";\nimport { InternalError, NotFoundError } from \"@decaf-ts/db-decorators\";\nimport { Sequence } from \"../persistence\";\nimport { SequenceOptions } from \"../interfaces\";\nimport { RamAdapter } from \"./RamAdapter\";\nimport { Repo, Repository } from \"../repository\";\n\n/**\n * @description RAM-specific sequence implementation\n * @summary Extends the base Sequence class to provide auto-incrementing sequence functionality\n * for the RAM adapter. This class manages sequences stored in memory, allowing for the generation\n * of sequential identifiers for entities.\n * @param {SequenceOptions} options - Configuration options for the sequence\n * @param {RamAdapter} adapter - The RAM adapter instance to use for storage\n * @class RamSequence\n * @category Ram\n * @example\n * ```typescript\n * // Create a new numeric sequence starting at 1\n * const sequence = new RamSequence({\n *   name: 'order_sequence',\n *   type: 'Number',\n *   startWith: 1,\n *   incrementBy: 1\n * }, ramAdapter);\n *\n * // Get the next value in the sequence\n * const nextId = await sequence.next();\n *\n * // Get a range of values\n * const idRange = await sequence.range(5); // Returns 5 sequential values\n * ```\n */\nexport class RamSequence extends Sequence {\n  protected repo: Repo<RamSequenceModel>;\n\n  constructor(options: SequenceOptions, adapter: RamAdapter) {\n    super(options);\n    this.repo = Repository.forModel(RamSequenceModel, adapter.alias);\n  }\n\n  /**\n   * @description Retrieves the current value of the sequence\n   * @summary Gets the current value of the sequence from storage. If the sequence\n   * doesn't exist yet, it returns the configured starting value.\n   * @return A promise that resolves to the current sequence value\n   */\n  async current(): Promise<string | number | bigint> {\n    const { name, startWith } = this.options;\n    try {\n      const sequence: RamSequenceModel = await this.repo.read(name as string);\n      return this.parse(sequence.current as string | number);\n    } catch (e: any) {\n      if (e instanceof NotFoundError) {\n        if (typeof startWith === \"undefined\")\n          throw new InternalError(\n            \"Starting value is not defined for a non existing sequence\"\n          );\n        try {\n          return this.parse(startWith);\n        } catch (e: any) {\n          throw new InternalError(\n            `Failed to parse initial value for sequence ${startWith}: ${e}`\n          );\n        }\n      }\n      throw new InternalError(\n        `Failed to retrieve current value for sequence ${name}: ${e}`\n      );\n    }\n  }\n\n  /**\n   * @description Parses a value according to the sequence type\n   * @summary Converts a value to the appropriate type for the sequence (string, number, or bigint)\n   * using the base Sequence class's parseValue method.\n   * @param {string | number | bigint} value - The value to parse\n   * @return {string | number | bigint} The parsed value in the correct type\n   */\n  private parse(value: string | number | bigint): string | number | bigint {\n    return Sequence.parseValue(this.options.type, value);\n  }\n\n  /**\n   * @description Increments the sequence value\n   * @summary Increases the current sequence value by the specified amount and persists\n   * the new value to storage. This method handles both numeric and BigInt sequence types.\n   * @param {string | number | bigint} current - The current value of the sequence\n   * @param {number} [count] - Optional amount to increment by, defaults to the sequence's incrementBy value\n   * @return A promise that resolves to the new sequence value after incrementing\n   */\n  private async increment(\n    current: string | number | bigint,\n    count?: number\n  ): Promise<string | number | bigint> {\n    const { type, incrementBy, name } = this.options;\n    let next: string | number | bigint;\n    const toIncrementBy = count || incrementBy;\n    if (toIncrementBy % incrementBy !== 0)\n      throw new InternalError(\n        `Value to increment does not consider the incrementBy setting: ${incrementBy}`\n      );\n    switch (type) {\n      case \"Number\":\n        next = (this.parse(current) as number) + toIncrementBy;\n        break;\n      case \"BigInt\":\n        next = (this.parse(current) as bigint) + BigInt(toIncrementBy);\n        break;\n      case \"String\":\n        next = this.parse(current);\n        break;\n      default:\n        throw new InternalError(\"Should never happen\");\n    }\n    let seq: RamSequenceModel;\n    const repo = this.repo.override({\n      ignoredValidationProperties: [\"updatedOn\"],\n    });\n    try {\n      seq = await repo.update(new RamSequenceModel({ id: name, current: next }));\n    } catch (e: any) {\n      if (!(e instanceof NotFoundError)) {\n        throw e;\n      }\n      seq = await repo.create(new RamSequenceModel({ id: name, current: next }));\n    }\n\n    return seq.current as string | number | bigint;\n  }\n\n  /**\n   * @description Gets the next value in the sequence\n   * @summary Retrieves the current value of the sequence and increments it by the\n   * configured increment amount. This is the main method used to get a new sequential value.\n   * @return A promise that resolves to the next value in the sequence\n   */\n  async next(): Promise<number | string | bigint> {\n    const current = await this.current();\n    return this.increment(current);\n  }\n\n  /**\n   * @description Generates a range of sequential values\n   * @summary Retrieves a specified number of sequential values from the sequence.\n   * This is useful when you need to allocate multiple IDs at once.\n   * The method increments the sequence by the total amount needed and returns all values in the range.\n   * @param {number} count - The number of sequential values to generate\n   * @return A promise that resolves to an array of sequential values\n   */\n  async range(count: number): Promise<(number | string | bigint)[]> {\n    const current = (await this.current()) as number;\n    const incrementBy = this.parse(\n      this.options.incrementBy as number\n    ) as number;\n    const next: string | number | bigint = await this.increment(\n      current,\n      (this.parse(count) as number) * incrementBy\n    );\n    const range: (number | string | bigint)[] = [];\n    for (let i: number = 1; i <= count; i++) {\n      range.push(current + incrementBy * (this.parse(i) as number));\n    }\n    if (range[range.length - 1] !== next && this.options.type !== \"String\")\n      throw new InternalError(\"Miscalculation of range\");\n    return range;\n  }\n}\n","import { Model } from \"@decaf-ts/decorator-validation\";\nimport { Repo } from \"../repository\";\nimport { RelationsMetadata } from \"../model\";\nimport { RamFlags } from \"./types\";\nimport { Context } from \"@decaf-ts/db-decorators\";\nimport { UnsupportedError } from \"../persistence\";\n\n/**\n * @description Sets the created by field on a model during RAM create/update operations\n * @summary Automatically populates a model field with the UUID from the context during create or update operations.\n * This function is designed to be used as a handler for RAM operations to track entity creation.\n * @template M - Type of the model being created/updated\n * @template R - Type of the repository handling the model\n * @template V - Type of the relations metadata\n * @template F - Type of the RAM flags\n * @template C - Type of the context\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The operation context containing user identification\n * @param {V} data - The relations metadata\n * @param key - The property key to set with the UUID\n * @param {M} model - The model instance being created/updated\n * @return {Promise<void>} A promise that resolves when the field has been set\n * @function createdByOnRamCreateUpdate\n * @memberOf module:core\n * @category Ram\n */\nexport async function createdByOnRamCreateUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\n  F extends RamFlags,\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  const uuid: string = context.get(\"UUID\");\n  if (!uuid)\n    throw new UnsupportedError(\n      \"This adapter does not support user identification\"\n    );\n  model[key] = uuid as M[keyof M];\n}\n","/**\n * @description Identifier for the RAM adapter\n * @summary A constant string that uniquely identifies the RAM adapter in the system. Used for adapter type identification and configuration across the core module.\n * @const RamFlavour\n * @memberOf module:core\n * @category Ram\n */\nexport const RamFlavour = \"ram\";\n","import {\n  RamFlags,\n  RawRamQuery,\n  RamStorage,\n  RamRepository,\n  RamConfig,\n} from \"./types\";\nimport { RamStatement } from \"./RamStatement\";\nimport { RamContext } from \"./RamContext\";\nimport { Repository } from \"../repository/Repository\";\nimport { Adapter, PersistenceKeys, Sequence } from \"../persistence\";\nimport { SequenceOptions } from \"../interfaces\";\nimport { Lock } from \"@decaf-ts/transactional-decorators\";\nimport {\n  Constructor,\n  Decoration,\n  hashObj,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport {\n  BaseError,\n  ConflictError,\n  findPrimaryKey,\n  InternalError,\n  NotFoundError,\n  onCreate,\n  onCreateUpdate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { RamSequence } from \"./RamSequence\";\nimport { createdByOnRamCreateUpdate } from \"./handlers\";\nimport { RamFlavour } from \"./constants\";\n/**\n * @description In-memory adapter for data persistence\n * @summary The RamAdapter provides an in-memory implementation of the persistence layer.\n * It stores data in JavaScript Maps and provides CRUD operations and query capabilities.\n * This adapter is useful for testing, prototyping, and applications that don't require\n * persistent storage across application restarts.\n * @class RamAdapter\n * @category Ram\n * @example\n * ```typescript\n * // Create a new RAM adapter\n * const adapter = new RamAdapter('myRamAdapter');\n *\n * // Create a repository for a model\n * const userRepo = new (adapter.repository<User>())(User, adapter);\n *\n * // Perform CRUD operations\n * const user = new User({ name: 'John', email: 'john@example.com' });\n * await userRepo.create(user);\n * const retrievedUser = await userRepo.findById(user.id);\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Repository\n *   participant RamAdapter\n *   participant Storage as In-Memory Storage\n *\n *   Client->>Repository: create(model)\n *   Repository->>RamAdapter: create(tableName, id, model)\n *   RamAdapter->>RamAdapter: lock.acquire()\n *   RamAdapter->>Storage: set(id, model)\n *   RamAdapter->>RamAdapter: lock.release()\n *   RamAdapter-->>Repository: model\n *   Repository-->>Client: model\n *\n *   Client->>Repository: findById(id)\n *   Repository->>RamAdapter: read(tableName, id)\n *   RamAdapter->>Storage: get(id)\n *   Storage-->>RamAdapter: model\n *   RamAdapter-->>Repository: model\n *   Repository-->>Client: model\n */\nexport class RamAdapter extends Adapter<\n  RamConfig,\n  RamStorage,\n  RawRamQuery<any>,\n  RamFlags,\n  RamContext\n> {\n  constructor(conf: RamConfig = {} as any, alias?: string) {\n    super(conf, RamFlavour, alias);\n  }\n\n  /**\n   * @description Gets the repository constructor for a model\n   * @summary Returns a constructor for creating repositories that work with the specified model type.\n   * This method overrides the base implementation to provide RAM-specific repository functionality.\n   * @template M - The model type for the repository\n   * @return {Constructor<RamRepository<M>>} A constructor for creating RAM repositories\n   */\n  override repository<M extends Model<boolean>>(): Constructor<\n    RamRepository<M>\n  > {\n    return super.repository<M>() as Constructor<RamRepository<M>>;\n  }\n\n  /**\n   * @description Creates operation flags with UUID\n   * @summary Extends the base flags with a UUID for user identification.\n   * This method ensures that all operations have a unique identifier for tracking purposes.\n   * @template M - The model type for the operation\n   * @param {OperationKeys} operation - The type of operation being performed\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<RamFlags>} flags - Partial flags to be extended\n   * @return {Promise<RamFlags>} Complete flags with UUID\n   */\n  override async flags<M extends Model<boolean>>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<RamFlags>\n  ): Promise<RamFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      UUID: this.config.user || \"\" + Date.now(),\n    }) as RamFlags;\n  }\n\n  override Context = RamContext;\n\n  private indexes: Record<\n    string,\n    Record<string | number, Record<string, any>>\n  > = {};\n\n  private lock = new Lock();\n\n  /**\n   * @description Indexes models in the RAM adapter\n   * @summary A no-op indexing method for the RAM adapter.\n   * Since RAM adapter doesn't require explicit indexing, this method simply resolves immediately.\n   * @param models - Models to be indexed (unused)\n   * @return {Promise<any>} A promise that resolves when indexing is complete\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async index(...models: Record<string, any>[]): Promise<any> {\n    return Promise.resolve(undefined);\n  }\n\n  /**\n   * @description Prepares a model for storage\n   * @summary Converts a model instance to a format suitable for storage in the RAM adapter.\n   * This method extracts the primary key and creates a record without the primary key field.\n   * @template M - The model type being prepared\n   * @param {M} model - The model instance to prepare\n   * @param pk - The primary key property name\n   * @return Object containing the record and ID\n   */\n  override prepare<M extends Model>(\n    model: M,\n    pk: keyof M\n  ): { record: Record<string, any>; id: string } {\n    const prepared = super.prepare(model, pk);\n    delete prepared.record[pk as string];\n    return prepared;\n  }\n\n  /**\n   * @description Converts a stored record back to a model instance\n   * @summary Reconstructs a model instance from a stored record by adding back the primary key.\n   * This method is the inverse of the prepare method.\n   * @template M - The model type to revert to\n   * @param {Record<string, any>} obj - The stored record\n   * @param {string | Constructor<M>} clazz - The model class or name\n   * @param pk - The primary key property name\n   * @param {string | number} id - The primary key value\n   * @return {M} The reconstructed model instance\n   */\n  override revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: string | Constructor<M>,\n    pk: keyof M,\n    id: string | number\n  ): M {\n    const res = super.revert(obj, clazz, pk, id);\n    return res;\n  }\n\n  /**\n   * @description Creates a new record in the in-memory storage\n   * @summary Stores a new record in the specified table with the given ID.\n   * This method acquires a lock to ensure thread safety, creates the table if it doesn't exist,\n   * checks for conflicts, and stores the model.\n   * @param {string} tableName - The name of the table to store the record in\n   * @param {string | number} id - The unique identifier for the record\n   * @param {Record<string, any>} model - The record data to store\n   * @return {Promise<Record<string, any>>} A promise that resolves to the stored record\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: create(tableName, id, model)\n   *   RamAdapter->>RamAdapter: lock.acquire()\n   *   RamAdapter->>Storage: has(tableName)\n   *   alt Table doesn't exist\n   *     RamAdapter->>Storage: set(tableName, new Map())\n   *   end\n   *   RamAdapter->>Storage: has(id)\n   *   alt Record exists\n   *     RamAdapter-->>Caller: throw ConflictError\n   *   end\n   *   RamAdapter->>Storage: set(id, model)\n   *   RamAdapter->>RamAdapter: lock.release()\n   *   RamAdapter-->>Caller: model\n   */\n  async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    await this.lock.acquire();\n    if (!this.client.has(tableName)) this.client.set(tableName, new Map());\n    if (this.client.get(tableName) && this.client.get(tableName)?.has(id))\n      throw new ConflictError(\n        `Record with id ${id} already exists in table ${tableName}`\n      );\n    this.client.get(tableName)?.set(id, model);\n    this.lock.release();\n    return model;\n  }\n\n  /**\n   * @description Retrieves a record from in-memory storage\n   * @summary Fetches a record with the specified ID from the given table.\n   * This method checks if the table and record exist and throws appropriate errors if not.\n   * @param {string} tableName - The name of the table to retrieve from\n   * @param {string | number} id - The unique identifier of the record to retrieve\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved record\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: read(tableName, id)\n   *   RamAdapter->>Storage: has(tableName)\n   *   alt Table doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: has(id)\n   *   alt Record doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: get(id)\n   *   Storage-->>RamAdapter: record\n   *   RamAdapter-->>Caller: record\n   */\n  async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    if (!this.client.has(tableName))\n      throw new NotFoundError(`Table ${tableName} not found`);\n    if (!this.client.get(tableName)?.has(id))\n      throw new NotFoundError(\n        `Record with id ${id} not found in table ${tableName}`\n      );\n    return this.client.get(tableName)?.get(id);\n  }\n\n  /**\n   * @description Updates an existing record in the in-memory storage\n   * @summary Updates a record with the specified ID in the given table.\n   * This method acquires a lock to ensure thread safety, checks if the table and record exist,\n   * and updates the record with the new data.\n   * @param {string} tableName - The name of the table containing the record\n   * @param {string | number} id - The unique identifier of the record to update\n   * @param {Record<string, any>} model - The new record data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated record\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: update(tableName, id, model)\n   *   RamAdapter->>RamAdapter: lock.acquire()\n   *   RamAdapter->>Storage: has(tableName)\n   *   alt Table doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: has(id)\n   *   alt Record doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: set(id, model)\n   *   RamAdapter->>RamAdapter: lock.release()\n   *   RamAdapter-->>Caller: model\n   */\n  async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    await this.lock.acquire();\n    if (!this.client.has(tableName))\n      throw new NotFoundError(`Table ${tableName} not found`);\n    if (!this.client.get(tableName)?.has(id))\n      throw new NotFoundError(\n        `Record with id ${id} not found in table ${tableName}`\n      );\n    this.client.get(tableName)?.set(id, model);\n    this.lock.release();\n    return model;\n  }\n\n  /**\n   * @description Deletes a record from the in-memory storage\n   * @summary Removes a record with the specified ID from the given table.\n   * This method acquires a lock to ensure thread safety, checks if the table and record exist,\n   * retrieves the record before deletion, and then removes it from storage.\n   * @param {string} tableName - The name of the table containing the record\n   * @param {string | number} id - The unique identifier of the record to delete\n   * @return {Promise<Record<string, any>>} A promise that resolves to the deleted record\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: delete(tableName, id)\n   *   RamAdapter->>RamAdapter: lock.acquire()\n   *   RamAdapter->>Storage: has(tableName)\n   *   alt Table doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: has(id)\n   *   alt Record doesn't exist\n   *     RamAdapter-->>Caller: throw NotFoundError\n   *   end\n   *   RamAdapter->>Storage: get(id)\n   *   Storage-->>RamAdapter: record\n   *   RamAdapter->>Storage: delete(id)\n   *   RamAdapter->>RamAdapter: lock.release()\n   *   RamAdapter-->>Caller: record\n   */\n  async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    await this.lock.acquire();\n    if (!this.client.has(tableName))\n      throw new NotFoundError(`Table ${tableName} not found`);\n    if (!this.client.get(tableName)?.has(id))\n      throw new NotFoundError(\n        `Record with id ${id} not found in table ${tableName}`\n      );\n    const natived = this.client.get(tableName)?.get(id);\n    this.client.get(tableName)?.delete(id);\n    this.lock.release();\n    return natived;\n  }\n\n  /**\n   * @description Gets or creates a table in the in-memory storage\n   * @summary Retrieves the Map representing a table for a given model or table name.\n   * If the table doesn't exist, it creates a new one. This is a helper method used\n   * by other methods to access the correct storage location.\n   * @template M - The model type for the table\n   * @param {string | Constructor<M>} from - The model class or table name\n   * @return {Map<string | number, any> | undefined} The table Map or undefined\n   */\n  protected tableFor<M extends Model>(from: string | Constructor<M>) {\n    if (typeof from === \"string\") from = Model.get(from) as Constructor<M>;\n    const table = Repository.table(from);\n    if (!this.client.has(table)) this.client.set(table, new Map());\n    return this.client.get(table);\n  }\n\n  /**\n   * @description Executes a raw query against the in-memory storage\n   * @summary Performs a query operation on the in-memory data store using the provided query specification.\n   * This method supports filtering, sorting, pagination, and field selection.\n   * @template R - The return type of the query\n   * @param {RawRamQuery<any>} rawInput - The query specification\n   * @return {Promise<R>} A promise that resolves to the query results\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant RamAdapter\n   *   participant Storage as In-Memory Storage\n   *\n   *   Caller->>RamAdapter: raw(rawInput)\n   *   RamAdapter->>RamAdapter: tableFor(from)\n   *   alt Table doesn't exist\n   *     RamAdapter-->>Caller: throw InternalError\n   *   end\n   *   RamAdapter->>RamAdapter: findPrimaryKey(new from())\n   *   RamAdapter->>Storage: entries()\n   *   Storage-->>RamAdapter: entries\n   *   loop For each entry\n   *     RamAdapter->>RamAdapter: revert(r, from, id, pk)\n   *   end\n   *   alt Where condition exists\n   *     RamAdapter->>RamAdapter: result.filter(where)\n   *   end\n   *   alt Sort condition exists\n   *     RamAdapter->>RamAdapter: result.sort(sort)\n   *   end\n   *   alt Skip specified\n   *     RamAdapter->>RamAdapter: result.slice(skip)\n   *   end\n   *   alt Limit specified\n   *     RamAdapter->>RamAdapter: result.slice(0, limit)\n   *   end\n   *   alt Select fields specified\n   *     loop For each result\n   *       RamAdapter->>RamAdapter: Filter to selected fields\n   *     end\n   *   end\n   *   RamAdapter-->>Caller: result\n   */\n  async raw<R>(rawInput: RawRamQuery<any>): Promise<R> {\n    const { where, sort, limit, skip, from } = rawInput;\n    let { select } = rawInput;\n    const collection = this.tableFor(from);\n    if (!collection)\n      throw new InternalError(`Table ${from} not found in RamAdapter`);\n    const { id, props } = findPrimaryKey(new from());\n\n    let result: any[] = Array.from(collection.entries()).map(([pk, r]) =>\n      this.revert(\n        r,\n        from,\n        id as any,\n        Sequence.parseValue(props.type as any, pk as string) as string\n      )\n    );\n\n    result = where ? result.filter(where) : result;\n\n    if (sort) result = result.sort(sort);\n\n    if (skip) result = result.slice(skip);\n    if (limit) result = result.slice(0, limit);\n\n    if (select) {\n      select = Array.isArray(select) ? select : [select];\n      result = result.map((r) =>\n        Object.entries(r).reduce((acc: Record<string, any>, [key, val]) => {\n          if ((select as string[]).includes(key)) acc[key] = val;\n          return acc;\n        }, {})\n      );\n    }\n\n    return result as unknown as R;\n  }\n\n  /**\n   * @description Parses and converts errors to appropriate types\n   * @summary Ensures that errors are of the correct type for consistent error handling.\n   * If the error is already a BaseError, it's returned as is; otherwise, it's wrapped in an InternalError.\n   * @template V - The expected error type, extending BaseError\n   * @param {Error} err - The error to parse\n   * @return {V} The parsed error of the expected type\n   */\n  parseError<V extends BaseError>(err: Error): V {\n    if (err instanceof BaseError) return err as V;\n    return new InternalError(err) as V;\n  }\n\n  /**\n   * @description Creates a new statement builder for queries\n   * @summary Factory method that creates a new RamStatement instance for building queries.\n   * This method allows for fluent query construction against the RAM adapter.\n   * @template M - The model type for the statement\n   * @return {RamStatement<M, any>} A new statement builder instance\n   */\n  Statement<M extends Model<boolean>>(): RamStatement<M, any> {\n    return new RamStatement<M, any>(this as any);\n  }\n\n  /**\n   * @description Creates a new sequence for generating sequential IDs\n   * @summary Factory method that creates a new RamSequence instance for ID generation.\n   * This method provides a way to create auto-incrementing sequences for entity IDs.\n   * @param {SequenceOptions} options - Configuration options for the sequence\n   * @return {Promise<Sequence>} A promise that resolves to the new sequence instance\n   */\n  async Sequence(options: SequenceOptions): Promise<Sequence> {\n    return new RamSequence(options, this);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  override for(config: Partial<RamConfig>, ...args: any[]): typeof this {\n    if (!this.proxies) this.proxies = {};\n    const key = `${this.alias} - ${hashObj(config)}`;\n    if (key in this.proxies) return this.proxies[key] as typeof this;\n\n    const proxy = new Proxy(this, {\n      get: (target: typeof this, p: string | symbol, receiver: any) => {\n        if (p === \"_config\") {\n          const originalConf: RamConfig = Reflect.get(target, p, receiver);\n          return Object.assign({}, originalConf, config);\n        }\n        return Reflect.get(target, p, receiver);\n      },\n    });\n    this.proxies[key] = proxy;\n    return proxy;\n  }\n\n  /**\n   * @description Sets up RAM-specific decorations for model properties\n   * @summary Configures decorations for createdBy and updatedBy fields in the RAM adapter.\n   * This static method is called during initialization to set up handlers that automatically\n   * populate these fields with the current user's UUID during create and update operations.\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant RamAdapter\n   *   participant Decoration\n   *   participant Repository\n   *\n   *   RamAdapter->>Repository: key(PersistenceKeys.CREATED_BY)\n   *   Repository-->>RamAdapter: createdByKey\n   *   RamAdapter->>Repository: key(PersistenceKeys.UPDATED_BY)\n   *   Repository-->>RamAdapter: updatedByKey\n   *\n   *   RamAdapter->>Decoration: flavouredAs(RamFlavour)\n   *   Decoration-->>RamAdapter: DecoratorBuilder\n   *   RamAdapter->>Decoration: for(createdByKey)\n   *   RamAdapter->>Decoration: define(onCreate, propMetadata)\n   *   RamAdapter->>Decoration: apply()\n   *\n   *   RamAdapter->>Decoration: flavouredAs(RamFlavour)\n   *   Decoration-->>RamAdapter: DecoratorBuilder\n   *   RamAdapter->>Decoration: for(updatedByKey)\n   *   RamAdapter->>Decoration: define(onCreate, propMetadata)\n   *   RamAdapter->>Decoration: apply()\n   */\n  static override decoration(): void {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(RamFlavour)\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnRamCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n    Decoration.flavouredAs(RamFlavour)\n      .for(updatedByKey)\n      .define(\n        onCreateUpdate(createdByOnRamCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n\n  protected override getClient(): RamStorage {\n    return new Map();\n  }\n}\n","/**\n * @module core\n * @description Core module for the Decaf TypeScript framework\n * @summary This module provides the foundational components of the Decaf framework, including identity management,\n * model definitions, repository patterns, persistence layer, query building, and utility functions.\n * It exports functionality from various submodules and sets up the injectable registry for repository decorators.\n */\n\nimport { InjectablesRegistry } from \"./repository/injectables\";\nimport { Injectables } from \"@decaf-ts/injectable-decorators\";\n\n// overrides the previous Injectables registry to enable the @repository decorator\nInjectables.setRegistry(new InjectablesRegistry());\n\n// imported first on purpose\nexport * from \"./overrides\";\nexport * from \"./repository\";\n\nexport * from \"./identity\";\nexport * from \"./interfaces\";\nexport * from \"./model\";\nexport * from \"./query\";\nexport * from \"./utils\";\nexport * from \"./ram/RamAdapter\";\n//left to last on purpose\nexport * from \"./persistence\";\n\n/**\n * @description Stores the current package version\n * @summary A constant representing the version of the core package\n * @const VERSION\n * @memberOf module:core\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":["Repository","Repo","Rep","populate","pop","newApply","newMetadata"],"mappings":"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"}
|