@decaf-ts/for-nano 0.1.7 → 0.1.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/for-nano.cjs +3 -3
- package/dist/for-nano.esm.cjs +4 -4
- package/lib/adapter.cjs +2 -2
- package/lib/esm/adapter.js +3 -3
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.js +1 -1
- package/lib/index.cjs +1 -1
- package/lib/index.d.ts +1 -1
- package/package.json +1 -1
package/dist/for-nano.cjs
CHANGED
|
@@ -828,7 +828,7 @@
|
|
|
828
828
|
.apply();
|
|
829
829
|
decoratorValidation.Decoration.flavouredAs("nano")
|
|
830
830
|
.for(updatedByKey)
|
|
831
|
-
.define(dbDecorators.
|
|
831
|
+
.define(dbDecorators.onCreateUpdate(createdByOnNanoCreateUpdate), decoratorValidation.propMetadata(updatedByKey, {}))
|
|
832
832
|
.apply();
|
|
833
833
|
}
|
|
834
834
|
}
|
|
@@ -847,7 +847,7 @@
|
|
|
847
847
|
* @const VERSION
|
|
848
848
|
* @memberOf module:for-nano
|
|
849
849
|
*/
|
|
850
|
-
const VERSION = "0.1.
|
|
850
|
+
const VERSION = "0.1.8";
|
|
851
851
|
|
|
852
852
|
exports.NanoAdapter = NanoAdapter;
|
|
853
853
|
exports.NanoFlavour = NanoFlavour;
|
|
@@ -855,4 +855,4 @@
|
|
|
855
855
|
exports.createdByOnNanoCreateUpdate = createdByOnNanoCreateUpdate;
|
|
856
856
|
|
|
857
857
|
}));
|
|
858
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-nano.cjs","sources":["../src/constants.ts","../src/NanoDispatch.ts","../src/adapter.ts","../src/index.ts"],"sourcesContent":["/**\n * @description Identifier for the Nano database flavor\n * @summary Constant string that identifies the database type as \"nano\" for use in adapter selection and configuration\n * @const NanoFlavour\n * @memberOf module:for-nano\n */\nexport const NanoFlavour = \"nano\";\n","import { Dispatch } from \"@decaf-ts/core\";\nimport {\n  DatabaseChangesResponse,\n  DatabaseChangesResultItem,\n  DocumentScope,\n  RequestError,\n} from \"nano\";\nimport { InternalError, OperationKeys } from \"@decaf-ts/db-decorators\";\nimport { CouchDBKeys } from \"@decaf-ts/for-couchdb\";\n\n/**\n * @description Dispatcher for Nano database change events\n * @summary Handles the subscription to and processing of database change events from a Nano database,\n * notifying observers when documents are created, updated, or deleted\n * @template DocumentScope - The Nano document scope type\n * @param {number} [timeout=5000] - Timeout in milliseconds for change feed requests\n * @class NanoDispatch\n * @example\n * ```typescript\n * // Create a dispatcher for a Nano database\n * const db = server.db.use('my_database');\n * const adapter = new NanoAdapter(db);\n * const dispatch = new NanoDispatch();\n *\n * // The dispatcher will automatically subscribe to changes\n * // and notify observers when documents change\n * ```\n * @mermaid\n * classDiagram\n *   class Dispatch {\n *     +initialize()\n *     +updateObservers()\n *   }\n *   class NanoDispatch {\n *     -observerLastUpdate?: string\n *     -attemptCounter: number\n *     -timeout: number\n *     +constructor(timeout)\n *     #changeHandler()\n *     #initialize()\n *   }\n *   Dispatch <|-- NanoDispatch\n */\nexport class NanoDispatch extends Dispatch<DocumentScope<any>> {\n  private observerLastUpdate?: string;\n  private attemptCounter: number = 0;\n  constructor(private timeout = 5000) {\n    super();\n  }\n\n  /**\n   * @description Processes database change events\n   * @summary Handles the response from the Nano changes feed, processes the changes,\n   * and notifies observers about document changes\n   * @param {RequestError | null} error - Error object if the request failed\n   * @param response - The changes response from Nano\n   * @param {any} [headers] - Response headers (unused)\n   * @return {Promise<void>} A promise that resolves when all changes have been processed\n   * @mermaid\n   * sequenceDiagram\n   *   participant D as NanoDispatch\n   *   participant L as Logger\n   *   participant O as Observers\n   *   Note over D: Receive changes from Nano\n   *   alt Error in response\n   *     D->>L: Log error\n   *     D-->>D: Return early\n   *   end\n   *   alt Response is string\n   *     D->>D: Parse JSON from string\n   *   end\n   *   D->>D: Process changes\n   *   D->>D: Group changes by table and operation\n   *   loop For each table\n   *     loop For each operation\n   *       D->>O: updateObservers(table, operation, ids)\n   *       D->>D: Update observerLastUpdate\n   *       D->>L: Log successful dispatch\n   *     end\n   *   end\n   */\n  protected async changeHandler(\n    error: RequestError | null,\n    response: (DatabaseChangesResponse | DatabaseChangesResultItem)[] | string,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    headers?: any\n  ) {\n    const log = this.log.for(this.changeHandler);\n    if (error) return log.error(`Error in change request: ${error}`);\n    try {\n      response = (\n        typeof response === \"string\"\n          ? response\n              .split(\"\\n\")\n              .filter((r) => !!r)\n              .map((r) => JSON.parse(r))\n          : response\n      ) as DatabaseChangesResponse[];\n    } catch (e: unknown) {\n      return log.error(`Error parsing couchdb change feed: ${e}`);\n    }\n    const count = response.length;\n    if (count > 0) {\n      log.debug(`Received ${count} changes. processing...`);\n      const changes = response\n        .map((rec, i) => {\n          if (i === count - 1) {\n            if (\n              this.observerLastUpdate ===\n              (rec as DatabaseChangesResponse).last_seq\n            )\n              log.error(\n                `Invalid last update check: ${this.observerLastUpdate} !== ${(rec as DatabaseChangesResponse).last_seq}`\n              );\n            return;\n          }\n          const r = rec as DatabaseChangesResultItem;\n          const [table, id] = r.id.split(CouchDBKeys.SEPARATOR);\n          return {\n            table: table,\n            id: id,\n            operation: r.deleted\n              ? OperationKeys.DELETE\n              : r.changes[r.changes.length - 1].rev.split(\"-\")[0] === \"1\"\n                ? OperationKeys.CREATE\n                : OperationKeys.UPDATE,\n            step: r.changes[r.changes.length - 1].rev,\n          };\n        })\n        .reduce(\n          (\n            accum: Record<\n              string,\n              Record<\n                string,\n                {\n                  ids: Set<any>;\n                  step: string;\n                }\n              >\n            >,\n            r\n          ) => {\n            if (!r) return accum;\n            const { table, id, operation, step } = r as {\n              table: string;\n              id: string;\n              operation: OperationKeys;\n              step: string;\n            };\n            if (!accum[table]) accum[table] = {};\n            if (!accum[table][operation])\n              accum[table][operation] = { ids: new Set(), step: step };\n            accum[table][operation].ids.add(id);\n            accum[table][operation].step = step;\n            return accum;\n          },\n          {}\n        );\n\n      for (const table of Object.keys(changes)) {\n        for (const op of Object.keys(changes[table])) {\n          try {\n            await this.updateObservers(table, op, [\n              ...changes[table][op].ids.values(),\n            ]);\n            this.observerLastUpdate = changes[table][op].step;\n            log.verbose(`Observer refresh dispatched by ${op} for ${table}`);\n            log.debug(`pks: ${Array.from(changes[table][op].ids.values())}`);\n          } catch (e: unknown) {\n            log.error(\n              `Failed to dispatch observer refresh for ${table}, op ${op}: ${e}`\n            );\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * @description Initializes the dispatcher and subscribes to database changes\n   * @summary Sets up the continuous changes feed subscription to the Nano database\n   * and handles reconnection attempts if the connection fails\n   * @return {Promise<void>} A promise that resolves when the subscription is established\n   * @mermaid\n   * sequenceDiagram\n   *   participant D as NanoDispatch\n   *   participant S as subscribeToCouch\n   *   participant DB as Nano Database\n   *   participant L as Logger\n   *   D->>S: Call subscribeToCouch\n   *   S->>S: Check adapter and native\n   *   alt No adapter or native\n   *     S-->>S: throw InternalError\n   *   end\n   *   S->>DB: changes(options, changeHandler)\n   *   alt Success\n   *     DB-->>S: Subscription established\n   *     S-->>D: Promise resolves\n   *     D->>L: Log successful subscription\n   *   else Error\n   *     DB-->>S: Error\n   *     S->>S: Increment attemptCounter\n   *     alt attemptCounter > 3\n   *       S->>L: Log error\n   *       S-->>D: Promise rejects\n   *     else attemptCounter <= 3\n   *       S->>L: Log retry\n   *       S->>S: Wait timeout\n   *       S->>S: Recursive call to subscribeToCouch\n   *     end\n   *   end\n   */\n  protected override async initialize(): Promise<void> {\n    const log = this.log.for(this.initialize);\n    const subLog = log.for(subscribeToCouch);\n    async function subscribeToCouch(this: NanoDispatch): Promise<void> {\n      if (!this.adapter || !this.native)\n        throw new InternalError(`No adapter/native observed for dispatch`);\n\n      try {\n        this.native.changes(\n          {\n            feed: \"continuous\",\n            include_docs: false,\n            since: this.observerLastUpdate || \"now\",\n            timeout: this.timeout,\n          },\n          this.changeHandler.bind(this) as any\n        );\n      } catch (e: unknown) {\n        if (++this.attemptCounter > 3)\n          return subLog.error(`Failed to subscribe to couchdb changes: ${e}`);\n        subLog.info(\n          `Failed to subscribe to couchdb changes: ${e}. Retrying in 5 seconds...`\n        );\n        await new Promise((resolve) => setTimeout(resolve, this.timeout));\n        return subscribeToCouch.call(this);\n      }\n    }\n\n    subscribeToCouch\n      .call(this)\n      .then(() => {\n        this.log.info(`Subscribed to couchdb changes`);\n      })\n      .catch((e: unknown) => {\n        throw new InternalError(`Failed to subscribe to couchdb changes: ${e}`);\n      });\n  }\n}\n","import {\n  ConflictError,\n  Context,\n  InternalError,\n  onCreate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  CreateIndexRequest,\n  generateIndexes,\n  MangoQuery,\n  MangoResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport Nano from \"nano\";\nimport {\n  DocumentBulkResponse,\n  DocumentGetResponse,\n  DocumentInsertResponse,\n  DocumentScope,\n  MaybeDocument,\n  ServerScope,\n} from \"nano\";\nimport {\n  Constructor,\n  Decoration,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport { NanoFlags } from \"./types\";\nimport {\n  Adapter,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { NanoFlavour } from \"./constants\";\nimport { NanoRepository } from \"./NanoRepository\";\nimport { NanoDispatch } from \"./NanoDispatch\";\n\n/**\n * @description Sets the creator or updater field in a model based on the user in the context\n * @summary Callback function used in decorators to automatically set the created_by or updated_by fields\n * with the username from the context when a document is created or updated\n * @template M - Type extending Model\n * @template R - Type extending NanoRepository<M>\n * @template V - Type extending RelationsMetadata\n * @param {R} this - The repository instance\n * @param {Context<NanoFlags>} context - The operation context containing user information\n * @param {V} data - The relation metadata\n * @param key - The property key to set with the username\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function createdByOnNanoCreateUpdate\n * @memberOf module:for-nano\n * @mermaid\n * sequenceDiagram\n *   participant F as createdByOnNanoCreateUpdate\n *   participant C as Context\n *   participant M as Model\n *   F->>C: get(\"user\")\n *   C-->>F: user object\n *   F->>M: set key to user.name\n *   Note over F: If no user in context\n *   F-->>F: throw UnsupportedError\n */\nexport async function createdByOnNanoCreateUpdate<\n  M extends Model,\n  R extends NanoRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<NanoFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"user\");\n    model[key] = user.name as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new UnsupportedError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Adapter for interacting with Nano databases\n * @summary Provides a standardized interface for performing CRUD operations on Nano databases,\n * extending the CouchDB adapter with Nano-specific functionality. This adapter handles document\n * creation, reading, updating, and deletion, as well as bulk operations and index management.\n * @template DocumentScope - The Nano document scope type\n * @template NanoFlags - Configuration flags for Nano operations\n * @template Context - Context type for operations\n * @param {DocumentScope<any>} scope - The Nano document scope to use for database operations\n * @param {string} [alias] - Optional alias for the adapter\n * @class NanoAdapter\n * @example\n * ```typescript\n * // Connect to a Nano database\n * const server = NanoAdapter.connect('admin', 'password', 'localhost:5984');\n * const db = server.db.use('my_database');\n *\n * // Create an adapter instance\n * const adapter = new NanoAdapter(db);\n *\n * // Use the adapter for database operations\n * const document = await adapter.read('users', '123');\n * ```\n * @mermaid\n * classDiagram\n *   class CouchDBAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +read()\n *     +update()\n *     +delete()\n *   }\n *   class NanoAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +createAll()\n *     +read()\n *     +readAll()\n *     +update()\n *     +updateAll()\n *     +delete()\n *     +deleteAll()\n *     +raw()\n *     +static connect()\n *     +static createDatabase()\n *     +static deleteDatabase()\n *     +static createUser()\n *     +static deleteUser()\n *     +static decoration()\n *   }\n *   CouchDBAdapter <|-- NanoAdapter\n */\nexport class NanoAdapter extends CouchDBAdapter<\n  DocumentScope<any>,\n  NanoFlags,\n  Context<NanoFlags>\n> {\n  constructor(scope: DocumentScope<any>, alias?: string) {\n    super(scope, NanoFlavour, alias);\n  }\n\n  /**\n   * @description Generates flags for database operations\n   * @summary Creates a set of flags for a specific operation, including user information\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation being performed (create, read, update, delete)\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<NanoFlags>} flags - Partial flags to be merged\n   * @return {Promise<NanoFlags>} Complete flags for the operation\n   */\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<NanoFlags>\n  ): Promise<NanoFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      user: {\n        name: this.native.config.url.split(\"@\")[0].split(\":\")[0],\n      },\n    }) as NanoFlags;\n  }\n\n  /**\n   * @description Creates a new NanoDispatch instance\n   * @summary Returns a dispatcher for handling Nano-specific operations\n   * @return {NanoDispatch} A new NanoDispatch instance\n   */\n  protected override Dispatch(): NanoDispatch {\n    return new NanoDispatch();\n  }\n\n  /**\n   * @description Creates database indexes for models\n   * @summary Generates and creates indexes in the Nano database based on the provided models\n   * @template M - Type extending Model\n   * @param models - Model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant G as generateIndexes\n   *   participant DB as Nano Database\n   *   A->>G: generateIndexes(models)\n   *   G-->>A: indexes\n   *   loop For each index\n   *     A->>DB: createIndex(index)\n   *     DB-->>A: response\n   *     Note over A: Check if index already exists\n   *     alt Index exists\n   *       A-->>A: throw ConflictError\n   *     end\n   *   end\n   */\n  protected override async index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  /**\n   * @description Creates a new document in the database\n   * @summary Inserts a new document into the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The document data to insert\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  /**\n   * @description Creates multiple documents in the database\n   * @summary Inserts multiple documents into the Nano database in a single bulk operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of document identifiers\n   * @param models - Array of document data to insert\n   * @return A promise that resolves to an array of created documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: bulk({docs: models})\n   *   alt Success\n   *     DB-->>A: response array\n   *     A->>A: Check if all responses have no errors\n   *     alt All OK\n   *       A->>A: assignMultipleMetadata(models, revs)\n   *       A-->>A: return documents with metadata\n   *     else Some errors\n   *       A->>A: Collect error messages\n   *       A-->>A: throw InternalError with collected messages\n   *     end\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  /**\n   * @description Retrieves a document from the database\n   * @summary Fetches a single document from the Nano database by its ID\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: generateId(tableName, id)\n   *   A->>DB: get(_id)\n   *   alt Success\n   *     DB-->>A: record\n   *     A->>A: assignMetadata(record, record._rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  /**\n   * @description Retrieves multiple documents from the database\n   * @summary Fetches multiple documents from the Nano database by their IDs in a single operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of document identifiers\n   * @return A promise that resolves to an array of retrieved documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: Map ids to generateId(tableName, id)\n   *   A->>DB: fetch({keys: mappedIds}, {})\n   *   DB-->>A: results\n   *   A->>A: Process each result row\n   *   loop For each row\n   *     alt Row has error\n   *       A-->>A: throw InternalError\n   *     else Row has document\n   *       A->>A: assignMetadata(doc, doc._rev)\n   *     else No document\n   *       A-->>A: throw InternalError\n   *     end\n   *   end\n   *   A-->>A: return documents with metadata\n   */\n  override async readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  /**\n   * @description Updates a document in the database\n   * @summary Updates an existing document in the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The updated document data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  override async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    const deletion: DocumentBulkResponse[] = await this.native.bulk({\n      docs: results.rows.map((r) => {\n        (r as any)[CouchDBKeys.DELETED] = true;\n        return r;\n      }),\n    });\n    deletion.forEach((d: DocumentBulkResponse) => {\n      if (d.error) console.error(d.error);\n    });\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  override async raw<R>(rawInput: MangoQuery, docsOnly = true): Promise<R> {\n    try {\n      const response: MangoResponse<R> = await this.native.find(rawInput);\n      if (response.warning) console.warn(response.warning);\n      if (docsOnly) return response.docs as R;\n      return response as R;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  static connect(\n    user: string,\n    pass: string,\n    host = \"localhost:5984\",\n    protocol: \"http\" | \"https\" = \"http\"\n  ): ServerScope {\n    return Nano(`${protocol}://${user}:${pass}@${host}`);\n  }\n\n  /**\n   * @description Creates a new database on the Nano server\n   * @summary Creates a new database with the specified name on the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to create\n   * @return {Promise<void>} A promise that resolves when the database is created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.create(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw parseError(error, reason)\n   *   end\n   */\n  static async createDatabase(con: ServerScope, name: string) {\n    let result: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.parseError(error as string, reason);\n  }\n\n  /**\n   * @description Deletes a database from the Nano server\n   * @summary Removes an existing database with the specified name from the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to delete\n   * @return {Promise<void>} A promise that resolves when the database is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.destroy(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async deleteDatabase(con: ServerScope, name: string) {\n    let result;\n    try {\n      result = await con.db.destroy(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok } = result;\n    if (!ok)\n      throw new InternalError(`Failed to delete database with name ${name}`);\n  }\n\n  /**\n   * @description Creates a new user and grants access to a database\n   * @summary Creates a new user in the Nano server and configures security to grant the user access to a specific database\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database to grant access to\n   * @param {string} user - The username to create\n   * @param {string} pass - The password for the new user\n   * @param {string[]} [roles=[\"reader\", \"writer\"]] - The roles to assign to the user\n   * @return {Promise<void>} A promise that resolves when the user is created and granted access\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   participant S as Security API\n   *   A->>A: Create user object\n   *   A->>U: insert(user)\n   *   alt Success\n   *     U-->>A: response with ok=true\n   *     A->>S: PUT _security with user permissions\n   *     alt Security Success\n   *       S-->>A: security response with ok=true\n   *     else Security Failure\n   *       S-->>A: security response with ok=false\n   *       A-->>A: throw InternalError\n   *     end\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     U-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async createUser(\n    con: ServerScope,\n    dbName: string,\n    user: string,\n    pass: string,\n    roles: string[] = [\"reader\", \"writer\"]\n  ) {\n    const users = con.db.use(\"_users\");\n    const usr = {\n      _id: \"org.couchdb.user:\" + user,\n      name: user,\n      password: pass,\n      roles: roles,\n      type: \"user\",\n    };\n    try {\n      const created: DocumentInsertResponse = await users.insert(\n        usr as MaybeDocument\n      );\n      const { ok } = created;\n      if (!ok) throw new InternalError(`Failed to create user ${user}`);\n      const security: any = await con.request({\n        db: dbName,\n        method: \"put\",\n        path: \"_security\",\n        // headers: {\n        //\n        // },\n        body: {\n          admins: {\n            names: [user],\n            roles: [],\n          },\n          members: {\n            names: [user],\n            roles: roles,\n          },\n        },\n      });\n      if (!security.ok)\n        throw new InternalError(\n          `Failed to authorize user ${user} to db ${dbName}`\n        );\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Deletes a user from the Nano server\n   * @summary Removes an existing user from the Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database (used for logging purposes)\n   * @param {string} user - The username to delete\n   * @return {Promise<void>} A promise that resolves when the user is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   A->>A: Generate user ID\n   *   A->>U: get(id)\n   *   U-->>A: user document\n   *   A->>U: destroy(id, user._rev)\n   *   alt Success\n   *     U-->>A: success response\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = con.db.use(\"_users\");\n    const id = \"org.couchdb.user:\" + user;\n    try {\n      const usr = await users.get(id);\n      await users.destroy(id, usr._rev);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Sets up decorations for Nano-specific model properties\n   * @summary Configures decorators for created_by and updated_by fields in models to be automatically\n   * populated with the user from the context when documents are created or updated\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant D as Decoration\n   *   participant R as Repository\n   *   A->>R: key(PersistenceKeys.CREATED_BY)\n   *   R-->>A: createdByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(createdByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   *   A->>R: key(PersistenceKeys.UPDATED_BY)\n   *   R-->>A: updatedByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(updatedByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   */\n  static override decoration() {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(\"nano\")\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n\n    Decoration.flavouredAs(\"nano\")\n      .for(updatedByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n}\n\nAdapter.setCurrent(NanoFlavour);\n","import { NanoAdapter } from \"./adapter\";\n\n// Forces override for Nano Decoration\nNanoAdapter.decoration();\n\nexport * from \"./constants\";\nexport * from \"./NanoRepository\";\nexport * from \"./types\";\n// Left to the end on purpose\nexport * from \"./adapter\";\n\n/**\n * @description A TypeScript module for interacting with Nano databases\n * @summary This module provides a set of utilities, classes, and types for working with Nano databases. It includes repository patterns, adapters, and type definitions to simplify database operations.\n * @module for-nano\n */\n\n/**\n * @description Package version identifier\n * @summary Stores the current package version string for the for-nano module\n * @const VERSION\n * @memberOf module:for-nano\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":["Dispatch","CouchDBKeys","OperationKeys","InternalError","UnsupportedError","CouchDBAdapter","generateIndexes","ConflictError","Repository","PersistenceKeys","Decoration","onCreate","propMetadata","Adapter"],"mappings":"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"}
|
|
858
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-nano.cjs","sources":["../src/constants.ts","../src/NanoDispatch.ts","../src/adapter.ts","../src/index.ts"],"sourcesContent":["/**\n * @description Identifier for the Nano database flavor\n * @summary Constant string that identifies the database type as \"nano\" for use in adapter selection and configuration\n * @const NanoFlavour\n * @memberOf module:for-nano\n */\nexport const NanoFlavour = \"nano\";\n","import { Dispatch } from \"@decaf-ts/core\";\nimport {\n  DatabaseChangesResponse,\n  DatabaseChangesResultItem,\n  DocumentScope,\n  RequestError,\n} from \"nano\";\nimport { InternalError, OperationKeys } from \"@decaf-ts/db-decorators\";\nimport { CouchDBKeys } from \"@decaf-ts/for-couchdb\";\n\n/**\n * @description Dispatcher for Nano database change events\n * @summary Handles the subscription to and processing of database change events from a Nano database,\n * notifying observers when documents are created, updated, or deleted\n * @template DocumentScope - The Nano document scope type\n * @param {number} [timeout=5000] - Timeout in milliseconds for change feed requests\n * @class NanoDispatch\n * @example\n * ```typescript\n * // Create a dispatcher for a Nano database\n * const db = server.db.use('my_database');\n * const adapter = new NanoAdapter(db);\n * const dispatch = new NanoDispatch();\n *\n * // The dispatcher will automatically subscribe to changes\n * // and notify observers when documents change\n * ```\n * @mermaid\n * classDiagram\n *   class Dispatch {\n *     +initialize()\n *     +updateObservers()\n *   }\n *   class NanoDispatch {\n *     -observerLastUpdate?: string\n *     -attemptCounter: number\n *     -timeout: number\n *     +constructor(timeout)\n *     #changeHandler()\n *     #initialize()\n *   }\n *   Dispatch <|-- NanoDispatch\n */\nexport class NanoDispatch extends Dispatch<DocumentScope<any>> {\n  private observerLastUpdate?: string;\n  private attemptCounter: number = 0;\n  constructor(private timeout = 5000) {\n    super();\n  }\n\n  /**\n   * @description Processes database change events\n   * @summary Handles the response from the Nano changes feed, processes the changes,\n   * and notifies observers about document changes\n   * @param {RequestError | null} error - Error object if the request failed\n   * @param response - The changes response from Nano\n   * @param {any} [headers] - Response headers (unused)\n   * @return {Promise<void>} A promise that resolves when all changes have been processed\n   * @mermaid\n   * sequenceDiagram\n   *   participant D as NanoDispatch\n   *   participant L as Logger\n   *   participant O as Observers\n   *   Note over D: Receive changes from Nano\n   *   alt Error in response\n   *     D->>L: Log error\n   *     D-->>D: Return early\n   *   end\n   *   alt Response is string\n   *     D->>D: Parse JSON from string\n   *   end\n   *   D->>D: Process changes\n   *   D->>D: Group changes by table and operation\n   *   loop For each table\n   *     loop For each operation\n   *       D->>O: updateObservers(table, operation, ids)\n   *       D->>D: Update observerLastUpdate\n   *       D->>L: Log successful dispatch\n   *     end\n   *   end\n   */\n  protected async changeHandler(\n    error: RequestError | null,\n    response: (DatabaseChangesResponse | DatabaseChangesResultItem)[] | string,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    headers?: any\n  ) {\n    const log = this.log.for(this.changeHandler);\n    if (error) return log.error(`Error in change request: ${error}`);\n    try {\n      response = (\n        typeof response === \"string\"\n          ? response\n              .split(\"\\n\")\n              .filter((r) => !!r)\n              .map((r) => JSON.parse(r))\n          : response\n      ) as DatabaseChangesResponse[];\n    } catch (e: unknown) {\n      return log.error(`Error parsing couchdb change feed: ${e}`);\n    }\n    const count = response.length;\n    if (count > 0) {\n      log.debug(`Received ${count} changes. processing...`);\n      const changes = response\n        .map((rec, i) => {\n          if (i === count - 1) {\n            if (\n              this.observerLastUpdate ===\n              (rec as DatabaseChangesResponse).last_seq\n            )\n              log.error(\n                `Invalid last update check: ${this.observerLastUpdate} !== ${(rec as DatabaseChangesResponse).last_seq}`\n              );\n            return;\n          }\n          const r = rec as DatabaseChangesResultItem;\n          const [table, id] = r.id.split(CouchDBKeys.SEPARATOR);\n          return {\n            table: table,\n            id: id,\n            operation: r.deleted\n              ? OperationKeys.DELETE\n              : r.changes[r.changes.length - 1].rev.split(\"-\")[0] === \"1\"\n                ? OperationKeys.CREATE\n                : OperationKeys.UPDATE,\n            step: r.changes[r.changes.length - 1].rev,\n          };\n        })\n        .reduce(\n          (\n            accum: Record<\n              string,\n              Record<\n                string,\n                {\n                  ids: Set<any>;\n                  step: string;\n                }\n              >\n            >,\n            r\n          ) => {\n            if (!r) return accum;\n            const { table, id, operation, step } = r as {\n              table: string;\n              id: string;\n              operation: OperationKeys;\n              step: string;\n            };\n            if (!accum[table]) accum[table] = {};\n            if (!accum[table][operation])\n              accum[table][operation] = { ids: new Set(), step: step };\n            accum[table][operation].ids.add(id);\n            accum[table][operation].step = step;\n            return accum;\n          },\n          {}\n        );\n\n      for (const table of Object.keys(changes)) {\n        for (const op of Object.keys(changes[table])) {\n          try {\n            await this.updateObservers(table, op, [\n              ...changes[table][op].ids.values(),\n            ]);\n            this.observerLastUpdate = changes[table][op].step;\n            log.verbose(`Observer refresh dispatched by ${op} for ${table}`);\n            log.debug(`pks: ${Array.from(changes[table][op].ids.values())}`);\n          } catch (e: unknown) {\n            log.error(\n              `Failed to dispatch observer refresh for ${table}, op ${op}: ${e}`\n            );\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * @description Initializes the dispatcher and subscribes to database changes\n   * @summary Sets up the continuous changes feed subscription to the Nano database\n   * and handles reconnection attempts if the connection fails\n   * @return {Promise<void>} A promise that resolves when the subscription is established\n   * @mermaid\n   * sequenceDiagram\n   *   participant D as NanoDispatch\n   *   participant S as subscribeToCouch\n   *   participant DB as Nano Database\n   *   participant L as Logger\n   *   D->>S: Call subscribeToCouch\n   *   S->>S: Check adapter and native\n   *   alt No adapter or native\n   *     S-->>S: throw InternalError\n   *   end\n   *   S->>DB: changes(options, changeHandler)\n   *   alt Success\n   *     DB-->>S: Subscription established\n   *     S-->>D: Promise resolves\n   *     D->>L: Log successful subscription\n   *   else Error\n   *     DB-->>S: Error\n   *     S->>S: Increment attemptCounter\n   *     alt attemptCounter > 3\n   *       S->>L: Log error\n   *       S-->>D: Promise rejects\n   *     else attemptCounter <= 3\n   *       S->>L: Log retry\n   *       S->>S: Wait timeout\n   *       S->>S: Recursive call to subscribeToCouch\n   *     end\n   *   end\n   */\n  protected override async initialize(): Promise<void> {\n    const log = this.log.for(this.initialize);\n    const subLog = log.for(subscribeToCouch);\n    async function subscribeToCouch(this: NanoDispatch): Promise<void> {\n      if (!this.adapter || !this.native)\n        throw new InternalError(`No adapter/native observed for dispatch`);\n\n      try {\n        this.native.changes(\n          {\n            feed: \"continuous\",\n            include_docs: false,\n            since: this.observerLastUpdate || \"now\",\n            timeout: this.timeout,\n          },\n          this.changeHandler.bind(this) as any\n        );\n      } catch (e: unknown) {\n        if (++this.attemptCounter > 3)\n          return subLog.error(`Failed to subscribe to couchdb changes: ${e}`);\n        subLog.info(\n          `Failed to subscribe to couchdb changes: ${e}. Retrying in 5 seconds...`\n        );\n        await new Promise((resolve) => setTimeout(resolve, this.timeout));\n        return subscribeToCouch.call(this);\n      }\n    }\n\n    subscribeToCouch\n      .call(this)\n      .then(() => {\n        this.log.info(`Subscribed to couchdb changes`);\n      })\n      .catch((e: unknown) => {\n        throw new InternalError(`Failed to subscribe to couchdb changes: ${e}`);\n      });\n  }\n}\n","import {\n  ConflictError,\n  Context,\n  InternalError,\n  onCreate,\n  onCreateUpdate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  CreateIndexRequest,\n  generateIndexes,\n  MangoQuery,\n  MangoResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport Nano from \"nano\";\nimport {\n  DocumentBulkResponse,\n  DocumentGetResponse,\n  DocumentInsertResponse,\n  DocumentScope,\n  MaybeDocument,\n  ServerScope,\n} from \"nano\";\nimport {\n  Constructor,\n  Decoration,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport { NanoFlags } from \"./types\";\nimport {\n  Adapter,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { NanoFlavour } from \"./constants\";\nimport { NanoRepository } from \"./NanoRepository\";\nimport { NanoDispatch } from \"./NanoDispatch\";\n\n/**\n * @description Sets the creator or updater field in a model based on the user in the context\n * @summary Callback function used in decorators to automatically set the created_by or updated_by fields\n * with the username from the context when a document is created or updated\n * @template M - Type extending Model\n * @template R - Type extending NanoRepository<M>\n * @template V - Type extending RelationsMetadata\n * @param {R} this - The repository instance\n * @param {Context<NanoFlags>} context - The operation context containing user information\n * @param {V} data - The relation metadata\n * @param key - The property key to set with the username\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function createdByOnNanoCreateUpdate\n * @memberOf module:for-nano\n * @mermaid\n * sequenceDiagram\n *   participant F as createdByOnNanoCreateUpdate\n *   participant C as Context\n *   participant M as Model\n *   F->>C: get(\"user\")\n *   C-->>F: user object\n *   F->>M: set key to user.name\n *   Note over F: If no user in context\n *   F-->>F: throw UnsupportedError\n */\nexport async function createdByOnNanoCreateUpdate<\n  M extends Model,\n  R extends NanoRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<NanoFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"user\");\n    model[key] = user.name as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new UnsupportedError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Adapter for interacting with Nano databases\n * @summary Provides a standardized interface for performing CRUD operations on Nano databases,\n * extending the CouchDB adapter with Nano-specific functionality. This adapter handles document\n * creation, reading, updating, and deletion, as well as bulk operations and index management.\n * @template DocumentScope - The Nano document scope type\n * @template NanoFlags - Configuration flags for Nano operations\n * @template Context - Context type for operations\n * @param {DocumentScope<any>} scope - The Nano document scope to use for database operations\n * @param {string} [alias] - Optional alias for the adapter\n * @class NanoAdapter\n * @example\n * ```typescript\n * // Connect to a Nano database\n * const server = NanoAdapter.connect('admin', 'password', 'localhost:5984');\n * const db = server.db.use('my_database');\n *\n * // Create an adapter instance\n * const adapter = new NanoAdapter(db);\n *\n * // Use the adapter for database operations\n * const document = await adapter.read('users', '123');\n * ```\n * @mermaid\n * classDiagram\n *   class CouchDBAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +read()\n *     +update()\n *     +delete()\n *   }\n *   class NanoAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +createAll()\n *     +read()\n *     +readAll()\n *     +update()\n *     +updateAll()\n *     +delete()\n *     +deleteAll()\n *     +raw()\n *     +static connect()\n *     +static createDatabase()\n *     +static deleteDatabase()\n *     +static createUser()\n *     +static deleteUser()\n *     +static decoration()\n *   }\n *   CouchDBAdapter <|-- NanoAdapter\n */\nexport class NanoAdapter extends CouchDBAdapter<\n  DocumentScope<any>,\n  NanoFlags,\n  Context<NanoFlags>\n> {\n  constructor(scope: DocumentScope<any>, alias?: string) {\n    super(scope, NanoFlavour, alias);\n  }\n\n  /**\n   * @description Generates flags for database operations\n   * @summary Creates a set of flags for a specific operation, including user information\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation being performed (create, read, update, delete)\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<NanoFlags>} flags - Partial flags to be merged\n   * @return {Promise<NanoFlags>} Complete flags for the operation\n   */\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<NanoFlags>\n  ): Promise<NanoFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      user: {\n        name: this.native.config.url.split(\"@\")[0].split(\":\")[0],\n      },\n    }) as NanoFlags;\n  }\n\n  /**\n   * @description Creates a new NanoDispatch instance\n   * @summary Returns a dispatcher for handling Nano-specific operations\n   * @return {NanoDispatch} A new NanoDispatch instance\n   */\n  protected override Dispatch(): NanoDispatch {\n    return new NanoDispatch();\n  }\n\n  /**\n   * @description Creates database indexes for models\n   * @summary Generates and creates indexes in the Nano database based on the provided models\n   * @template M - Type extending Model\n   * @param models - Model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant G as generateIndexes\n   *   participant DB as Nano Database\n   *   A->>G: generateIndexes(models)\n   *   G-->>A: indexes\n   *   loop For each index\n   *     A->>DB: createIndex(index)\n   *     DB-->>A: response\n   *     Note over A: Check if index already exists\n   *     alt Index exists\n   *       A-->>A: throw ConflictError\n   *     end\n   *   end\n   */\n  protected override async index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  /**\n   * @description Creates a new document in the database\n   * @summary Inserts a new document into the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The document data to insert\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  /**\n   * @description Creates multiple documents in the database\n   * @summary Inserts multiple documents into the Nano database in a single bulk operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of document identifiers\n   * @param models - Array of document data to insert\n   * @return A promise that resolves to an array of created documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: bulk({docs: models})\n   *   alt Success\n   *     DB-->>A: response array\n   *     A->>A: Check if all responses have no errors\n   *     alt All OK\n   *       A->>A: assignMultipleMetadata(models, revs)\n   *       A-->>A: return documents with metadata\n   *     else Some errors\n   *       A->>A: Collect error messages\n   *       A-->>A: throw InternalError with collected messages\n   *     end\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  /**\n   * @description Retrieves a document from the database\n   * @summary Fetches a single document from the Nano database by its ID\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: generateId(tableName, id)\n   *   A->>DB: get(_id)\n   *   alt Success\n   *     DB-->>A: record\n   *     A->>A: assignMetadata(record, record._rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  /**\n   * @description Retrieves multiple documents from the database\n   * @summary Fetches multiple documents from the Nano database by their IDs in a single operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of document identifiers\n   * @return A promise that resolves to an array of retrieved documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: Map ids to generateId(tableName, id)\n   *   A->>DB: fetch({keys: mappedIds}, {})\n   *   DB-->>A: results\n   *   A->>A: Process each result row\n   *   loop For each row\n   *     alt Row has error\n   *       A-->>A: throw InternalError\n   *     else Row has document\n   *       A->>A: assignMetadata(doc, doc._rev)\n   *     else No document\n   *       A-->>A: throw InternalError\n   *     end\n   *   end\n   *   A-->>A: return documents with metadata\n   */\n  override async readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  /**\n   * @description Updates a document in the database\n   * @summary Updates an existing document in the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The updated document data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  override async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    const deletion: DocumentBulkResponse[] = await this.native.bulk({\n      docs: results.rows.map((r) => {\n        (r as any)[CouchDBKeys.DELETED] = true;\n        return r;\n      }),\n    });\n    deletion.forEach((d: DocumentBulkResponse) => {\n      if (d.error) console.error(d.error);\n    });\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  override async raw<R>(rawInput: MangoQuery, docsOnly = true): Promise<R> {\n    try {\n      const response: MangoResponse<R> = await this.native.find(rawInput);\n      if (response.warning) console.warn(response.warning);\n      if (docsOnly) return response.docs as R;\n      return response as R;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  static connect(\n    user: string,\n    pass: string,\n    host = \"localhost:5984\",\n    protocol: \"http\" | \"https\" = \"http\"\n  ): ServerScope {\n    return Nano(`${protocol}://${user}:${pass}@${host}`);\n  }\n\n  /**\n   * @description Creates a new database on the Nano server\n   * @summary Creates a new database with the specified name on the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to create\n   * @return {Promise<void>} A promise that resolves when the database is created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.create(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw parseError(error, reason)\n   *   end\n   */\n  static async createDatabase(con: ServerScope, name: string) {\n    let result: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.parseError(error as string, reason);\n  }\n\n  /**\n   * @description Deletes a database from the Nano server\n   * @summary Removes an existing database with the specified name from the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to delete\n   * @return {Promise<void>} A promise that resolves when the database is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.destroy(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async deleteDatabase(con: ServerScope, name: string) {\n    let result;\n    try {\n      result = await con.db.destroy(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok } = result;\n    if (!ok)\n      throw new InternalError(`Failed to delete database with name ${name}`);\n  }\n\n  /**\n   * @description Creates a new user and grants access to a database\n   * @summary Creates a new user in the Nano server and configures security to grant the user access to a specific database\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database to grant access to\n   * @param {string} user - The username to create\n   * @param {string} pass - The password for the new user\n   * @param {string[]} [roles=[\"reader\", \"writer\"]] - The roles to assign to the user\n   * @return {Promise<void>} A promise that resolves when the user is created and granted access\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   participant S as Security API\n   *   A->>A: Create user object\n   *   A->>U: insert(user)\n   *   alt Success\n   *     U-->>A: response with ok=true\n   *     A->>S: PUT _security with user permissions\n   *     alt Security Success\n   *       S-->>A: security response with ok=true\n   *     else Security Failure\n   *       S-->>A: security response with ok=false\n   *       A-->>A: throw InternalError\n   *     end\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     U-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async createUser(\n    con: ServerScope,\n    dbName: string,\n    user: string,\n    pass: string,\n    roles: string[] = [\"reader\", \"writer\"]\n  ) {\n    const users = con.db.use(\"_users\");\n    const usr = {\n      _id: \"org.couchdb.user:\" + user,\n      name: user,\n      password: pass,\n      roles: roles,\n      type: \"user\",\n    };\n    try {\n      const created: DocumentInsertResponse = await users.insert(\n        usr as MaybeDocument\n      );\n      const { ok } = created;\n      if (!ok) throw new InternalError(`Failed to create user ${user}`);\n      const security: any = await con.request({\n        db: dbName,\n        method: \"put\",\n        path: \"_security\",\n        // headers: {\n        //\n        // },\n        body: {\n          admins: {\n            names: [user],\n            roles: [],\n          },\n          members: {\n            names: [user],\n            roles: roles,\n          },\n        },\n      });\n      if (!security.ok)\n        throw new InternalError(\n          `Failed to authorize user ${user} to db ${dbName}`\n        );\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Deletes a user from the Nano server\n   * @summary Removes an existing user from the Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database (used for logging purposes)\n   * @param {string} user - The username to delete\n   * @return {Promise<void>} A promise that resolves when the user is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   A->>A: Generate user ID\n   *   A->>U: get(id)\n   *   U-->>A: user document\n   *   A->>U: destroy(id, user._rev)\n   *   alt Success\n   *     U-->>A: success response\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = con.db.use(\"_users\");\n    const id = \"org.couchdb.user:\" + user;\n    try {\n      const usr = await users.get(id);\n      await users.destroy(id, usr._rev);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Sets up decorations for Nano-specific model properties\n   * @summary Configures decorators for created_by and updated_by fields in models to be automatically\n   * populated with the user from the context when documents are created or updated\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant D as Decoration\n   *   participant R as Repository\n   *   A->>R: key(PersistenceKeys.CREATED_BY)\n   *   R-->>A: createdByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(createdByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   *   A->>R: key(PersistenceKeys.UPDATED_BY)\n   *   R-->>A: updatedByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(updatedByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   */\n  static override decoration() {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(\"nano\")\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n\n    Decoration.flavouredAs(\"nano\")\n      .for(updatedByKey)\n      .define(\n        onCreateUpdate(createdByOnNanoCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n}\n\nAdapter.setCurrent(NanoFlavour);\n","import { NanoAdapter } from \"./adapter\";\n\n// Forces override for Nano Decoration\nNanoAdapter.decoration();\n\nexport * from \"./constants\";\nexport * from \"./NanoRepository\";\nexport * from \"./types\";\n// Left to the end on purpose\nexport * from \"./adapter\";\n\n/**\n * @description A TypeScript module for interacting with Nano databases\n * @summary This module provides a set of utilities, classes, and types for working with Nano databases. It includes repository patterns, adapters, and type definitions to simplify database operations.\n * @module for-nano\n */\n\n/**\n * @description Package version identifier\n * @summary Stores the current package version string for the for-nano module\n * @const VERSION\n * @memberOf module:for-nano\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":["Dispatch","CouchDBKeys","OperationKeys","InternalError","UnsupportedError","CouchDBAdapter","generateIndexes","ConflictError","Repository","PersistenceKeys","Decoration","onCreate","propMetadata","onCreateUpdate","Adapter"],"mappings":"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"}
|
package/dist/for-nano.esm.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { OperationKeys, InternalError, ConflictError, onCreate } from '@decaf-ts/db-decorators';
|
|
1
|
+
import { OperationKeys, InternalError, ConflictError, onCreate, onCreateUpdate } from '@decaf-ts/db-decorators';
|
|
2
2
|
import 'reflect-metadata';
|
|
3
3
|
import { CouchDBKeys, CouchDBAdapter, generateIndexes } from '@decaf-ts/for-couchdb';
|
|
4
4
|
import Nano from 'nano';
|
|
@@ -829,7 +829,7 @@ class NanoAdapter extends CouchDBAdapter {
|
|
|
829
829
|
.apply();
|
|
830
830
|
Decoration.flavouredAs("nano")
|
|
831
831
|
.for(updatedByKey)
|
|
832
|
-
.define(
|
|
832
|
+
.define(onCreateUpdate(createdByOnNanoCreateUpdate), propMetadata(updatedByKey, {}))
|
|
833
833
|
.apply();
|
|
834
834
|
}
|
|
835
835
|
}
|
|
@@ -848,7 +848,7 @@ NanoAdapter.decoration();
|
|
|
848
848
|
* @const VERSION
|
|
849
849
|
* @memberOf module:for-nano
|
|
850
850
|
*/
|
|
851
|
-
const VERSION = "0.1.
|
|
851
|
+
const VERSION = "0.1.8";
|
|
852
852
|
|
|
853
853
|
export { NanoAdapter, NanoFlavour, VERSION, createdByOnNanoCreateUpdate };
|
|
854
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-nano.esm.cjs","sources":["../src/constants.ts","../src/NanoDispatch.ts","../src/adapter.ts","../src/index.ts"],"sourcesContent":["/**\n * @description Identifier for the Nano database flavor\n * @summary Constant string that identifies the database type as \"nano\" for use in adapter selection and configuration\n * @const NanoFlavour\n * @memberOf module:for-nano\n */\nexport const NanoFlavour = \"nano\";\n","import { Dispatch } from \"@decaf-ts/core\";\nimport {\n  DatabaseChangesResponse,\n  DatabaseChangesResultItem,\n  DocumentScope,\n  RequestError,\n} from \"nano\";\nimport { InternalError, OperationKeys } from \"@decaf-ts/db-decorators\";\nimport { CouchDBKeys } from \"@decaf-ts/for-couchdb\";\n\n/**\n * @description Dispatcher for Nano database change events\n * @summary Handles the subscription to and processing of database change events from a Nano database,\n * notifying observers when documents are created, updated, or deleted\n * @template DocumentScope - The Nano document scope type\n * @param {number} [timeout=5000] - Timeout in milliseconds for change feed requests\n * @class NanoDispatch\n * @example\n * ```typescript\n * // Create a dispatcher for a Nano database\n * const db = server.db.use('my_database');\n * const adapter = new NanoAdapter(db);\n * const dispatch = new NanoDispatch();\n *\n * // The dispatcher will automatically subscribe to changes\n * // and notify observers when documents change\n * ```\n * @mermaid\n * classDiagram\n *   class Dispatch {\n *     +initialize()\n *     +updateObservers()\n *   }\n *   class NanoDispatch {\n *     -observerLastUpdate?: string\n *     -attemptCounter: number\n *     -timeout: number\n *     +constructor(timeout)\n *     #changeHandler()\n *     #initialize()\n *   }\n *   Dispatch <|-- NanoDispatch\n */\nexport class NanoDispatch extends Dispatch<DocumentScope<any>> {\n  private observerLastUpdate?: string;\n  private attemptCounter: number = 0;\n  constructor(private timeout = 5000) {\n    super();\n  }\n\n  /**\n   * @description Processes database change events\n   * @summary Handles the response from the Nano changes feed, processes the changes,\n   * and notifies observers about document changes\n   * @param {RequestError | null} error - Error object if the request failed\n   * @param response - The changes response from Nano\n   * @param {any} [headers] - Response headers (unused)\n   * @return {Promise<void>} A promise that resolves when all changes have been processed\n   * @mermaid\n   * sequenceDiagram\n   *   participant D as NanoDispatch\n   *   participant L as Logger\n   *   participant O as Observers\n   *   Note over D: Receive changes from Nano\n   *   alt Error in response\n   *     D->>L: Log error\n   *     D-->>D: Return early\n   *   end\n   *   alt Response is string\n   *     D->>D: Parse JSON from string\n   *   end\n   *   D->>D: Process changes\n   *   D->>D: Group changes by table and operation\n   *   loop For each table\n   *     loop For each operation\n   *       D->>O: updateObservers(table, operation, ids)\n   *       D->>D: Update observerLastUpdate\n   *       D->>L: Log successful dispatch\n   *     end\n   *   end\n   */\n  protected async changeHandler(\n    error: RequestError | null,\n    response: (DatabaseChangesResponse | DatabaseChangesResultItem)[] | string,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    headers?: any\n  ) {\n    const log = this.log.for(this.changeHandler);\n    if (error) return log.error(`Error in change request: ${error}`);\n    try {\n      response = (\n        typeof response === \"string\"\n          ? response\n              .split(\"\\n\")\n              .filter((r) => !!r)\n              .map((r) => JSON.parse(r))\n          : response\n      ) as DatabaseChangesResponse[];\n    } catch (e: unknown) {\n      return log.error(`Error parsing couchdb change feed: ${e}`);\n    }\n    const count = response.length;\n    if (count > 0) {\n      log.debug(`Received ${count} changes. processing...`);\n      const changes = response\n        .map((rec, i) => {\n          if (i === count - 1) {\n            if (\n              this.observerLastUpdate ===\n              (rec as DatabaseChangesResponse).last_seq\n            )\n              log.error(\n                `Invalid last update check: ${this.observerLastUpdate} !== ${(rec as DatabaseChangesResponse).last_seq}`\n              );\n            return;\n          }\n          const r = rec as DatabaseChangesResultItem;\n          const [table, id] = r.id.split(CouchDBKeys.SEPARATOR);\n          return {\n            table: table,\n            id: id,\n            operation: r.deleted\n              ? OperationKeys.DELETE\n              : r.changes[r.changes.length - 1].rev.split(\"-\")[0] === \"1\"\n                ? OperationKeys.CREATE\n                : OperationKeys.UPDATE,\n            step: r.changes[r.changes.length - 1].rev,\n          };\n        })\n        .reduce(\n          (\n            accum: Record<\n              string,\n              Record<\n                string,\n                {\n                  ids: Set<any>;\n                  step: string;\n                }\n              >\n            >,\n            r\n          ) => {\n            if (!r) return accum;\n            const { table, id, operation, step } = r as {\n              table: string;\n              id: string;\n              operation: OperationKeys;\n              step: string;\n            };\n            if (!accum[table]) accum[table] = {};\n            if (!accum[table][operation])\n              accum[table][operation] = { ids: new Set(), step: step };\n            accum[table][operation].ids.add(id);\n            accum[table][operation].step = step;\n            return accum;\n          },\n          {}\n        );\n\n      for (const table of Object.keys(changes)) {\n        for (const op of Object.keys(changes[table])) {\n          try {\n            await this.updateObservers(table, op, [\n              ...changes[table][op].ids.values(),\n            ]);\n            this.observerLastUpdate = changes[table][op].step;\n            log.verbose(`Observer refresh dispatched by ${op} for ${table}`);\n            log.debug(`pks: ${Array.from(changes[table][op].ids.values())}`);\n          } catch (e: unknown) {\n            log.error(\n              `Failed to dispatch observer refresh for ${table}, op ${op}: ${e}`\n            );\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * @description Initializes the dispatcher and subscribes to database changes\n   * @summary Sets up the continuous changes feed subscription to the Nano database\n   * and handles reconnection attempts if the connection fails\n   * @return {Promise<void>} A promise that resolves when the subscription is established\n   * @mermaid\n   * sequenceDiagram\n   *   participant D as NanoDispatch\n   *   participant S as subscribeToCouch\n   *   participant DB as Nano Database\n   *   participant L as Logger\n   *   D->>S: Call subscribeToCouch\n   *   S->>S: Check adapter and native\n   *   alt No adapter or native\n   *     S-->>S: throw InternalError\n   *   end\n   *   S->>DB: changes(options, changeHandler)\n   *   alt Success\n   *     DB-->>S: Subscription established\n   *     S-->>D: Promise resolves\n   *     D->>L: Log successful subscription\n   *   else Error\n   *     DB-->>S: Error\n   *     S->>S: Increment attemptCounter\n   *     alt attemptCounter > 3\n   *       S->>L: Log error\n   *       S-->>D: Promise rejects\n   *     else attemptCounter <= 3\n   *       S->>L: Log retry\n   *       S->>S: Wait timeout\n   *       S->>S: Recursive call to subscribeToCouch\n   *     end\n   *   end\n   */\n  protected override async initialize(): Promise<void> {\n    const log = this.log.for(this.initialize);\n    const subLog = log.for(subscribeToCouch);\n    async function subscribeToCouch(this: NanoDispatch): Promise<void> {\n      if (!this.adapter || !this.native)\n        throw new InternalError(`No adapter/native observed for dispatch`);\n\n      try {\n        this.native.changes(\n          {\n            feed: \"continuous\",\n            include_docs: false,\n            since: this.observerLastUpdate || \"now\",\n            timeout: this.timeout,\n          },\n          this.changeHandler.bind(this) as any\n        );\n      } catch (e: unknown) {\n        if (++this.attemptCounter > 3)\n          return subLog.error(`Failed to subscribe to couchdb changes: ${e}`);\n        subLog.info(\n          `Failed to subscribe to couchdb changes: ${e}. Retrying in 5 seconds...`\n        );\n        await new Promise((resolve) => setTimeout(resolve, this.timeout));\n        return subscribeToCouch.call(this);\n      }\n    }\n\n    subscribeToCouch\n      .call(this)\n      .then(() => {\n        this.log.info(`Subscribed to couchdb changes`);\n      })\n      .catch((e: unknown) => {\n        throw new InternalError(`Failed to subscribe to couchdb changes: ${e}`);\n      });\n  }\n}\n","import {\n  ConflictError,\n  Context,\n  InternalError,\n  onCreate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  CreateIndexRequest,\n  generateIndexes,\n  MangoQuery,\n  MangoResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport Nano from \"nano\";\nimport {\n  DocumentBulkResponse,\n  DocumentGetResponse,\n  DocumentInsertResponse,\n  DocumentScope,\n  MaybeDocument,\n  ServerScope,\n} from \"nano\";\nimport {\n  Constructor,\n  Decoration,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport { NanoFlags } from \"./types\";\nimport {\n  Adapter,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { NanoFlavour } from \"./constants\";\nimport { NanoRepository } from \"./NanoRepository\";\nimport { NanoDispatch } from \"./NanoDispatch\";\n\n/**\n * @description Sets the creator or updater field in a model based on the user in the context\n * @summary Callback function used in decorators to automatically set the created_by or updated_by fields\n * with the username from the context when a document is created or updated\n * @template M - Type extending Model\n * @template R - Type extending NanoRepository<M>\n * @template V - Type extending RelationsMetadata\n * @param {R} this - The repository instance\n * @param {Context<NanoFlags>} context - The operation context containing user information\n * @param {V} data - The relation metadata\n * @param key - The property key to set with the username\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function createdByOnNanoCreateUpdate\n * @memberOf module:for-nano\n * @mermaid\n * sequenceDiagram\n *   participant F as createdByOnNanoCreateUpdate\n *   participant C as Context\n *   participant M as Model\n *   F->>C: get(\"user\")\n *   C-->>F: user object\n *   F->>M: set key to user.name\n *   Note over F: If no user in context\n *   F-->>F: throw UnsupportedError\n */\nexport async function createdByOnNanoCreateUpdate<\n  M extends Model,\n  R extends NanoRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<NanoFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"user\");\n    model[key] = user.name as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new UnsupportedError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Adapter for interacting with Nano databases\n * @summary Provides a standardized interface for performing CRUD operations on Nano databases,\n * extending the CouchDB adapter with Nano-specific functionality. This adapter handles document\n * creation, reading, updating, and deletion, as well as bulk operations and index management.\n * @template DocumentScope - The Nano document scope type\n * @template NanoFlags - Configuration flags for Nano operations\n * @template Context - Context type for operations\n * @param {DocumentScope<any>} scope - The Nano document scope to use for database operations\n * @param {string} [alias] - Optional alias for the adapter\n * @class NanoAdapter\n * @example\n * ```typescript\n * // Connect to a Nano database\n * const server = NanoAdapter.connect('admin', 'password', 'localhost:5984');\n * const db = server.db.use('my_database');\n *\n * // Create an adapter instance\n * const adapter = new NanoAdapter(db);\n *\n * // Use the adapter for database operations\n * const document = await adapter.read('users', '123');\n * ```\n * @mermaid\n * classDiagram\n *   class CouchDBAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +read()\n *     +update()\n *     +delete()\n *   }\n *   class NanoAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +createAll()\n *     +read()\n *     +readAll()\n *     +update()\n *     +updateAll()\n *     +delete()\n *     +deleteAll()\n *     +raw()\n *     +static connect()\n *     +static createDatabase()\n *     +static deleteDatabase()\n *     +static createUser()\n *     +static deleteUser()\n *     +static decoration()\n *   }\n *   CouchDBAdapter <|-- NanoAdapter\n */\nexport class NanoAdapter extends CouchDBAdapter<\n  DocumentScope<any>,\n  NanoFlags,\n  Context<NanoFlags>\n> {\n  constructor(scope: DocumentScope<any>, alias?: string) {\n    super(scope, NanoFlavour, alias);\n  }\n\n  /**\n   * @description Generates flags for database operations\n   * @summary Creates a set of flags for a specific operation, including user information\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation being performed (create, read, update, delete)\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<NanoFlags>} flags - Partial flags to be merged\n   * @return {Promise<NanoFlags>} Complete flags for the operation\n   */\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<NanoFlags>\n  ): Promise<NanoFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      user: {\n        name: this.native.config.url.split(\"@\")[0].split(\":\")[0],\n      },\n    }) as NanoFlags;\n  }\n\n  /**\n   * @description Creates a new NanoDispatch instance\n   * @summary Returns a dispatcher for handling Nano-specific operations\n   * @return {NanoDispatch} A new NanoDispatch instance\n   */\n  protected override Dispatch(): NanoDispatch {\n    return new NanoDispatch();\n  }\n\n  /**\n   * @description Creates database indexes for models\n   * @summary Generates and creates indexes in the Nano database based on the provided models\n   * @template M - Type extending Model\n   * @param models - Model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant G as generateIndexes\n   *   participant DB as Nano Database\n   *   A->>G: generateIndexes(models)\n   *   G-->>A: indexes\n   *   loop For each index\n   *     A->>DB: createIndex(index)\n   *     DB-->>A: response\n   *     Note over A: Check if index already exists\n   *     alt Index exists\n   *       A-->>A: throw ConflictError\n   *     end\n   *   end\n   */\n  protected override async index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  /**\n   * @description Creates a new document in the database\n   * @summary Inserts a new document into the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The document data to insert\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  /**\n   * @description Creates multiple documents in the database\n   * @summary Inserts multiple documents into the Nano database in a single bulk operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of document identifiers\n   * @param models - Array of document data to insert\n   * @return A promise that resolves to an array of created documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: bulk({docs: models})\n   *   alt Success\n   *     DB-->>A: response array\n   *     A->>A: Check if all responses have no errors\n   *     alt All OK\n   *       A->>A: assignMultipleMetadata(models, revs)\n   *       A-->>A: return documents with metadata\n   *     else Some errors\n   *       A->>A: Collect error messages\n   *       A-->>A: throw InternalError with collected messages\n   *     end\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  /**\n   * @description Retrieves a document from the database\n   * @summary Fetches a single document from the Nano database by its ID\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: generateId(tableName, id)\n   *   A->>DB: get(_id)\n   *   alt Success\n   *     DB-->>A: record\n   *     A->>A: assignMetadata(record, record._rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  /**\n   * @description Retrieves multiple documents from the database\n   * @summary Fetches multiple documents from the Nano database by their IDs in a single operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of document identifiers\n   * @return A promise that resolves to an array of retrieved documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: Map ids to generateId(tableName, id)\n   *   A->>DB: fetch({keys: mappedIds}, {})\n   *   DB-->>A: results\n   *   A->>A: Process each result row\n   *   loop For each row\n   *     alt Row has error\n   *       A-->>A: throw InternalError\n   *     else Row has document\n   *       A->>A: assignMetadata(doc, doc._rev)\n   *     else No document\n   *       A-->>A: throw InternalError\n   *     end\n   *   end\n   *   A-->>A: return documents with metadata\n   */\n  override async readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  /**\n   * @description Updates a document in the database\n   * @summary Updates an existing document in the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The updated document data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  override async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    const deletion: DocumentBulkResponse[] = await this.native.bulk({\n      docs: results.rows.map((r) => {\n        (r as any)[CouchDBKeys.DELETED] = true;\n        return r;\n      }),\n    });\n    deletion.forEach((d: DocumentBulkResponse) => {\n      if (d.error) console.error(d.error);\n    });\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  override async raw<R>(rawInput: MangoQuery, docsOnly = true): Promise<R> {\n    try {\n      const response: MangoResponse<R> = await this.native.find(rawInput);\n      if (response.warning) console.warn(response.warning);\n      if (docsOnly) return response.docs as R;\n      return response as R;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  static connect(\n    user: string,\n    pass: string,\n    host = \"localhost:5984\",\n    protocol: \"http\" | \"https\" = \"http\"\n  ): ServerScope {\n    return Nano(`${protocol}://${user}:${pass}@${host}`);\n  }\n\n  /**\n   * @description Creates a new database on the Nano server\n   * @summary Creates a new database with the specified name on the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to create\n   * @return {Promise<void>} A promise that resolves when the database is created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.create(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw parseError(error, reason)\n   *   end\n   */\n  static async createDatabase(con: ServerScope, name: string) {\n    let result: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.parseError(error as string, reason);\n  }\n\n  /**\n   * @description Deletes a database from the Nano server\n   * @summary Removes an existing database with the specified name from the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to delete\n   * @return {Promise<void>} A promise that resolves when the database is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.destroy(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async deleteDatabase(con: ServerScope, name: string) {\n    let result;\n    try {\n      result = await con.db.destroy(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok } = result;\n    if (!ok)\n      throw new InternalError(`Failed to delete database with name ${name}`);\n  }\n\n  /**\n   * @description Creates a new user and grants access to a database\n   * @summary Creates a new user in the Nano server and configures security to grant the user access to a specific database\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database to grant access to\n   * @param {string} user - The username to create\n   * @param {string} pass - The password for the new user\n   * @param {string[]} [roles=[\"reader\", \"writer\"]] - The roles to assign to the user\n   * @return {Promise<void>} A promise that resolves when the user is created and granted access\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   participant S as Security API\n   *   A->>A: Create user object\n   *   A->>U: insert(user)\n   *   alt Success\n   *     U-->>A: response with ok=true\n   *     A->>S: PUT _security with user permissions\n   *     alt Security Success\n   *       S-->>A: security response with ok=true\n   *     else Security Failure\n   *       S-->>A: security response with ok=false\n   *       A-->>A: throw InternalError\n   *     end\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     U-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async createUser(\n    con: ServerScope,\n    dbName: string,\n    user: string,\n    pass: string,\n    roles: string[] = [\"reader\", \"writer\"]\n  ) {\n    const users = con.db.use(\"_users\");\n    const usr = {\n      _id: \"org.couchdb.user:\" + user,\n      name: user,\n      password: pass,\n      roles: roles,\n      type: \"user\",\n    };\n    try {\n      const created: DocumentInsertResponse = await users.insert(\n        usr as MaybeDocument\n      );\n      const { ok } = created;\n      if (!ok) throw new InternalError(`Failed to create user ${user}`);\n      const security: any = await con.request({\n        db: dbName,\n        method: \"put\",\n        path: \"_security\",\n        // headers: {\n        //\n        // },\n        body: {\n          admins: {\n            names: [user],\n            roles: [],\n          },\n          members: {\n            names: [user],\n            roles: roles,\n          },\n        },\n      });\n      if (!security.ok)\n        throw new InternalError(\n          `Failed to authorize user ${user} to db ${dbName}`\n        );\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Deletes a user from the Nano server\n   * @summary Removes an existing user from the Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database (used for logging purposes)\n   * @param {string} user - The username to delete\n   * @return {Promise<void>} A promise that resolves when the user is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   A->>A: Generate user ID\n   *   A->>U: get(id)\n   *   U-->>A: user document\n   *   A->>U: destroy(id, user._rev)\n   *   alt Success\n   *     U-->>A: success response\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = con.db.use(\"_users\");\n    const id = \"org.couchdb.user:\" + user;\n    try {\n      const usr = await users.get(id);\n      await users.destroy(id, usr._rev);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Sets up decorations for Nano-specific model properties\n   * @summary Configures decorators for created_by and updated_by fields in models to be automatically\n   * populated with the user from the context when documents are created or updated\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant D as Decoration\n   *   participant R as Repository\n   *   A->>R: key(PersistenceKeys.CREATED_BY)\n   *   R-->>A: createdByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(createdByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   *   A->>R: key(PersistenceKeys.UPDATED_BY)\n   *   R-->>A: updatedByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(updatedByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   */\n  static override decoration() {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(\"nano\")\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n\n    Decoration.flavouredAs(\"nano\")\n      .for(updatedByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n}\n\nAdapter.setCurrent(NanoFlavour);\n","import { NanoAdapter } from \"./adapter\";\n\n// Forces override for Nano Decoration\nNanoAdapter.decoration();\n\nexport * from \"./constants\";\nexport * from \"./NanoRepository\";\nexport * from \"./types\";\n// Left to the end on purpose\nexport * from \"./adapter\";\n\n/**\n * @description A TypeScript module for interacting with Nano databases\n * @summary This module provides a set of utilities, classes, and types for working with Nano databases. It includes repository patterns, adapters, and type definitions to simplify database operations.\n * @module for-nano\n */\n\n/**\n * @description Package version identifier\n * @summary Stores the current package version string for the for-nano module\n * @const VERSION\n * @memberOf module:for-nano\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":[],"mappings":"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"}
|
|
854
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-nano.esm.cjs","sources":["../src/constants.ts","../src/NanoDispatch.ts","../src/adapter.ts","../src/index.ts"],"sourcesContent":["/**\n * @description Identifier for the Nano database flavor\n * @summary Constant string that identifies the database type as \"nano\" for use in adapter selection and configuration\n * @const NanoFlavour\n * @memberOf module:for-nano\n */\nexport const NanoFlavour = \"nano\";\n","import { Dispatch } from \"@decaf-ts/core\";\nimport {\n  DatabaseChangesResponse,\n  DatabaseChangesResultItem,\n  DocumentScope,\n  RequestError,\n} from \"nano\";\nimport { InternalError, OperationKeys } from \"@decaf-ts/db-decorators\";\nimport { CouchDBKeys } from \"@decaf-ts/for-couchdb\";\n\n/**\n * @description Dispatcher for Nano database change events\n * @summary Handles the subscription to and processing of database change events from a Nano database,\n * notifying observers when documents are created, updated, or deleted\n * @template DocumentScope - The Nano document scope type\n * @param {number} [timeout=5000] - Timeout in milliseconds for change feed requests\n * @class NanoDispatch\n * @example\n * ```typescript\n * // Create a dispatcher for a Nano database\n * const db = server.db.use('my_database');\n * const adapter = new NanoAdapter(db);\n * const dispatch = new NanoDispatch();\n *\n * // The dispatcher will automatically subscribe to changes\n * // and notify observers when documents change\n * ```\n * @mermaid\n * classDiagram\n *   class Dispatch {\n *     +initialize()\n *     +updateObservers()\n *   }\n *   class NanoDispatch {\n *     -observerLastUpdate?: string\n *     -attemptCounter: number\n *     -timeout: number\n *     +constructor(timeout)\n *     #changeHandler()\n *     #initialize()\n *   }\n *   Dispatch <|-- NanoDispatch\n */\nexport class NanoDispatch extends Dispatch<DocumentScope<any>> {\n  private observerLastUpdate?: string;\n  private attemptCounter: number = 0;\n  constructor(private timeout = 5000) {\n    super();\n  }\n\n  /**\n   * @description Processes database change events\n   * @summary Handles the response from the Nano changes feed, processes the changes,\n   * and notifies observers about document changes\n   * @param {RequestError | null} error - Error object if the request failed\n   * @param response - The changes response from Nano\n   * @param {any} [headers] - Response headers (unused)\n   * @return {Promise<void>} A promise that resolves when all changes have been processed\n   * @mermaid\n   * sequenceDiagram\n   *   participant D as NanoDispatch\n   *   participant L as Logger\n   *   participant O as Observers\n   *   Note over D: Receive changes from Nano\n   *   alt Error in response\n   *     D->>L: Log error\n   *     D-->>D: Return early\n   *   end\n   *   alt Response is string\n   *     D->>D: Parse JSON from string\n   *   end\n   *   D->>D: Process changes\n   *   D->>D: Group changes by table and operation\n   *   loop For each table\n   *     loop For each operation\n   *       D->>O: updateObservers(table, operation, ids)\n   *       D->>D: Update observerLastUpdate\n   *       D->>L: Log successful dispatch\n   *     end\n   *   end\n   */\n  protected async changeHandler(\n    error: RequestError | null,\n    response: (DatabaseChangesResponse | DatabaseChangesResultItem)[] | string,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    headers?: any\n  ) {\n    const log = this.log.for(this.changeHandler);\n    if (error) return log.error(`Error in change request: ${error}`);\n    try {\n      response = (\n        typeof response === \"string\"\n          ? response\n              .split(\"\\n\")\n              .filter((r) => !!r)\n              .map((r) => JSON.parse(r))\n          : response\n      ) as DatabaseChangesResponse[];\n    } catch (e: unknown) {\n      return log.error(`Error parsing couchdb change feed: ${e}`);\n    }\n    const count = response.length;\n    if (count > 0) {\n      log.debug(`Received ${count} changes. processing...`);\n      const changes = response\n        .map((rec, i) => {\n          if (i === count - 1) {\n            if (\n              this.observerLastUpdate ===\n              (rec as DatabaseChangesResponse).last_seq\n            )\n              log.error(\n                `Invalid last update check: ${this.observerLastUpdate} !== ${(rec as DatabaseChangesResponse).last_seq}`\n              );\n            return;\n          }\n          const r = rec as DatabaseChangesResultItem;\n          const [table, id] = r.id.split(CouchDBKeys.SEPARATOR);\n          return {\n            table: table,\n            id: id,\n            operation: r.deleted\n              ? OperationKeys.DELETE\n              : r.changes[r.changes.length - 1].rev.split(\"-\")[0] === \"1\"\n                ? OperationKeys.CREATE\n                : OperationKeys.UPDATE,\n            step: r.changes[r.changes.length - 1].rev,\n          };\n        })\n        .reduce(\n          (\n            accum: Record<\n              string,\n              Record<\n                string,\n                {\n                  ids: Set<any>;\n                  step: string;\n                }\n              >\n            >,\n            r\n          ) => {\n            if (!r) return accum;\n            const { table, id, operation, step } = r as {\n              table: string;\n              id: string;\n              operation: OperationKeys;\n              step: string;\n            };\n            if (!accum[table]) accum[table] = {};\n            if (!accum[table][operation])\n              accum[table][operation] = { ids: new Set(), step: step };\n            accum[table][operation].ids.add(id);\n            accum[table][operation].step = step;\n            return accum;\n          },\n          {}\n        );\n\n      for (const table of Object.keys(changes)) {\n        for (const op of Object.keys(changes[table])) {\n          try {\n            await this.updateObservers(table, op, [\n              ...changes[table][op].ids.values(),\n            ]);\n            this.observerLastUpdate = changes[table][op].step;\n            log.verbose(`Observer refresh dispatched by ${op} for ${table}`);\n            log.debug(`pks: ${Array.from(changes[table][op].ids.values())}`);\n          } catch (e: unknown) {\n            log.error(\n              `Failed to dispatch observer refresh for ${table}, op ${op}: ${e}`\n            );\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * @description Initializes the dispatcher and subscribes to database changes\n   * @summary Sets up the continuous changes feed subscription to the Nano database\n   * and handles reconnection attempts if the connection fails\n   * @return {Promise<void>} A promise that resolves when the subscription is established\n   * @mermaid\n   * sequenceDiagram\n   *   participant D as NanoDispatch\n   *   participant S as subscribeToCouch\n   *   participant DB as Nano Database\n   *   participant L as Logger\n   *   D->>S: Call subscribeToCouch\n   *   S->>S: Check adapter and native\n   *   alt No adapter or native\n   *     S-->>S: throw InternalError\n   *   end\n   *   S->>DB: changes(options, changeHandler)\n   *   alt Success\n   *     DB-->>S: Subscription established\n   *     S-->>D: Promise resolves\n   *     D->>L: Log successful subscription\n   *   else Error\n   *     DB-->>S: Error\n   *     S->>S: Increment attemptCounter\n   *     alt attemptCounter > 3\n   *       S->>L: Log error\n   *       S-->>D: Promise rejects\n   *     else attemptCounter <= 3\n   *       S->>L: Log retry\n   *       S->>S: Wait timeout\n   *       S->>S: Recursive call to subscribeToCouch\n   *     end\n   *   end\n   */\n  protected override async initialize(): Promise<void> {\n    const log = this.log.for(this.initialize);\n    const subLog = log.for(subscribeToCouch);\n    async function subscribeToCouch(this: NanoDispatch): Promise<void> {\n      if (!this.adapter || !this.native)\n        throw new InternalError(`No adapter/native observed for dispatch`);\n\n      try {\n        this.native.changes(\n          {\n            feed: \"continuous\",\n            include_docs: false,\n            since: this.observerLastUpdate || \"now\",\n            timeout: this.timeout,\n          },\n          this.changeHandler.bind(this) as any\n        );\n      } catch (e: unknown) {\n        if (++this.attemptCounter > 3)\n          return subLog.error(`Failed to subscribe to couchdb changes: ${e}`);\n        subLog.info(\n          `Failed to subscribe to couchdb changes: ${e}. Retrying in 5 seconds...`\n        );\n        await new Promise((resolve) => setTimeout(resolve, this.timeout));\n        return subscribeToCouch.call(this);\n      }\n    }\n\n    subscribeToCouch\n      .call(this)\n      .then(() => {\n        this.log.info(`Subscribed to couchdb changes`);\n      })\n      .catch((e: unknown) => {\n        throw new InternalError(`Failed to subscribe to couchdb changes: ${e}`);\n      });\n  }\n}\n","import {\n  ConflictError,\n  Context,\n  InternalError,\n  onCreate,\n  onCreateUpdate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  CreateIndexRequest,\n  generateIndexes,\n  MangoQuery,\n  MangoResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport Nano from \"nano\";\nimport {\n  DocumentBulkResponse,\n  DocumentGetResponse,\n  DocumentInsertResponse,\n  DocumentScope,\n  MaybeDocument,\n  ServerScope,\n} from \"nano\";\nimport {\n  Constructor,\n  Decoration,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport { NanoFlags } from \"./types\";\nimport {\n  Adapter,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { NanoFlavour } from \"./constants\";\nimport { NanoRepository } from \"./NanoRepository\";\nimport { NanoDispatch } from \"./NanoDispatch\";\n\n/**\n * @description Sets the creator or updater field in a model based on the user in the context\n * @summary Callback function used in decorators to automatically set the created_by or updated_by fields\n * with the username from the context when a document is created or updated\n * @template M - Type extending Model\n * @template R - Type extending NanoRepository<M>\n * @template V - Type extending RelationsMetadata\n * @param {R} this - The repository instance\n * @param {Context<NanoFlags>} context - The operation context containing user information\n * @param {V} data - The relation metadata\n * @param key - The property key to set with the username\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function createdByOnNanoCreateUpdate\n * @memberOf module:for-nano\n * @mermaid\n * sequenceDiagram\n *   participant F as createdByOnNanoCreateUpdate\n *   participant C as Context\n *   participant M as Model\n *   F->>C: get(\"user\")\n *   C-->>F: user object\n *   F->>M: set key to user.name\n *   Note over F: If no user in context\n *   F-->>F: throw UnsupportedError\n */\nexport async function createdByOnNanoCreateUpdate<\n  M extends Model,\n  R extends NanoRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<NanoFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"user\");\n    model[key] = user.name as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new UnsupportedError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Adapter for interacting with Nano databases\n * @summary Provides a standardized interface for performing CRUD operations on Nano databases,\n * extending the CouchDB adapter with Nano-specific functionality. This adapter handles document\n * creation, reading, updating, and deletion, as well as bulk operations and index management.\n * @template DocumentScope - The Nano document scope type\n * @template NanoFlags - Configuration flags for Nano operations\n * @template Context - Context type for operations\n * @param {DocumentScope<any>} scope - The Nano document scope to use for database operations\n * @param {string} [alias] - Optional alias for the adapter\n * @class NanoAdapter\n * @example\n * ```typescript\n * // Connect to a Nano database\n * const server = NanoAdapter.connect('admin', 'password', 'localhost:5984');\n * const db = server.db.use('my_database');\n *\n * // Create an adapter instance\n * const adapter = new NanoAdapter(db);\n *\n * // Use the adapter for database operations\n * const document = await adapter.read('users', '123');\n * ```\n * @mermaid\n * classDiagram\n *   class CouchDBAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +read()\n *     +update()\n *     +delete()\n *   }\n *   class NanoAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +createAll()\n *     +read()\n *     +readAll()\n *     +update()\n *     +updateAll()\n *     +delete()\n *     +deleteAll()\n *     +raw()\n *     +static connect()\n *     +static createDatabase()\n *     +static deleteDatabase()\n *     +static createUser()\n *     +static deleteUser()\n *     +static decoration()\n *   }\n *   CouchDBAdapter <|-- NanoAdapter\n */\nexport class NanoAdapter extends CouchDBAdapter<\n  DocumentScope<any>,\n  NanoFlags,\n  Context<NanoFlags>\n> {\n  constructor(scope: DocumentScope<any>, alias?: string) {\n    super(scope, NanoFlavour, alias);\n  }\n\n  /**\n   * @description Generates flags for database operations\n   * @summary Creates a set of flags for a specific operation, including user information\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation being performed (create, read, update, delete)\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<NanoFlags>} flags - Partial flags to be merged\n   * @return {Promise<NanoFlags>} Complete flags for the operation\n   */\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<NanoFlags>\n  ): Promise<NanoFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      user: {\n        name: this.native.config.url.split(\"@\")[0].split(\":\")[0],\n      },\n    }) as NanoFlags;\n  }\n\n  /**\n   * @description Creates a new NanoDispatch instance\n   * @summary Returns a dispatcher for handling Nano-specific operations\n   * @return {NanoDispatch} A new NanoDispatch instance\n   */\n  protected override Dispatch(): NanoDispatch {\n    return new NanoDispatch();\n  }\n\n  /**\n   * @description Creates database indexes for models\n   * @summary Generates and creates indexes in the Nano database based on the provided models\n   * @template M - Type extending Model\n   * @param models - Model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant G as generateIndexes\n   *   participant DB as Nano Database\n   *   A->>G: generateIndexes(models)\n   *   G-->>A: indexes\n   *   loop For each index\n   *     A->>DB: createIndex(index)\n   *     DB-->>A: response\n   *     Note over A: Check if index already exists\n   *     alt Index exists\n   *       A-->>A: throw ConflictError\n   *     end\n   *   end\n   */\n  protected override async index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  /**\n   * @description Creates a new document in the database\n   * @summary Inserts a new document into the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The document data to insert\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  /**\n   * @description Creates multiple documents in the database\n   * @summary Inserts multiple documents into the Nano database in a single bulk operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of document identifiers\n   * @param models - Array of document data to insert\n   * @return A promise that resolves to an array of created documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: bulk({docs: models})\n   *   alt Success\n   *     DB-->>A: response array\n   *     A->>A: Check if all responses have no errors\n   *     alt All OK\n   *       A->>A: assignMultipleMetadata(models, revs)\n   *       A-->>A: return documents with metadata\n   *     else Some errors\n   *       A->>A: Collect error messages\n   *       A-->>A: throw InternalError with collected messages\n   *     end\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  /**\n   * @description Retrieves a document from the database\n   * @summary Fetches a single document from the Nano database by its ID\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: generateId(tableName, id)\n   *   A->>DB: get(_id)\n   *   alt Success\n   *     DB-->>A: record\n   *     A->>A: assignMetadata(record, record._rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  /**\n   * @description Retrieves multiple documents from the database\n   * @summary Fetches multiple documents from the Nano database by their IDs in a single operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of document identifiers\n   * @return A promise that resolves to an array of retrieved documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: Map ids to generateId(tableName, id)\n   *   A->>DB: fetch({keys: mappedIds}, {})\n   *   DB-->>A: results\n   *   A->>A: Process each result row\n   *   loop For each row\n   *     alt Row has error\n   *       A-->>A: throw InternalError\n   *     else Row has document\n   *       A->>A: assignMetadata(doc, doc._rev)\n   *     else No document\n   *       A-->>A: throw InternalError\n   *     end\n   *   end\n   *   A-->>A: return documents with metadata\n   */\n  override async readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  /**\n   * @description Updates a document in the database\n   * @summary Updates an existing document in the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The updated document data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  override async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    const deletion: DocumentBulkResponse[] = await this.native.bulk({\n      docs: results.rows.map((r) => {\n        (r as any)[CouchDBKeys.DELETED] = true;\n        return r;\n      }),\n    });\n    deletion.forEach((d: DocumentBulkResponse) => {\n      if (d.error) console.error(d.error);\n    });\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  override async raw<R>(rawInput: MangoQuery, docsOnly = true): Promise<R> {\n    try {\n      const response: MangoResponse<R> = await this.native.find(rawInput);\n      if (response.warning) console.warn(response.warning);\n      if (docsOnly) return response.docs as R;\n      return response as R;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  static connect(\n    user: string,\n    pass: string,\n    host = \"localhost:5984\",\n    protocol: \"http\" | \"https\" = \"http\"\n  ): ServerScope {\n    return Nano(`${protocol}://${user}:${pass}@${host}`);\n  }\n\n  /**\n   * @description Creates a new database on the Nano server\n   * @summary Creates a new database with the specified name on the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to create\n   * @return {Promise<void>} A promise that resolves when the database is created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.create(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw parseError(error, reason)\n   *   end\n   */\n  static async createDatabase(con: ServerScope, name: string) {\n    let result: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.parseError(error as string, reason);\n  }\n\n  /**\n   * @description Deletes a database from the Nano server\n   * @summary Removes an existing database with the specified name from the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to delete\n   * @return {Promise<void>} A promise that resolves when the database is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.destroy(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async deleteDatabase(con: ServerScope, name: string) {\n    let result;\n    try {\n      result = await con.db.destroy(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok } = result;\n    if (!ok)\n      throw new InternalError(`Failed to delete database with name ${name}`);\n  }\n\n  /**\n   * @description Creates a new user and grants access to a database\n   * @summary Creates a new user in the Nano server and configures security to grant the user access to a specific database\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database to grant access to\n   * @param {string} user - The username to create\n   * @param {string} pass - The password for the new user\n   * @param {string[]} [roles=[\"reader\", \"writer\"]] - The roles to assign to the user\n   * @return {Promise<void>} A promise that resolves when the user is created and granted access\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   participant S as Security API\n   *   A->>A: Create user object\n   *   A->>U: insert(user)\n   *   alt Success\n   *     U-->>A: response with ok=true\n   *     A->>S: PUT _security with user permissions\n   *     alt Security Success\n   *       S-->>A: security response with ok=true\n   *     else Security Failure\n   *       S-->>A: security response with ok=false\n   *       A-->>A: throw InternalError\n   *     end\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     U-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async createUser(\n    con: ServerScope,\n    dbName: string,\n    user: string,\n    pass: string,\n    roles: string[] = [\"reader\", \"writer\"]\n  ) {\n    const users = con.db.use(\"_users\");\n    const usr = {\n      _id: \"org.couchdb.user:\" + user,\n      name: user,\n      password: pass,\n      roles: roles,\n      type: \"user\",\n    };\n    try {\n      const created: DocumentInsertResponse = await users.insert(\n        usr as MaybeDocument\n      );\n      const { ok } = created;\n      if (!ok) throw new InternalError(`Failed to create user ${user}`);\n      const security: any = await con.request({\n        db: dbName,\n        method: \"put\",\n        path: \"_security\",\n        // headers: {\n        //\n        // },\n        body: {\n          admins: {\n            names: [user],\n            roles: [],\n          },\n          members: {\n            names: [user],\n            roles: roles,\n          },\n        },\n      });\n      if (!security.ok)\n        throw new InternalError(\n          `Failed to authorize user ${user} to db ${dbName}`\n        );\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Deletes a user from the Nano server\n   * @summary Removes an existing user from the Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database (used for logging purposes)\n   * @param {string} user - The username to delete\n   * @return {Promise<void>} A promise that resolves when the user is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   A->>A: Generate user ID\n   *   A->>U: get(id)\n   *   U-->>A: user document\n   *   A->>U: destroy(id, user._rev)\n   *   alt Success\n   *     U-->>A: success response\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = con.db.use(\"_users\");\n    const id = \"org.couchdb.user:\" + user;\n    try {\n      const usr = await users.get(id);\n      await users.destroy(id, usr._rev);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Sets up decorations for Nano-specific model properties\n   * @summary Configures decorators for created_by and updated_by fields in models to be automatically\n   * populated with the user from the context when documents are created or updated\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant D as Decoration\n   *   participant R as Repository\n   *   A->>R: key(PersistenceKeys.CREATED_BY)\n   *   R-->>A: createdByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(createdByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   *   A->>R: key(PersistenceKeys.UPDATED_BY)\n   *   R-->>A: updatedByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(updatedByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   */\n  static override decoration() {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(\"nano\")\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n\n    Decoration.flavouredAs(\"nano\")\n      .for(updatedByKey)\n      .define(\n        onCreateUpdate(createdByOnNanoCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n}\n\nAdapter.setCurrent(NanoFlavour);\n","import { NanoAdapter } from \"./adapter\";\n\n// Forces override for Nano Decoration\nNanoAdapter.decoration();\n\nexport * from \"./constants\";\nexport * from \"./NanoRepository\";\nexport * from \"./types\";\n// Left to the end on purpose\nexport * from \"./adapter\";\n\n/**\n * @description A TypeScript module for interacting with Nano databases\n * @summary This module provides a set of utilities, classes, and types for working with Nano databases. It includes repository patterns, adapters, and type definitions to simplify database operations.\n * @module for-nano\n */\n\n/**\n * @description Package version identifier\n * @summary Stores the current package version string for the for-nano module\n * @const VERSION\n * @memberOf module:for-nano\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":[],"mappings":";;;;;;;AAAA;;;;;AAKG;AACI,MAAM,WAAW,GAAG;;ACI3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgCG;AACG,MAAO,YAAa,SAAQ,QAA4B,CAAA;AAG5D,IAAA,WAAA,CAAoB,UAAU,IAAI,EAAA;AAChC,QAAA,KAAK,EAAE;QADW,IAAO,CAAA,OAAA,GAAP,OAAO;QADnB,IAAc,CAAA,cAAA,GAAW,CAAC;;AAKlC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BG;AACO,IAAA,MAAM,aAAa,CAC3B,KAA0B,EAC1B,QAA0E;;IAE1E,OAAa,EAAA;AAEb,QAAA,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC;AAC5C,QAAA,IAAI,KAAK;YAAE,OAAO,GAAG,CAAC,KAAK,CAAC,4BAA4B,KAAK,CAAA,CAAE,CAAC;AAChE,QAAA,IAAI;AACF,YAAA,QAAQ,IACN,OAAO,QAAQ,KAAK;AAClB,kBAAE;qBACG,KAAK,CAAC,IAAI;qBACV,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;AACjB,qBAAA,GAAG,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;kBAC3B,QAAQ,CACgB;;QAC9B,OAAO,CAAU,EAAE;YACnB,OAAO,GAAG,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAA,CAAE,CAAC;;AAE7D,QAAA,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM;AAC7B,QAAA,IAAI,KAAK,GAAG,CAAC,EAAE;AACb,YAAA,GAAG,CAAC,KAAK,CAAC,YAAY,KAAK,CAAA,uBAAA,CAAyB,CAAC;YACrD,MAAM,OAAO,GAAG;AACb,iBAAA,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,KAAI;AACd,gBAAA,IAAI,CAAC,KAAK,KAAK,GAAG,CAAC,EAAE;oBACnB,IACE,IAAI,CAAC,kBAAkB;AACtB,wBAAA,GAA+B,CAAC,QAAQ;AAEzC,wBAAA,GAAG,CAAC,KAAK,CACP,CAAA,2BAAA,EAA8B,IAAI,CAAC,kBAAkB,CAAA,KAAA,EAAS,GAA+B,CAAC,QAAQ,CAAA,CAAE,CACzG;oBACH;;gBAEF,MAAM,CAAC,GAAG,GAAgC;AAC1C,gBAAA,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC;gBACrD,OAAO;AACL,oBAAA,KAAK,EAAE,KAAK;AACZ,oBAAA,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC,CAAC;0BACT,aAAa,CAAC;0BACd,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK;8BACpD,aAAa,CAAC;8BACd,aAAa,CAAC,MAAM;AAC1B,oBAAA,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG;iBAC1C;AACH,aAAC;AACA,iBAAA,MAAM,CACL,CACE,KASC,EACD,CAAC,KACC;AACF,gBAAA,IAAI,CAAC,CAAC;AAAE,oBAAA,OAAO,KAAK;gBACpB,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,CAKtC;AACD,gBAAA,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;AAAE,oBAAA,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE;AACpC,gBAAA,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC;AAC1B,oBAAA,KAAK,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE;AAC1D,gBAAA,KAAK,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBACnC,KAAK,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,GAAG,IAAI;AACnC,gBAAA,OAAO,KAAK;aACb,EACD,EAAE,CACH;YAEH,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;AACxC,gBAAA,KAAK,MAAM,EAAE,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE;AAC5C,oBAAA,IAAI;AACF,wBAAA,MAAM,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,EAAE,EAAE;4BACpC,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE;AACnC,yBAAA,CAAC;AACF,wBAAA,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI;wBACjD,GAAG,CAAC,OAAO,CAAC,CAAA,+BAAA,EAAkC,EAAE,CAAQ,KAAA,EAAA,KAAK,CAAE,CAAA,CAAC;wBAChE,GAAG,CAAC,KAAK,CAAC,CAAA,KAAA,EAAQ,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAE,CAAA,CAAC;;oBAChE,OAAO,CAAU,EAAE;wBACnB,GAAG,CAAC,KAAK,CACP,CAA2C,wCAAA,EAAA,KAAK,CAAQ,KAAA,EAAA,EAAE,CAAK,EAAA,EAAA,CAAC,CAAE,CAAA,CACnE;;;;;;AAOX;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiCG;AACgB,IAAA,MAAM,UAAU,GAAA;AACjC,QAAA,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;QACzC,MAAM,MAAM,GAAG,GAAG,CAAC,GAAG,CAAC,gBAAgB,CAAC;AACxC,QAAA,eAAe,gBAAgB,GAAA;YAC7B,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM;AAC/B,gBAAA,MAAM,IAAI,aAAa,CAAC,CAAA,uCAAA,CAAyC,CAAC;AAEpE,YAAA,IAAI;AACF,gBAAA,IAAI,CAAC,MAAM,CAAC,OAAO,CACjB;AACE,oBAAA,IAAI,EAAE,YAAY;AAClB,oBAAA,YAAY,EAAE,KAAK;AACnB,oBAAA,KAAK,EAAE,IAAI,CAAC,kBAAkB,IAAI,KAAK;oBACvC,OAAO,EAAE,IAAI,CAAC,OAAO;iBACtB,EACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAQ,CACrC;;YACD,OAAO,CAAU,EAAE;AACnB,gBAAA,IAAI,EAAE,IAAI,CAAC,cAAc,GAAG,CAAC;oBAC3B,OAAO,MAAM,CAAC,KAAK,CAAC,2CAA2C,CAAC,CAAA,CAAE,CAAC;AACrE,gBAAA,MAAM,CAAC,IAAI,CACT,2CAA2C,CAAC,CAAA,0BAAA,CAA4B,CACzE;AACD,gBAAA,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,KAAK,UAAU,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;AACjE,gBAAA,OAAO,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC;;;QAItC;aACG,IAAI,CAAC,IAAI;aACT,IAAI,CAAC,MAAK;AACT,YAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA,6BAAA,CAA+B,CAAC;AAChD,SAAC;AACA,aAAA,KAAK,CAAC,CAAC,CAAU,KAAI;AACpB,YAAA,MAAM,IAAI,aAAa,CAAC,2CAA2C,CAAC,CAAA,CAAE,CAAC;AACzE,SAAC,CAAC;;AAEP;;AC9MD;;;;;;;;;;;;;;;;;;;;;;;;;AAyBG;AACI,eAAe,2BAA2B,CAM/C,OAA2B,EAC3B,IAAO,EACP,GAAY,EACZ,KAAQ,EAAA;AAER,IAAA,IAAI;QACF,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC;AAChC,QAAA,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,IAAqB;;;IAEvC,OAAO,CAAU,EAAE;AACnB,QAAA,MAAM,IAAI,gBAAgB,CACxB,gEAAgE,CACjE;;AAEL;AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuDG;AACG,MAAO,WAAY,SAAQ,cAIhC,CAAA;IACC,WAAY,CAAA,KAAyB,EAAE,KAAc,EAAA;AACnD,QAAA,KAAK,CAAC,KAAK,EAAE,WAAW,EAAE,KAAK,CAAC;;AAGlC;;;;;;;;AAQG;AACgB,IAAA,MAAM,KAAK,CAC5B,SAAwB,EACxB,KAAqB,EACrB,KAAyB,EAAA;AAEzB,QAAA,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,EAAE,KAAK,CAAC,EAAE;AAC/D,YAAA,IAAI,EAAE;gBACJ,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACzD,aAAA;AACF,SAAA,CAAc;;AAGjB;;;;AAIG;IACgB,QAAQ,GAAA;QACzB,OAAO,IAAI,YAAY,EAAE;;AAG3B;;;;;;;;;;;;;;;;;;;;;AAqBG;AACgB,IAAA,MAAM,KAAK,CAC5B,GAAG,MAAwB,EAAA;AAE3B,QAAA,MAAM,OAAO,GAAyB,eAAe,CAAC,MAAM,CAAC;AAC7D,QAAA,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;YAC3B,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC;YAChD,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,GAAG;YAChC,IAAI,MAAM,KAAK,UAAU;gBACvB,MAAM,IAAI,aAAa,CAAC,CAAA,gBAAA,EAAmB,IAAI,CAAY,SAAA,EAAA,EAAE,CAAE,CAAA,CAAC;;;AAItE;;;;;;;;;;;;;;;;;;;;;;;AAuBG;AACM,IAAA,MAAM,MAAM,CACnB,SAAiB,EACjB,EAAmB,EACnB,KAA0B,EAAA;AAE1B,QAAA,IAAI,QAAgC;AACpC,QAAA,IAAI;YACF,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC;;QAC1C,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;;QAG1B,IAAI,CAAC,QAAQ,CAAC,EAAE;YACd,MAAM,IAAI,aAAa,CACrB,CAAA,yBAAA,EAA4B,EAAE,CAAa,UAAA,EAAA,SAAS,CAAE,CAAA,CACvD;QACH,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC;;AAGjD;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BG;AACM,IAAA,MAAM,SAAS,CACtB,SAAiB,EACjB,GAAwB,EACxB,MAA6B,EAAA;AAE7B,QAAA,IAAI,QAAgC;AACpC,QAAA,IAAI;AACF,YAAA,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;QACnD,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;;AAE1B,QAAA,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE;AACpC,YAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,KAAe,EAAE,EAAE,EAAE,CAAC,KAAI;gBACxD,IAAI,EAAE,CAAC,KAAK;oBACV,KAAK,CAAC,IAAI,CACR,CAAM,GAAA,EAAA,CAAC,CAAK,EAAA,EAAA,EAAE,CAAC,KAAK,CAAG,EAAA,EAAE,CAAC,MAAM,GAAG,CAAA,GAAA,EAAM,EAAE,CAAC,MAAM,CAAA,CAAE,GAAG,EAAE,CAAE,CAAA,CAC5D;AACH,gBAAA,OAAO,KAAK;aACb,EAAE,EAAE,CAAC;YACN,MAAM,IAAI,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;QAG5C,OAAO,IAAI,CAAC,sBAAsB,CAChC,MAAM,EACN,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,GAAa,CAAC,CACrC;;AAGH;;;;;;;;;;;;;;;;;;;;AAoBG;AACM,IAAA,MAAM,IAAI,CACjB,SAAiB,EACjB,EAAmB,EAAA;QAEnB,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,EAAE,CAAC;AAC1C,QAAA,IAAI,MAA2B;AAC/B,QAAA,IAAI;YACF,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC;;QACnC,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;;QAE1B,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;;AAGjD;;;;;;;;;;;;;;;;;;;;;;;;AAwBG;AACM,IAAA,MAAM,OAAO,CACpB,SAAiB,EACjB,GAAiC,EAAA;AAEjC,QAAA,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CACrC,EAAE,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,EAAS,CAAC,CAAC,EAAE,EAChE,EAAE,CACH;QACD,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,KAAI;YAC5B,IAAK,CAAS,CAAC,KAAK;AAAE,gBAAA,MAAM,IAAI,aAAa,CAAE,CAAS,CAAC,KAAK,CAAC;AAC/D,YAAA,IAAK,CAAS,CAAC,GAAG,EAAE;AAClB,gBAAA,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAG,CAAS,CAAC,GAAG,CAAC;AAC7C,gBAAA,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,EAAG,CAAS,CAAC,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;;AAElE,YAAA,MAAM,IAAI,aAAa,CAAC,sBAAsB,CAAC;AACjD,SAAC,CAAC;;AAGJ;;;;;;;;;;;;;;;;;;;;;;;AAuBG;AACM,IAAA,MAAM,MAAM,CACnB,SAAiB,EACjB,EAAmB,EACnB,KAA0B,EAAA;AAE1B,QAAA,IAAI,QAAgC;AACpC,QAAA,IAAI;YACF,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC;;QAC1C,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;;QAG1B,IAAI,CAAC,QAAQ,CAAC,EAAE;YACd,MAAM,IAAI,aAAa,CACrB,CAAA,yBAAA,EAA4B,EAAE,CAAa,UAAA,EAAA,SAAS,CAAE,CAAA,CACvD;QACH,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC;;AAGxC,IAAA,MAAM,SAAS,CACtB,SAAiB,EACjB,GAAwB,EACxB,MAA6B,EAAA;AAE7B,QAAA,IAAI,QAAgC;AACpC,QAAA,IAAI;AACF,YAAA,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;QACnD,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;;AAE1B,QAAA,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE;AACpC,YAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,KAAe,EAAE,EAAE,EAAE,CAAC,KAAI;gBACxD,IAAI,EAAE,CAAC,KAAK;oBACV,KAAK,CAAC,IAAI,CACR,CAAM,GAAA,EAAA,CAAC,CAAK,EAAA,EAAA,EAAE,CAAC,KAAK,CAAG,EAAA,EAAE,CAAC,MAAM,GAAG,CAAA,GAAA,EAAM,EAAE,CAAC,MAAM,CAAA,CAAE,GAAG,EAAE,CAAE,CAAA,CAC5D;AACH,gBAAA,OAAO,KAAK;aACb,EAAE,EAAE,CAAC;YACN,MAAM,IAAI,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;QAG5C,OAAO,IAAI,CAAC,sBAAsB,CAChC,MAAM,EACN,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,GAAa,CAAC,CACrC;;AAGM,IAAA,MAAM,MAAM,CACnB,SAAiB,EACjB,EAAmB,EAAA;QAEnB,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,EAAE,CAAC;AAC1C,QAAA,IAAI,MAA2B;AAC/B,QAAA,IAAI;YACF,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC;AACnC,YAAA,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC;;QAC3C,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;;QAE1B,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;;AAGxC,IAAA,MAAM,SAAS,CACtB,SAAiB,EACjB,GAAiC,EAAA;AAEjC,QAAA,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CACrC,EAAE,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,EAAS,CAAC,CAAC,EAAE,EAChE,EAAE,CACH;QACD,MAAM,QAAQ,GAA2B,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;YAC9D,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,KAAI;AAC1B,gBAAA,CAAS,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,IAAI;AACtC,gBAAA,OAAO,CAAC;AACV,aAAC,CAAC;AACH,SAAA,CAAC;AACF,QAAA,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAuB,KAAI;YAC3C,IAAI,CAAC,CAAC,KAAK;AAAE,gBAAA,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;AACrC,SAAC,CAAC;QACF,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,KAAI;YAC5B,IAAK,CAAS,CAAC,KAAK;AAAE,gBAAA,MAAM,IAAI,aAAa,CAAE,CAAS,CAAC,KAAK,CAAC;AAC/D,YAAA,IAAK,CAAS,CAAC,GAAG,EAAE;AAClB,gBAAA,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAG,CAAS,CAAC,GAAG,CAAC;AAC7C,gBAAA,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,EAAG,CAAS,CAAC,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;;AAElE,YAAA,MAAM,IAAI,aAAa,CAAC,sBAAsB,CAAC;AACjD,SAAC,CAAC;;AAGK,IAAA,MAAM,GAAG,CAAI,QAAoB,EAAE,QAAQ,GAAG,IAAI,EAAA;AACzD,QAAA,IAAI;YACF,MAAM,QAAQ,GAAqB,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;YACnE,IAAI,QAAQ,CAAC,OAAO;AAAE,gBAAA,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;AACpD,YAAA,IAAI,QAAQ;gBAAE,OAAO,QAAQ,CAAC,IAAS;AACvC,YAAA,OAAO,QAAa;;QACpB,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;;;AAI5B,IAAA,OAAO,OAAO,CACZ,IAAY,EACZ,IAAY,EACZ,IAAI,GAAG,gBAAgB,EACvB,QAAA,GAA6B,MAAM,EAAA;AAEnC,QAAA,OAAO,IAAI,CAAC,CAAG,EAAA,QAAQ,CAAM,GAAA,EAAA,IAAI,CAAI,CAAA,EAAA,IAAI,CAAI,CAAA,EAAA,IAAI,CAAE,CAAA,CAAC;;AAGtD;;;;;;;;;;;;;;;;;;;;AAoBG;AACH,IAAA,aAAa,cAAc,CAAC,GAAgB,EAAE,IAAY,EAAA;AACxD,QAAA,IAAI,MAAW;AACf,QAAA,IAAI;YACF,MAAM,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;;QAClC,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;;QAEpC,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM;AACpC,QAAA,IAAI,CAAC,EAAE;YAAE,MAAM,cAAc,CAAC,UAAU,CAAC,KAAe,EAAE,MAAM,CAAC;;AAGnE;;;;;;;;;;;;;;;;;;;;AAoBG;AACH,IAAA,aAAa,cAAc,CAAC,GAAgB,EAAE,IAAY,EAAA;AACxD,QAAA,IAAI,MAAM;AACV,QAAA,IAAI;YACF,MAAM,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;;QACnC,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;;AAEpC,QAAA,MAAM,EAAE,EAAE,EAAE,GAAG,MAAM;AACrB,QAAA,IAAI,CAAC,EAAE;AACL,YAAA,MAAM,IAAI,aAAa,CAAC,uCAAuC,IAAI,CAAA,CAAE,CAAC;;AAG1E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgCG;AACH,IAAA,aAAa,UAAU,CACrB,GAAgB,EAChB,MAAc,EACd,IAAY,EACZ,IAAY,EACZ,KAAA,GAAkB,CAAC,QAAQ,EAAE,QAAQ,CAAC,EAAA;QAEtC,MAAM,KAAK,GAAG,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,QAAQ,CAAC;AAClC,QAAA,MAAM,GAAG,GAAG;YACV,GAAG,EAAE,mBAAmB,GAAG,IAAI;AAC/B,YAAA,IAAI,EAAE,IAAI;AACV,YAAA,QAAQ,EAAE,IAAI;AACd,YAAA,KAAK,EAAE,KAAK;AACZ,YAAA,IAAI,EAAE,MAAM;SACb;AACD,QAAA,IAAI;YACF,MAAM,OAAO,GAA2B,MAAM,KAAK,CAAC,MAAM,CACxD,GAAoB,CACrB;AACD,YAAA,MAAM,EAAE,EAAE,EAAE,GAAG,OAAO;AACtB,YAAA,IAAI,CAAC,EAAE;AAAE,gBAAA,MAAM,IAAI,aAAa,CAAC,yBAAyB,IAAI,CAAA,CAAE,CAAC;AACjE,YAAA,MAAM,QAAQ,GAAQ,MAAM,GAAG,CAAC,OAAO,CAAC;AACtC,gBAAA,EAAE,EAAE,MAAM;AACV,gBAAA,MAAM,EAAE,KAAK;AACb,gBAAA,IAAI,EAAE,WAAW;;;;AAIjB,gBAAA,IAAI,EAAE;AACJ,oBAAA,MAAM,EAAE;wBACN,KAAK,EAAE,CAAC,IAAI,CAAC;AACb,wBAAA,KAAK,EAAE,EAAE;AACV,qBAAA;AACD,oBAAA,OAAO,EAAE;wBACP,KAAK,EAAE,CAAC,IAAI,CAAC;AACb,wBAAA,KAAK,EAAE,KAAK;AACb,qBAAA;AACF,iBAAA;AACF,aAAA,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,EAAE;gBACd,MAAM,IAAI,aAAa,CACrB,CAAA,yBAAA,EAA4B,IAAI,CAAU,OAAA,EAAA,MAAM,CAAE,CAAA,CACnD;;QACH,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;;;AAItC;;;;;;;;;;;;;;;;;;;;;AAqBG;IACH,aAAa,UAAU,CAAC,GAAgB,EAAE,MAAc,EAAE,IAAY,EAAA;QACpE,MAAM,KAAK,GAAG,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,QAAQ,CAAC;AAClC,QAAA,MAAM,EAAE,GAAG,mBAAmB,GAAG,IAAI;AACrC,QAAA,IAAI;YACF,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;YAC/B,MAAM,KAAK,CAAC,OAAO,CAAC,EAAE,EAAE,GAAG,CAAC,IAAI,CAAC;;QACjC,OAAO,CAAM,EAAE;AACf,YAAA,MAAM,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;;;AAItC;;;;;;;;;;;;;;;;;;;;;;AAsBG;AACH,IAAA,OAAgB,UAAU,GAAA;QACxB,KAAK,CAAC,UAAU,EAAE;QAClB,MAAM,YAAY,GAAG,UAAU,CAAC,GAAG,CAAC,eAAe,CAAC,UAAU,CAAC;QAC/D,MAAM,YAAY,GAAG,UAAU,CAAC,GAAG,CAAC,eAAe,CAAC,UAAU,CAAC;AAC/D,QAAA,UAAU,CAAC,WAAW,CAAC,MAAM;aAC1B,GAAG,CAAC,YAAY;AAChB,aAAA,MAAM,CACL,QAAQ,CAAC,2BAA2B,CAAC,EACrC,YAAY,CAAC,YAAY,EAAE,EAAE,CAAC;AAE/B,aAAA,KAAK,EAAE;AAEV,QAAA,UAAU,CAAC,WAAW,CAAC,MAAM;aAC1B,GAAG,CAAC,YAAY;AAChB,aAAA,MAAM,CACL,cAAc,CAAC,2BAA2B,CAAC,EAC3C,YAAY,CAAC,YAAY,EAAE,EAAE,CAAC;AAE/B,aAAA,KAAK,EAAE;;AAEb;AAED,OAAO,CAAC,UAAU,CAAC,WAAW,CAAC;;AChvB/B;AACA,WAAW,CAAC,UAAU,EAAE;AAQxB;;;;AAIG;AAEH;;;;;AAKG;AACI,MAAM,OAAO,GAAG;;;;"}
|
package/lib/adapter.cjs
CHANGED
|
@@ -622,10 +622,10 @@ class NanoAdapter extends for_couchdb_1.CouchDBAdapter {
|
|
|
622
622
|
.apply();
|
|
623
623
|
decorator_validation_1.Decoration.flavouredAs("nano")
|
|
624
624
|
.for(updatedByKey)
|
|
625
|
-
.define((0, db_decorators_1.
|
|
625
|
+
.define((0, db_decorators_1.onCreateUpdate)(createdByOnNanoCreateUpdate), (0, decorator_validation_1.propMetadata)(updatedByKey, {}))
|
|
626
626
|
.apply();
|
|
627
627
|
}
|
|
628
628
|
}
|
|
629
629
|
exports.NanoAdapter = NanoAdapter;
|
|
630
630
|
core_1.Adapter.setCurrent(constants_1.NanoFlavour);
|
|
631
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../src/adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ConflictError,\n  Context,\n  InternalError,\n  onCreate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  CreateIndexRequest,\n  generateIndexes,\n  MangoQuery,\n  MangoResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport Nano from \"nano\";\nimport {\n  DocumentBulkResponse,\n  DocumentGetResponse,\n  DocumentInsertResponse,\n  DocumentScope,\n  MaybeDocument,\n  ServerScope,\n} from \"nano\";\nimport {\n  Constructor,\n  Decoration,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport { NanoFlags } from \"./types\";\nimport {\n  Adapter,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { NanoFlavour } from \"./constants\";\nimport { NanoRepository } from \"./NanoRepository\";\nimport { NanoDispatch } from \"./NanoDispatch\";\n\n/**\n * @description Sets the creator or updater field in a model based on the user in the context\n * @summary Callback function used in decorators to automatically set the created_by or updated_by fields\n * with the username from the context when a document is created or updated\n * @template M - Type extending Model\n * @template R - Type extending NanoRepository<M>\n * @template V - Type extending RelationsMetadata\n * @param {R} this - The repository instance\n * @param {Context<NanoFlags>} context - The operation context containing user information\n * @param {V} data - The relation metadata\n * @param key - The property key to set with the username\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function createdByOnNanoCreateUpdate\n * @memberOf module:for-nano\n * @mermaid\n * sequenceDiagram\n *   participant F as createdByOnNanoCreateUpdate\n *   participant C as Context\n *   participant M as Model\n *   F->>C: get(\"user\")\n *   C-->>F: user object\n *   F->>M: set key to user.name\n *   Note over F: If no user in context\n *   F-->>F: throw UnsupportedError\n */\nexport async function createdByOnNanoCreateUpdate<\n  M extends Model,\n  R extends NanoRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<NanoFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"user\");\n    model[key] = user.name as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new UnsupportedError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Adapter for interacting with Nano databases\n * @summary Provides a standardized interface for performing CRUD operations on Nano databases,\n * extending the CouchDB adapter with Nano-specific functionality. This adapter handles document\n * creation, reading, updating, and deletion, as well as bulk operations and index management.\n * @template DocumentScope - The Nano document scope type\n * @template NanoFlags - Configuration flags for Nano operations\n * @template Context - Context type for operations\n * @param {DocumentScope<any>} scope - The Nano document scope to use for database operations\n * @param {string} [alias] - Optional alias for the adapter\n * @class NanoAdapter\n * @example\n * ```typescript\n * // Connect to a Nano database\n * const server = NanoAdapter.connect('admin', 'password', 'localhost:5984');\n * const db = server.db.use('my_database');\n *\n * // Create an adapter instance\n * const adapter = new NanoAdapter(db);\n *\n * // Use the adapter for database operations\n * const document = await adapter.read('users', '123');\n * ```\n * @mermaid\n * classDiagram\n *   class CouchDBAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +read()\n *     +update()\n *     +delete()\n *   }\n *   class NanoAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +createAll()\n *     +read()\n *     +readAll()\n *     +update()\n *     +updateAll()\n *     +delete()\n *     +deleteAll()\n *     +raw()\n *     +static connect()\n *     +static createDatabase()\n *     +static deleteDatabase()\n *     +static createUser()\n *     +static deleteUser()\n *     +static decoration()\n *   }\n *   CouchDBAdapter <|-- NanoAdapter\n */\nexport class NanoAdapter extends CouchDBAdapter<\n  DocumentScope<any>,\n  NanoFlags,\n  Context<NanoFlags>\n> {\n  constructor(scope: DocumentScope<any>, alias?: string) {\n    super(scope, NanoFlavour, alias);\n  }\n\n  /**\n   * @description Generates flags for database operations\n   * @summary Creates a set of flags for a specific operation, including user information\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation being performed (create, read, update, delete)\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<NanoFlags>} flags - Partial flags to be merged\n   * @return {Promise<NanoFlags>} Complete flags for the operation\n   */\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<NanoFlags>\n  ): Promise<NanoFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      user: {\n        name: this.native.config.url.split(\"@\")[0].split(\":\")[0],\n      },\n    }) as NanoFlags;\n  }\n\n  /**\n   * @description Creates a new NanoDispatch instance\n   * @summary Returns a dispatcher for handling Nano-specific operations\n   * @return {NanoDispatch} A new NanoDispatch instance\n   */\n  protected override Dispatch(): NanoDispatch {\n    return new NanoDispatch();\n  }\n\n  /**\n   * @description Creates database indexes for models\n   * @summary Generates and creates indexes in the Nano database based on the provided models\n   * @template M - Type extending Model\n   * @param models - Model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant G as generateIndexes\n   *   participant DB as Nano Database\n   *   A->>G: generateIndexes(models)\n   *   G-->>A: indexes\n   *   loop For each index\n   *     A->>DB: createIndex(index)\n   *     DB-->>A: response\n   *     Note over A: Check if index already exists\n   *     alt Index exists\n   *       A-->>A: throw ConflictError\n   *     end\n   *   end\n   */\n  protected override async index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  /**\n   * @description Creates a new document in the database\n   * @summary Inserts a new document into the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The document data to insert\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  /**\n   * @description Creates multiple documents in the database\n   * @summary Inserts multiple documents into the Nano database in a single bulk operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of document identifiers\n   * @param models - Array of document data to insert\n   * @return A promise that resolves to an array of created documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: bulk({docs: models})\n   *   alt Success\n   *     DB-->>A: response array\n   *     A->>A: Check if all responses have no errors\n   *     alt All OK\n   *       A->>A: assignMultipleMetadata(models, revs)\n   *       A-->>A: return documents with metadata\n   *     else Some errors\n   *       A->>A: Collect error messages\n   *       A-->>A: throw InternalError with collected messages\n   *     end\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  /**\n   * @description Retrieves a document from the database\n   * @summary Fetches a single document from the Nano database by its ID\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: generateId(tableName, id)\n   *   A->>DB: get(_id)\n   *   alt Success\n   *     DB-->>A: record\n   *     A->>A: assignMetadata(record, record._rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  /**\n   * @description Retrieves multiple documents from the database\n   * @summary Fetches multiple documents from the Nano database by their IDs in a single operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of document identifiers\n   * @return A promise that resolves to an array of retrieved documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: Map ids to generateId(tableName, id)\n   *   A->>DB: fetch({keys: mappedIds}, {})\n   *   DB-->>A: results\n   *   A->>A: Process each result row\n   *   loop For each row\n   *     alt Row has error\n   *       A-->>A: throw InternalError\n   *     else Row has document\n   *       A->>A: assignMetadata(doc, doc._rev)\n   *     else No document\n   *       A-->>A: throw InternalError\n   *     end\n   *   end\n   *   A-->>A: return documents with metadata\n   */\n  override async readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  /**\n   * @description Updates a document in the database\n   * @summary Updates an existing document in the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The updated document data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  override async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    const deletion: DocumentBulkResponse[] = await this.native.bulk({\n      docs: results.rows.map((r) => {\n        (r as any)[CouchDBKeys.DELETED] = true;\n        return r;\n      }),\n    });\n    deletion.forEach((d: DocumentBulkResponse) => {\n      if (d.error) console.error(d.error);\n    });\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  override async raw<R>(rawInput: MangoQuery, docsOnly = true): Promise<R> {\n    try {\n      const response: MangoResponse<R> = await this.native.find(rawInput);\n      if (response.warning) console.warn(response.warning);\n      if (docsOnly) return response.docs as R;\n      return response as R;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  static connect(\n    user: string,\n    pass: string,\n    host = \"localhost:5984\",\n    protocol: \"http\" | \"https\" = \"http\"\n  ): ServerScope {\n    return Nano(`${protocol}://${user}:${pass}@${host}`);\n  }\n\n  /**\n   * @description Creates a new database on the Nano server\n   * @summary Creates a new database with the specified name on the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to create\n   * @return {Promise<void>} A promise that resolves when the database is created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.create(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw parseError(error, reason)\n   *   end\n   */\n  static async createDatabase(con: ServerScope, name: string) {\n    let result: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.parseError(error as string, reason);\n  }\n\n  /**\n   * @description Deletes a database from the Nano server\n   * @summary Removes an existing database with the specified name from the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to delete\n   * @return {Promise<void>} A promise that resolves when the database is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.destroy(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async deleteDatabase(con: ServerScope, name: string) {\n    let result;\n    try {\n      result = await con.db.destroy(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok } = result;\n    if (!ok)\n      throw new InternalError(`Failed to delete database with name ${name}`);\n  }\n\n  /**\n   * @description Creates a new user and grants access to a database\n   * @summary Creates a new user in the Nano server and configures security to grant the user access to a specific database\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database to grant access to\n   * @param {string} user - The username to create\n   * @param {string} pass - The password for the new user\n   * @param {string[]} [roles=[\"reader\", \"writer\"]] - The roles to assign to the user\n   * @return {Promise<void>} A promise that resolves when the user is created and granted access\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   participant S as Security API\n   *   A->>A: Create user object\n   *   A->>U: insert(user)\n   *   alt Success\n   *     U-->>A: response with ok=true\n   *     A->>S: PUT _security with user permissions\n   *     alt Security Success\n   *       S-->>A: security response with ok=true\n   *     else Security Failure\n   *       S-->>A: security response with ok=false\n   *       A-->>A: throw InternalError\n   *     end\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     U-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async createUser(\n    con: ServerScope,\n    dbName: string,\n    user: string,\n    pass: string,\n    roles: string[] = [\"reader\", \"writer\"]\n  ) {\n    const users = con.db.use(\"_users\");\n    const usr = {\n      _id: \"org.couchdb.user:\" + user,\n      name: user,\n      password: pass,\n      roles: roles,\n      type: \"user\",\n    };\n    try {\n      const created: DocumentInsertResponse = await users.insert(\n        usr as MaybeDocument\n      );\n      const { ok } = created;\n      if (!ok) throw new InternalError(`Failed to create user ${user}`);\n      const security: any = await con.request({\n        db: dbName,\n        method: \"put\",\n        path: \"_security\",\n        // headers: {\n        //\n        // },\n        body: {\n          admins: {\n            names: [user],\n            roles: [],\n          },\n          members: {\n            names: [user],\n            roles: roles,\n          },\n        },\n      });\n      if (!security.ok)\n        throw new InternalError(\n          `Failed to authorize user ${user} to db ${dbName}`\n        );\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Deletes a user from the Nano server\n   * @summary Removes an existing user from the Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database (used for logging purposes)\n   * @param {string} user - The username to delete\n   * @return {Promise<void>} A promise that resolves when the user is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   A->>A: Generate user ID\n   *   A->>U: get(id)\n   *   U-->>A: user document\n   *   A->>U: destroy(id, user._rev)\n   *   alt Success\n   *     U-->>A: success response\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = con.db.use(\"_users\");\n    const id = \"org.couchdb.user:\" + user;\n    try {\n      const usr = await users.get(id);\n      await users.destroy(id, usr._rev);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Sets up decorations for Nano-specific model properties\n   * @summary Configures decorators for created_by and updated_by fields in models to be automatically\n   * populated with the user from the context when documents are created or updated\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant D as Decoration\n   *   participant R as Repository\n   *   A->>R: key(PersistenceKeys.CREATED_BY)\n   *   R-->>A: createdByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(createdByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   *   A->>R: key(PersistenceKeys.UPDATED_BY)\n   *   R-->>A: updatedByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(updatedByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   */\n  static override decoration() {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(\"nano\")\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n\n    Decoration.flavouredAs(\"nano\")\n      .for(updatedByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n}\n\nAdapter.setCurrent(NanoFlavour);\n"]}
|
|
631
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../src/adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ConflictError,\n  Context,\n  InternalError,\n  onCreate,\n  onCreateUpdate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  CreateIndexRequest,\n  generateIndexes,\n  MangoQuery,\n  MangoResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport Nano from \"nano\";\nimport {\n  DocumentBulkResponse,\n  DocumentGetResponse,\n  DocumentInsertResponse,\n  DocumentScope,\n  MaybeDocument,\n  ServerScope,\n} from \"nano\";\nimport {\n  Constructor,\n  Decoration,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport { NanoFlags } from \"./types\";\nimport {\n  Adapter,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { NanoFlavour } from \"./constants\";\nimport { NanoRepository } from \"./NanoRepository\";\nimport { NanoDispatch } from \"./NanoDispatch\";\n\n/**\n * @description Sets the creator or updater field in a model based on the user in the context\n * @summary Callback function used in decorators to automatically set the created_by or updated_by fields\n * with the username from the context when a document is created or updated\n * @template M - Type extending Model\n * @template R - Type extending NanoRepository<M>\n * @template V - Type extending RelationsMetadata\n * @param {R} this - The repository instance\n * @param {Context<NanoFlags>} context - The operation context containing user information\n * @param {V} data - The relation metadata\n * @param key - The property key to set with the username\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function createdByOnNanoCreateUpdate\n * @memberOf module:for-nano\n * @mermaid\n * sequenceDiagram\n *   participant F as createdByOnNanoCreateUpdate\n *   participant C as Context\n *   participant M as Model\n *   F->>C: get(\"user\")\n *   C-->>F: user object\n *   F->>M: set key to user.name\n *   Note over F: If no user in context\n *   F-->>F: throw UnsupportedError\n */\nexport async function createdByOnNanoCreateUpdate<\n  M extends Model,\n  R extends NanoRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<NanoFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"user\");\n    model[key] = user.name as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new UnsupportedError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Adapter for interacting with Nano databases\n * @summary Provides a standardized interface for performing CRUD operations on Nano databases,\n * extending the CouchDB adapter with Nano-specific functionality. This adapter handles document\n * creation, reading, updating, and deletion, as well as bulk operations and index management.\n * @template DocumentScope - The Nano document scope type\n * @template NanoFlags - Configuration flags for Nano operations\n * @template Context - Context type for operations\n * @param {DocumentScope<any>} scope - The Nano document scope to use for database operations\n * @param {string} [alias] - Optional alias for the adapter\n * @class NanoAdapter\n * @example\n * ```typescript\n * // Connect to a Nano database\n * const server = NanoAdapter.connect('admin', 'password', 'localhost:5984');\n * const db = server.db.use('my_database');\n *\n * // Create an adapter instance\n * const adapter = new NanoAdapter(db);\n *\n * // Use the adapter for database operations\n * const document = await adapter.read('users', '123');\n * ```\n * @mermaid\n * classDiagram\n *   class CouchDBAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +read()\n *     +update()\n *     +delete()\n *   }\n *   class NanoAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +createAll()\n *     +read()\n *     +readAll()\n *     +update()\n *     +updateAll()\n *     +delete()\n *     +deleteAll()\n *     +raw()\n *     +static connect()\n *     +static createDatabase()\n *     +static deleteDatabase()\n *     +static createUser()\n *     +static deleteUser()\n *     +static decoration()\n *   }\n *   CouchDBAdapter <|-- NanoAdapter\n */\nexport class NanoAdapter extends CouchDBAdapter<\n  DocumentScope<any>,\n  NanoFlags,\n  Context<NanoFlags>\n> {\n  constructor(scope: DocumentScope<any>, alias?: string) {\n    super(scope, NanoFlavour, alias);\n  }\n\n  /**\n   * @description Generates flags for database operations\n   * @summary Creates a set of flags for a specific operation, including user information\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation being performed (create, read, update, delete)\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<NanoFlags>} flags - Partial flags to be merged\n   * @return {Promise<NanoFlags>} Complete flags for the operation\n   */\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<NanoFlags>\n  ): Promise<NanoFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      user: {\n        name: this.native.config.url.split(\"@\")[0].split(\":\")[0],\n      },\n    }) as NanoFlags;\n  }\n\n  /**\n   * @description Creates a new NanoDispatch instance\n   * @summary Returns a dispatcher for handling Nano-specific operations\n   * @return {NanoDispatch} A new NanoDispatch instance\n   */\n  protected override Dispatch(): NanoDispatch {\n    return new NanoDispatch();\n  }\n\n  /**\n   * @description Creates database indexes for models\n   * @summary Generates and creates indexes in the Nano database based on the provided models\n   * @template M - Type extending Model\n   * @param models - Model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant G as generateIndexes\n   *   participant DB as Nano Database\n   *   A->>G: generateIndexes(models)\n   *   G-->>A: indexes\n   *   loop For each index\n   *     A->>DB: createIndex(index)\n   *     DB-->>A: response\n   *     Note over A: Check if index already exists\n   *     alt Index exists\n   *       A-->>A: throw ConflictError\n   *     end\n   *   end\n   */\n  protected override async index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  /**\n   * @description Creates a new document in the database\n   * @summary Inserts a new document into the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The document data to insert\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  /**\n   * @description Creates multiple documents in the database\n   * @summary Inserts multiple documents into the Nano database in a single bulk operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of document identifiers\n   * @param models - Array of document data to insert\n   * @return A promise that resolves to an array of created documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: bulk({docs: models})\n   *   alt Success\n   *     DB-->>A: response array\n   *     A->>A: Check if all responses have no errors\n   *     alt All OK\n   *       A->>A: assignMultipleMetadata(models, revs)\n   *       A-->>A: return documents with metadata\n   *     else Some errors\n   *       A->>A: Collect error messages\n   *       A-->>A: throw InternalError with collected messages\n   *     end\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  /**\n   * @description Retrieves a document from the database\n   * @summary Fetches a single document from the Nano database by its ID\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: generateId(tableName, id)\n   *   A->>DB: get(_id)\n   *   alt Success\n   *     DB-->>A: record\n   *     A->>A: assignMetadata(record, record._rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  /**\n   * @description Retrieves multiple documents from the database\n   * @summary Fetches multiple documents from the Nano database by their IDs in a single operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of document identifiers\n   * @return A promise that resolves to an array of retrieved documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: Map ids to generateId(tableName, id)\n   *   A->>DB: fetch({keys: mappedIds}, {})\n   *   DB-->>A: results\n   *   A->>A: Process each result row\n   *   loop For each row\n   *     alt Row has error\n   *       A-->>A: throw InternalError\n   *     else Row has document\n   *       A->>A: assignMetadata(doc, doc._rev)\n   *     else No document\n   *       A-->>A: throw InternalError\n   *     end\n   *   end\n   *   A-->>A: return documents with metadata\n   */\n  override async readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  /**\n   * @description Updates a document in the database\n   * @summary Updates an existing document in the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The updated document data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  override async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    const deletion: DocumentBulkResponse[] = await this.native.bulk({\n      docs: results.rows.map((r) => {\n        (r as any)[CouchDBKeys.DELETED] = true;\n        return r;\n      }),\n    });\n    deletion.forEach((d: DocumentBulkResponse) => {\n      if (d.error) console.error(d.error);\n    });\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  override async raw<R>(rawInput: MangoQuery, docsOnly = true): Promise<R> {\n    try {\n      const response: MangoResponse<R> = await this.native.find(rawInput);\n      if (response.warning) console.warn(response.warning);\n      if (docsOnly) return response.docs as R;\n      return response as R;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  static connect(\n    user: string,\n    pass: string,\n    host = \"localhost:5984\",\n    protocol: \"http\" | \"https\" = \"http\"\n  ): ServerScope {\n    return Nano(`${protocol}://${user}:${pass}@${host}`);\n  }\n\n  /**\n   * @description Creates a new database on the Nano server\n   * @summary Creates a new database with the specified name on the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to create\n   * @return {Promise<void>} A promise that resolves when the database is created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.create(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw parseError(error, reason)\n   *   end\n   */\n  static async createDatabase(con: ServerScope, name: string) {\n    let result: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.parseError(error as string, reason);\n  }\n\n  /**\n   * @description Deletes a database from the Nano server\n   * @summary Removes an existing database with the specified name from the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to delete\n   * @return {Promise<void>} A promise that resolves when the database is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.destroy(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async deleteDatabase(con: ServerScope, name: string) {\n    let result;\n    try {\n      result = await con.db.destroy(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok } = result;\n    if (!ok)\n      throw new InternalError(`Failed to delete database with name ${name}`);\n  }\n\n  /**\n   * @description Creates a new user and grants access to a database\n   * @summary Creates a new user in the Nano server and configures security to grant the user access to a specific database\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database to grant access to\n   * @param {string} user - The username to create\n   * @param {string} pass - The password for the new user\n   * @param {string[]} [roles=[\"reader\", \"writer\"]] - The roles to assign to the user\n   * @return {Promise<void>} A promise that resolves when the user is created and granted access\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   participant S as Security API\n   *   A->>A: Create user object\n   *   A->>U: insert(user)\n   *   alt Success\n   *     U-->>A: response with ok=true\n   *     A->>S: PUT _security with user permissions\n   *     alt Security Success\n   *       S-->>A: security response with ok=true\n   *     else Security Failure\n   *       S-->>A: security response with ok=false\n   *       A-->>A: throw InternalError\n   *     end\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     U-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async createUser(\n    con: ServerScope,\n    dbName: string,\n    user: string,\n    pass: string,\n    roles: string[] = [\"reader\", \"writer\"]\n  ) {\n    const users = con.db.use(\"_users\");\n    const usr = {\n      _id: \"org.couchdb.user:\" + user,\n      name: user,\n      password: pass,\n      roles: roles,\n      type: \"user\",\n    };\n    try {\n      const created: DocumentInsertResponse = await users.insert(\n        usr as MaybeDocument\n      );\n      const { ok } = created;\n      if (!ok) throw new InternalError(`Failed to create user ${user}`);\n      const security: any = await con.request({\n        db: dbName,\n        method: \"put\",\n        path: \"_security\",\n        // headers: {\n        //\n        // },\n        body: {\n          admins: {\n            names: [user],\n            roles: [],\n          },\n          members: {\n            names: [user],\n            roles: roles,\n          },\n        },\n      });\n      if (!security.ok)\n        throw new InternalError(\n          `Failed to authorize user ${user} to db ${dbName}`\n        );\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Deletes a user from the Nano server\n   * @summary Removes an existing user from the Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database (used for logging purposes)\n   * @param {string} user - The username to delete\n   * @return {Promise<void>} A promise that resolves when the user is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   A->>A: Generate user ID\n   *   A->>U: get(id)\n   *   U-->>A: user document\n   *   A->>U: destroy(id, user._rev)\n   *   alt Success\n   *     U-->>A: success response\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = con.db.use(\"_users\");\n    const id = \"org.couchdb.user:\" + user;\n    try {\n      const usr = await users.get(id);\n      await users.destroy(id, usr._rev);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Sets up decorations for Nano-specific model properties\n   * @summary Configures decorators for created_by and updated_by fields in models to be automatically\n   * populated with the user from the context when documents are created or updated\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant D as Decoration\n   *   participant R as Repository\n   *   A->>R: key(PersistenceKeys.CREATED_BY)\n   *   R-->>A: createdByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(createdByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   *   A->>R: key(PersistenceKeys.UPDATED_BY)\n   *   R-->>A: updatedByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(updatedByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   */\n  static override decoration() {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(\"nano\")\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n\n    Decoration.flavouredAs(\"nano\")\n      .for(updatedByKey)\n      .define(\n        onCreateUpdate(createdByOnNanoCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n}\n\nAdapter.setCurrent(NanoFlavour);\n"]}
|
package/lib/esm/adapter.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ConflictError, InternalError, onCreate, } from "@decaf-ts/db-decorators";
|
|
1
|
+
import { ConflictError, InternalError, onCreate, onCreateUpdate, } from "@decaf-ts/db-decorators";
|
|
2
2
|
import "reflect-metadata";
|
|
3
3
|
import { CouchDBAdapter, CouchDBKeys, generateIndexes, } from "@decaf-ts/for-couchdb";
|
|
4
4
|
import Nano from "nano";
|
|
@@ -615,9 +615,9 @@ export class NanoAdapter extends CouchDBAdapter {
|
|
|
615
615
|
.apply();
|
|
616
616
|
Decoration.flavouredAs("nano")
|
|
617
617
|
.for(updatedByKey)
|
|
618
|
-
.define(
|
|
618
|
+
.define(onCreateUpdate(createdByOnNanoCreateUpdate), propMetadata(updatedByKey, {}))
|
|
619
619
|
.apply();
|
|
620
620
|
}
|
|
621
621
|
}
|
|
622
622
|
Adapter.setCurrent(NanoFlavour);
|
|
623
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../src/adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ConflictError,\n  Context,\n  InternalError,\n  onCreate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  CreateIndexRequest,\n  generateIndexes,\n  MangoQuery,\n  MangoResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport Nano from \"nano\";\nimport {\n  DocumentBulkResponse,\n  DocumentGetResponse,\n  DocumentInsertResponse,\n  DocumentScope,\n  MaybeDocument,\n  ServerScope,\n} from \"nano\";\nimport {\n  Constructor,\n  Decoration,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport { NanoFlags } from \"./types\";\nimport {\n  Adapter,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { NanoFlavour } from \"./constants\";\nimport { NanoRepository } from \"./NanoRepository\";\nimport { NanoDispatch } from \"./NanoDispatch\";\n\n/**\n * @description Sets the creator or updater field in a model based on the user in the context\n * @summary Callback function used in decorators to automatically set the created_by or updated_by fields\n * with the username from the context when a document is created or updated\n * @template M - Type extending Model\n * @template R - Type extending NanoRepository<M>\n * @template V - Type extending RelationsMetadata\n * @param {R} this - The repository instance\n * @param {Context<NanoFlags>} context - The operation context containing user information\n * @param {V} data - The relation metadata\n * @param key - The property key to set with the username\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function createdByOnNanoCreateUpdate\n * @memberOf module:for-nano\n * @mermaid\n * sequenceDiagram\n *   participant F as createdByOnNanoCreateUpdate\n *   participant C as Context\n *   participant M as Model\n *   F->>C: get(\"user\")\n *   C-->>F: user object\n *   F->>M: set key to user.name\n *   Note over F: If no user in context\n *   F-->>F: throw UnsupportedError\n */\nexport async function createdByOnNanoCreateUpdate<\n  M extends Model,\n  R extends NanoRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<NanoFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"user\");\n    model[key] = user.name as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new UnsupportedError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Adapter for interacting with Nano databases\n * @summary Provides a standardized interface for performing CRUD operations on Nano databases,\n * extending the CouchDB adapter with Nano-specific functionality. This adapter handles document\n * creation, reading, updating, and deletion, as well as bulk operations and index management.\n * @template DocumentScope - The Nano document scope type\n * @template NanoFlags - Configuration flags for Nano operations\n * @template Context - Context type for operations\n * @param {DocumentScope<any>} scope - The Nano document scope to use for database operations\n * @param {string} [alias] - Optional alias for the adapter\n * @class NanoAdapter\n * @example\n * ```typescript\n * // Connect to a Nano database\n * const server = NanoAdapter.connect('admin', 'password', 'localhost:5984');\n * const db = server.db.use('my_database');\n *\n * // Create an adapter instance\n * const adapter = new NanoAdapter(db);\n *\n * // Use the adapter for database operations\n * const document = await adapter.read('users', '123');\n * ```\n * @mermaid\n * classDiagram\n *   class CouchDBAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +read()\n *     +update()\n *     +delete()\n *   }\n *   class NanoAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +createAll()\n *     +read()\n *     +readAll()\n *     +update()\n *     +updateAll()\n *     +delete()\n *     +deleteAll()\n *     +raw()\n *     +static connect()\n *     +static createDatabase()\n *     +static deleteDatabase()\n *     +static createUser()\n *     +static deleteUser()\n *     +static decoration()\n *   }\n *   CouchDBAdapter <|-- NanoAdapter\n */\nexport class NanoAdapter extends CouchDBAdapter<\n  DocumentScope<any>,\n  NanoFlags,\n  Context<NanoFlags>\n> {\n  constructor(scope: DocumentScope<any>, alias?: string) {\n    super(scope, NanoFlavour, alias);\n  }\n\n  /**\n   * @description Generates flags for database operations\n   * @summary Creates a set of flags for a specific operation, including user information\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation being performed (create, read, update, delete)\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<NanoFlags>} flags - Partial flags to be merged\n   * @return {Promise<NanoFlags>} Complete flags for the operation\n   */\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<NanoFlags>\n  ): Promise<NanoFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      user: {\n        name: this.native.config.url.split(\"@\")[0].split(\":\")[0],\n      },\n    }) as NanoFlags;\n  }\n\n  /**\n   * @description Creates a new NanoDispatch instance\n   * @summary Returns a dispatcher for handling Nano-specific operations\n   * @return {NanoDispatch} A new NanoDispatch instance\n   */\n  protected override Dispatch(): NanoDispatch {\n    return new NanoDispatch();\n  }\n\n  /**\n   * @description Creates database indexes for models\n   * @summary Generates and creates indexes in the Nano database based on the provided models\n   * @template M - Type extending Model\n   * @param models - Model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant G as generateIndexes\n   *   participant DB as Nano Database\n   *   A->>G: generateIndexes(models)\n   *   G-->>A: indexes\n   *   loop For each index\n   *     A->>DB: createIndex(index)\n   *     DB-->>A: response\n   *     Note over A: Check if index already exists\n   *     alt Index exists\n   *       A-->>A: throw ConflictError\n   *     end\n   *   end\n   */\n  protected override async index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  /**\n   * @description Creates a new document in the database\n   * @summary Inserts a new document into the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The document data to insert\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  /**\n   * @description Creates multiple documents in the database\n   * @summary Inserts multiple documents into the Nano database in a single bulk operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of document identifiers\n   * @param models - Array of document data to insert\n   * @return A promise that resolves to an array of created documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: bulk({docs: models})\n   *   alt Success\n   *     DB-->>A: response array\n   *     A->>A: Check if all responses have no errors\n   *     alt All OK\n   *       A->>A: assignMultipleMetadata(models, revs)\n   *       A-->>A: return documents with metadata\n   *     else Some errors\n   *       A->>A: Collect error messages\n   *       A-->>A: throw InternalError with collected messages\n   *     end\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  /**\n   * @description Retrieves a document from the database\n   * @summary Fetches a single document from the Nano database by its ID\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: generateId(tableName, id)\n   *   A->>DB: get(_id)\n   *   alt Success\n   *     DB-->>A: record\n   *     A->>A: assignMetadata(record, record._rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  /**\n   * @description Retrieves multiple documents from the database\n   * @summary Fetches multiple documents from the Nano database by their IDs in a single operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of document identifiers\n   * @return A promise that resolves to an array of retrieved documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: Map ids to generateId(tableName, id)\n   *   A->>DB: fetch({keys: mappedIds}, {})\n   *   DB-->>A: results\n   *   A->>A: Process each result row\n   *   loop For each row\n   *     alt Row has error\n   *       A-->>A: throw InternalError\n   *     else Row has document\n   *       A->>A: assignMetadata(doc, doc._rev)\n   *     else No document\n   *       A-->>A: throw InternalError\n   *     end\n   *   end\n   *   A-->>A: return documents with metadata\n   */\n  override async readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  /**\n   * @description Updates a document in the database\n   * @summary Updates an existing document in the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The updated document data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  override async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    const deletion: DocumentBulkResponse[] = await this.native.bulk({\n      docs: results.rows.map((r) => {\n        (r as any)[CouchDBKeys.DELETED] = true;\n        return r;\n      }),\n    });\n    deletion.forEach((d: DocumentBulkResponse) => {\n      if (d.error) console.error(d.error);\n    });\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  override async raw<R>(rawInput: MangoQuery, docsOnly = true): Promise<R> {\n    try {\n      const response: MangoResponse<R> = await this.native.find(rawInput);\n      if (response.warning) console.warn(response.warning);\n      if (docsOnly) return response.docs as R;\n      return response as R;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  static connect(\n    user: string,\n    pass: string,\n    host = \"localhost:5984\",\n    protocol: \"http\" | \"https\" = \"http\"\n  ): ServerScope {\n    return Nano(`${protocol}://${user}:${pass}@${host}`);\n  }\n\n  /**\n   * @description Creates a new database on the Nano server\n   * @summary Creates a new database with the specified name on the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to create\n   * @return {Promise<void>} A promise that resolves when the database is created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.create(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw parseError(error, reason)\n   *   end\n   */\n  static async createDatabase(con: ServerScope, name: string) {\n    let result: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.parseError(error as string, reason);\n  }\n\n  /**\n   * @description Deletes a database from the Nano server\n   * @summary Removes an existing database with the specified name from the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to delete\n   * @return {Promise<void>} A promise that resolves when the database is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.destroy(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async deleteDatabase(con: ServerScope, name: string) {\n    let result;\n    try {\n      result = await con.db.destroy(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok } = result;\n    if (!ok)\n      throw new InternalError(`Failed to delete database with name ${name}`);\n  }\n\n  /**\n   * @description Creates a new user and grants access to a database\n   * @summary Creates a new user in the Nano server and configures security to grant the user access to a specific database\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database to grant access to\n   * @param {string} user - The username to create\n   * @param {string} pass - The password for the new user\n   * @param {string[]} [roles=[\"reader\", \"writer\"]] - The roles to assign to the user\n   * @return {Promise<void>} A promise that resolves when the user is created and granted access\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   participant S as Security API\n   *   A->>A: Create user object\n   *   A->>U: insert(user)\n   *   alt Success\n   *     U-->>A: response with ok=true\n   *     A->>S: PUT _security with user permissions\n   *     alt Security Success\n   *       S-->>A: security response with ok=true\n   *     else Security Failure\n   *       S-->>A: security response with ok=false\n   *       A-->>A: throw InternalError\n   *     end\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     U-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async createUser(\n    con: ServerScope,\n    dbName: string,\n    user: string,\n    pass: string,\n    roles: string[] = [\"reader\", \"writer\"]\n  ) {\n    const users = con.db.use(\"_users\");\n    const usr = {\n      _id: \"org.couchdb.user:\" + user,\n      name: user,\n      password: pass,\n      roles: roles,\n      type: \"user\",\n    };\n    try {\n      const created: DocumentInsertResponse = await users.insert(\n        usr as MaybeDocument\n      );\n      const { ok } = created;\n      if (!ok) throw new InternalError(`Failed to create user ${user}`);\n      const security: any = await con.request({\n        db: dbName,\n        method: \"put\",\n        path: \"_security\",\n        // headers: {\n        //\n        // },\n        body: {\n          admins: {\n            names: [user],\n            roles: [],\n          },\n          members: {\n            names: [user],\n            roles: roles,\n          },\n        },\n      });\n      if (!security.ok)\n        throw new InternalError(\n          `Failed to authorize user ${user} to db ${dbName}`\n        );\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Deletes a user from the Nano server\n   * @summary Removes an existing user from the Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database (used for logging purposes)\n   * @param {string} user - The username to delete\n   * @return {Promise<void>} A promise that resolves when the user is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   A->>A: Generate user ID\n   *   A->>U: get(id)\n   *   U-->>A: user document\n   *   A->>U: destroy(id, user._rev)\n   *   alt Success\n   *     U-->>A: success response\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = con.db.use(\"_users\");\n    const id = \"org.couchdb.user:\" + user;\n    try {\n      const usr = await users.get(id);\n      await users.destroy(id, usr._rev);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Sets up decorations for Nano-specific model properties\n   * @summary Configures decorators for created_by and updated_by fields in models to be automatically\n   * populated with the user from the context when documents are created or updated\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant D as Decoration\n   *   participant R as Repository\n   *   A->>R: key(PersistenceKeys.CREATED_BY)\n   *   R-->>A: createdByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(createdByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   *   A->>R: key(PersistenceKeys.UPDATED_BY)\n   *   R-->>A: updatedByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(updatedByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   */\n  static override decoration() {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(\"nano\")\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n\n    Decoration.flavouredAs(\"nano\")\n      .for(updatedByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n}\n\nAdapter.setCurrent(NanoFlavour);\n"]}
|
|
623
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../src/adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ConflictError,\n  Context,\n  InternalError,\n  onCreate,\n  onCreateUpdate,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  CreateIndexRequest,\n  generateIndexes,\n  MangoQuery,\n  MangoResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport Nano from \"nano\";\nimport {\n  DocumentBulkResponse,\n  DocumentGetResponse,\n  DocumentInsertResponse,\n  DocumentScope,\n  MaybeDocument,\n  ServerScope,\n} from \"nano\";\nimport {\n  Constructor,\n  Decoration,\n  Model,\n  propMetadata,\n} from \"@decaf-ts/decorator-validation\";\nimport { NanoFlags } from \"./types\";\nimport {\n  Adapter,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { NanoFlavour } from \"./constants\";\nimport { NanoRepository } from \"./NanoRepository\";\nimport { NanoDispatch } from \"./NanoDispatch\";\n\n/**\n * @description Sets the creator or updater field in a model based on the user in the context\n * @summary Callback function used in decorators to automatically set the created_by or updated_by fields\n * with the username from the context when a document is created or updated\n * @template M - Type extending Model\n * @template R - Type extending NanoRepository<M>\n * @template V - Type extending RelationsMetadata\n * @param {R} this - The repository instance\n * @param {Context<NanoFlags>} context - The operation context containing user information\n * @param {V} data - The relation metadata\n * @param key - The property key to set with the username\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function createdByOnNanoCreateUpdate\n * @memberOf module:for-nano\n * @mermaid\n * sequenceDiagram\n *   participant F as createdByOnNanoCreateUpdate\n *   participant C as Context\n *   participant M as Model\n *   F->>C: get(\"user\")\n *   C-->>F: user object\n *   F->>M: set key to user.name\n *   Note over F: If no user in context\n *   F-->>F: throw UnsupportedError\n */\nexport async function createdByOnNanoCreateUpdate<\n  M extends Model,\n  R extends NanoRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<NanoFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"user\");\n    model[key] = user.name as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new UnsupportedError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Adapter for interacting with Nano databases\n * @summary Provides a standardized interface for performing CRUD operations on Nano databases,\n * extending the CouchDB adapter with Nano-specific functionality. This adapter handles document\n * creation, reading, updating, and deletion, as well as bulk operations and index management.\n * @template DocumentScope - The Nano document scope type\n * @template NanoFlags - Configuration flags for Nano operations\n * @template Context - Context type for operations\n * @param {DocumentScope<any>} scope - The Nano document scope to use for database operations\n * @param {string} [alias] - Optional alias for the adapter\n * @class NanoAdapter\n * @example\n * ```typescript\n * // Connect to a Nano database\n * const server = NanoAdapter.connect('admin', 'password', 'localhost:5984');\n * const db = server.db.use('my_database');\n *\n * // Create an adapter instance\n * const adapter = new NanoAdapter(db);\n *\n * // Use the adapter for database operations\n * const document = await adapter.read('users', '123');\n * ```\n * @mermaid\n * classDiagram\n *   class CouchDBAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +read()\n *     +update()\n *     +delete()\n *   }\n *   class NanoAdapter {\n *     +flags()\n *     +Dispatch()\n *     +index()\n *     +create()\n *     +createAll()\n *     +read()\n *     +readAll()\n *     +update()\n *     +updateAll()\n *     +delete()\n *     +deleteAll()\n *     +raw()\n *     +static connect()\n *     +static createDatabase()\n *     +static deleteDatabase()\n *     +static createUser()\n *     +static deleteUser()\n *     +static decoration()\n *   }\n *   CouchDBAdapter <|-- NanoAdapter\n */\nexport class NanoAdapter extends CouchDBAdapter<\n  DocumentScope<any>,\n  NanoFlags,\n  Context<NanoFlags>\n> {\n  constructor(scope: DocumentScope<any>, alias?: string) {\n    super(scope, NanoFlavour, alias);\n  }\n\n  /**\n   * @description Generates flags for database operations\n   * @summary Creates a set of flags for a specific operation, including user information\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation being performed (create, read, update, delete)\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<NanoFlags>} flags - Partial flags to be merged\n   * @return {Promise<NanoFlags>} Complete flags for the operation\n   */\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<NanoFlags>\n  ): Promise<NanoFlags> {\n    return Object.assign(await super.flags(operation, model, flags), {\n      user: {\n        name: this.native.config.url.split(\"@\")[0].split(\":\")[0],\n      },\n    }) as NanoFlags;\n  }\n\n  /**\n   * @description Creates a new NanoDispatch instance\n   * @summary Returns a dispatcher for handling Nano-specific operations\n   * @return {NanoDispatch} A new NanoDispatch instance\n   */\n  protected override Dispatch(): NanoDispatch {\n    return new NanoDispatch();\n  }\n\n  /**\n   * @description Creates database indexes for models\n   * @summary Generates and creates indexes in the Nano database based on the provided models\n   * @template M - Type extending Model\n   * @param models - Model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant G as generateIndexes\n   *   participant DB as Nano Database\n   *   A->>G: generateIndexes(models)\n   *   G-->>A: indexes\n   *   loop For each index\n   *     A->>DB: createIndex(index)\n   *     DB-->>A: response\n   *     Note over A: Check if index already exists\n   *     alt Index exists\n   *       A-->>A: throw ConflictError\n   *     end\n   *   end\n   */\n  protected override async index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  /**\n   * @description Creates a new document in the database\n   * @summary Inserts a new document into the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The document data to insert\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  /**\n   * @description Creates multiple documents in the database\n   * @summary Inserts multiple documents into the Nano database in a single bulk operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of document identifiers\n   * @param models - Array of document data to insert\n   * @return A promise that resolves to an array of created documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: bulk({docs: models})\n   *   alt Success\n   *     DB-->>A: response array\n   *     A->>A: Check if all responses have no errors\n   *     alt All OK\n   *       A->>A: assignMultipleMetadata(models, revs)\n   *       A-->>A: return documents with metadata\n   *     else Some errors\n   *       A->>A: Collect error messages\n   *       A-->>A: throw InternalError with collected messages\n   *     end\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  /**\n   * @description Retrieves a document from the database\n   * @summary Fetches a single document from the Nano database by its ID\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @return {Promise<Record<string, any>>} A promise that resolves to the retrieved document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: generateId(tableName, id)\n   *   A->>DB: get(_id)\n   *   alt Success\n   *     DB-->>A: record\n   *     A->>A: assignMetadata(record, record._rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  override async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  /**\n   * @description Retrieves multiple documents from the database\n   * @summary Fetches multiple documents from the Nano database by their IDs in a single operation\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of document identifiers\n   * @return A promise that resolves to an array of retrieved documents with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>A: Map ids to generateId(tableName, id)\n   *   A->>DB: fetch({keys: mappedIds}, {})\n   *   DB-->>A: results\n   *   A->>A: Process each result row\n   *   loop For each row\n   *     alt Row has error\n   *       A-->>A: throw InternalError\n   *     else Row has document\n   *       A->>A: assignMetadata(doc, doc._rev)\n   *     else No document\n   *       A-->>A: throw InternalError\n   *     end\n   *   end\n   *   A-->>A: return documents with metadata\n   */\n  override async readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  /**\n   * @description Updates a document in the database\n   * @summary Updates an existing document in the Nano database with the provided data\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The document identifier\n   * @param {Record<string, any>} model - The updated document data\n   * @return {Promise<Record<string, any>>} A promise that resolves to the updated document with metadata\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Database\n   *   A->>DB: insert(model)\n   *   alt Success\n   *     DB-->>A: response with ok=true\n   *     A->>A: assignMetadata(model, response.rev)\n   *     A-->>A: return document with metadata\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    return this.assignMetadata(model, response.rev);\n  }\n\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: models });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    return this.assignMultipleMetadata(\n      models,\n      response.map((r) => r.rev as string)\n    );\n  }\n\n  override async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return this.assignMetadata(record, record._rev);\n  }\n\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    const deletion: DocumentBulkResponse[] = await this.native.bulk({\n      docs: results.rows.map((r) => {\n        (r as any)[CouchDBKeys.DELETED] = true;\n        return r;\n      }),\n    });\n    deletion.forEach((d: DocumentBulkResponse) => {\n      if (d.error) console.error(d.error);\n    });\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        return this.assignMetadata(res, (r as any).doc[CouchDBKeys.REV]);\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  override async raw<R>(rawInput: MangoQuery, docsOnly = true): Promise<R> {\n    try {\n      const response: MangoResponse<R> = await this.native.find(rawInput);\n      if (response.warning) console.warn(response.warning);\n      if (docsOnly) return response.docs as R;\n      return response as R;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  static connect(\n    user: string,\n    pass: string,\n    host = \"localhost:5984\",\n    protocol: \"http\" | \"https\" = \"http\"\n  ): ServerScope {\n    return Nano(`${protocol}://${user}:${pass}@${host}`);\n  }\n\n  /**\n   * @description Creates a new database on the Nano server\n   * @summary Creates a new database with the specified name on the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to create\n   * @return {Promise<void>} A promise that resolves when the database is created\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.create(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw parseError(error, reason)\n   *   end\n   */\n  static async createDatabase(con: ServerScope, name: string) {\n    let result: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.parseError(error as string, reason);\n  }\n\n  /**\n   * @description Deletes a database from the Nano server\n   * @summary Removes an existing database with the specified name from the connected Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} name - The name of the database to delete\n   * @return {Promise<void>} A promise that resolves when the database is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant DB as Nano Server\n   *   A->>DB: db.destroy(name)\n   *   alt Success\n   *     DB-->>A: result with ok=true\n   *   else Error\n   *     DB-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     DB-->>A: result with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async deleteDatabase(con: ServerScope, name: string) {\n    let result;\n    try {\n      result = await con.db.destroy(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok } = result;\n    if (!ok)\n      throw new InternalError(`Failed to delete database with name ${name}`);\n  }\n\n  /**\n   * @description Creates a new user and grants access to a database\n   * @summary Creates a new user in the Nano server and configures security to grant the user access to a specific database\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database to grant access to\n   * @param {string} user - The username to create\n   * @param {string} pass - The password for the new user\n   * @param {string[]} [roles=[\"reader\", \"writer\"]] - The roles to assign to the user\n   * @return {Promise<void>} A promise that resolves when the user is created and granted access\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   participant S as Security API\n   *   A->>A: Create user object\n   *   A->>U: insert(user)\n   *   alt Success\n   *     U-->>A: response with ok=true\n   *     A->>S: PUT _security with user permissions\n   *     alt Security Success\n   *       S-->>A: security response with ok=true\n   *     else Security Failure\n   *       S-->>A: security response with ok=false\n   *       A-->>A: throw InternalError\n   *     end\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   else Not OK\n   *     U-->>A: response with ok=false\n   *     A-->>A: throw InternalError\n   *   end\n   */\n  static async createUser(\n    con: ServerScope,\n    dbName: string,\n    user: string,\n    pass: string,\n    roles: string[] = [\"reader\", \"writer\"]\n  ) {\n    const users = con.db.use(\"_users\");\n    const usr = {\n      _id: \"org.couchdb.user:\" + user,\n      name: user,\n      password: pass,\n      roles: roles,\n      type: \"user\",\n    };\n    try {\n      const created: DocumentInsertResponse = await users.insert(\n        usr as MaybeDocument\n      );\n      const { ok } = created;\n      if (!ok) throw new InternalError(`Failed to create user ${user}`);\n      const security: any = await con.request({\n        db: dbName,\n        method: \"put\",\n        path: \"_security\",\n        // headers: {\n        //\n        // },\n        body: {\n          admins: {\n            names: [user],\n            roles: [],\n          },\n          members: {\n            names: [user],\n            roles: roles,\n          },\n        },\n      });\n      if (!security.ok)\n        throw new InternalError(\n          `Failed to authorize user ${user} to db ${dbName}`\n        );\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Deletes a user from the Nano server\n   * @summary Removes an existing user from the Nano server\n   * @param {ServerScope} con - The Nano server connection\n   * @param {string} dbName - The name of the database (used for logging purposes)\n   * @param {string} user - The username to delete\n   * @return {Promise<void>} A promise that resolves when the user is deleted\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant U as _users Database\n   *   A->>A: Generate user ID\n   *   A->>U: get(id)\n   *   U-->>A: user document\n   *   A->>U: destroy(id, user._rev)\n   *   alt Success\n   *     U-->>A: success response\n   *   else Error\n   *     U-->>A: error\n   *     A-->>A: throw parseError(e)\n   *   end\n   */\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = con.db.use(\"_users\");\n    const id = \"org.couchdb.user:\" + user;\n    try {\n      const usr = await users.get(id);\n      await users.destroy(id, usr._rev);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n  }\n\n  /**\n   * @description Sets up decorations for Nano-specific model properties\n   * @summary Configures decorators for created_by and updated_by fields in models to be automatically\n   * populated with the user from the context when documents are created or updated\n   * @return {void}\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as NanoAdapter\n   *   participant D as Decoration\n   *   participant R as Repository\n   *   A->>R: key(PersistenceKeys.CREATED_BY)\n   *   R-->>A: createdByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(createdByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   *   A->>R: key(PersistenceKeys.UPDATED_BY)\n   *   R-->>A: updatedByKey\n   *   A->>D: flavouredAs(\"nano\")\n   *   A->>D: for(updatedByKey)\n   *   A->>D: define(onCreate(createdByOnNanoCreateUpdate), propMetadata)\n   *   A->>D: apply()\n   */\n  static override decoration() {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(\"nano\")\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnNanoCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n\n    Decoration.flavouredAs(\"nano\")\n      .for(updatedByKey)\n      .define(\n        onCreateUpdate(createdByOnNanoCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n  }\n}\n\nAdapter.setCurrent(NanoFlavour);\n"]}
|
package/lib/esm/index.d.ts
CHANGED
package/lib/esm/index.js
CHANGED
|
@@ -17,5 +17,5 @@ export * from "./adapter.js";
|
|
|
17
17
|
* @const VERSION
|
|
18
18
|
* @memberOf module:for-nano
|
|
19
19
|
*/
|
|
20
|
-
export const VERSION = "0.1.
|
|
20
|
+
export const VERSION = "0.1.8";
|
|
21
21
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxxQkFBa0I7QUFFeEMsc0NBQXNDO0FBQ3RDLFdBQVcsQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUV6QiwrQkFBNEI7QUFDNUIsb0NBQWlDO0FBQ2pDLDJCQUF3QjtBQUN4Qiw2QkFBNkI7QUFDN0IsNkJBQTBCO0FBRTFCOzs7O0dBSUc7QUFFSDs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOYW5vQWRhcHRlciB9IGZyb20gXCIuL2FkYXB0ZXJcIjtcblxuLy8gRm9yY2VzIG92ZXJyaWRlIGZvciBOYW5vIERlY29yYXRpb25cbk5hbm9BZGFwdGVyLmRlY29yYXRpb24oKTtcblxuZXhwb3J0ICogZnJvbSBcIi4vY29uc3RhbnRzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9OYW5vUmVwb3NpdG9yeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdHlwZXNcIjtcbi8vIExlZnQgdG8gdGhlIGVuZCBvbiBwdXJwb3NlXG5leHBvcnQgKiBmcm9tIFwiLi9hZGFwdGVyXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEEgVHlwZVNjcmlwdCBtb2R1bGUgZm9yIGludGVyYWN0aW5nIHdpdGggTmFubyBkYXRhYmFzZXNcbiAqIEBzdW1tYXJ5IFRoaXMgbW9kdWxlIHByb3ZpZGVzIGEgc2V0IG9mIHV0aWxpdGllcywgY2xhc3NlcywgYW5kIHR5cGVzIGZvciB3b3JraW5nIHdpdGggTmFubyBkYXRhYmFzZXMuIEl0IGluY2x1ZGVzIHJlcG9zaXRvcnkgcGF0dGVybnMsIGFkYXB0ZXJzLCBhbmQgdHlwZSBkZWZpbml0aW9ucyB0byBzaW1wbGlmeSBkYXRhYmFzZSBvcGVyYXRpb25zLlxuICogQG1vZHVsZSBmb3ItbmFub1xuICovXG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIFBhY2thZ2UgdmVyc2lvbiBpZGVudGlmaWVyXG4gKiBAc3VtbWFyeSBTdG9yZXMgdGhlIGN1cnJlbnQgcGFja2FnZSB2ZXJzaW9uIHN0cmluZyBmb3IgdGhlIGZvci1uYW5vIG1vZHVsZVxuICogQGNvbnN0IFZFUlNJT05cbiAqIEBtZW1iZXJPZiBtb2R1bGU6Zm9yLW5hbm9cbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG4iXX0=
|
package/lib/index.cjs
CHANGED
|
@@ -34,5 +34,5 @@ __exportStar(require("./adapter.cjs"), exports);
|
|
|
34
34
|
* @const VERSION
|
|
35
35
|
* @memberOf module:for-nano
|
|
36
36
|
*/
|
|
37
|
-
exports.VERSION = "0.1.
|
|
37
|
+
exports.VERSION = "0.1.8";
|
|
38
38
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBd0M7QUFFeEMsc0NBQXNDO0FBQ3RDLHFCQUFXLENBQUMsVUFBVSxFQUFFLENBQUM7QUFFekIsa0RBQTRCO0FBQzVCLHVEQUFpQztBQUNqQyw4Q0FBd0I7QUFDeEIsNkJBQTZCO0FBQzdCLGdEQUEwQjtBQUUxQjs7OztHQUlHO0FBRUg7Ozs7O0dBS0c7QUFDVSxRQUFBLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOYW5vQWRhcHRlciB9IGZyb20gXCIuL2FkYXB0ZXJcIjtcblxuLy8gRm9yY2VzIG92ZXJyaWRlIGZvciBOYW5vIERlY29yYXRpb25cbk5hbm9BZGFwdGVyLmRlY29yYXRpb24oKTtcblxuZXhwb3J0ICogZnJvbSBcIi4vY29uc3RhbnRzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9OYW5vUmVwb3NpdG9yeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdHlwZXNcIjtcbi8vIExlZnQgdG8gdGhlIGVuZCBvbiBwdXJwb3NlXG5leHBvcnQgKiBmcm9tIFwiLi9hZGFwdGVyXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEEgVHlwZVNjcmlwdCBtb2R1bGUgZm9yIGludGVyYWN0aW5nIHdpdGggTmFubyBkYXRhYmFzZXNcbiAqIEBzdW1tYXJ5IFRoaXMgbW9kdWxlIHByb3ZpZGVzIGEgc2V0IG9mIHV0aWxpdGllcywgY2xhc3NlcywgYW5kIHR5cGVzIGZvciB3b3JraW5nIHdpdGggTmFubyBkYXRhYmFzZXMuIEl0IGluY2x1ZGVzIHJlcG9zaXRvcnkgcGF0dGVybnMsIGFkYXB0ZXJzLCBhbmQgdHlwZSBkZWZpbml0aW9ucyB0byBzaW1wbGlmeSBkYXRhYmFzZSBvcGVyYXRpb25zLlxuICogQG1vZHVsZSBmb3ItbmFub1xuICovXG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIFBhY2thZ2UgdmVyc2lvbiBpZGVudGlmaWVyXG4gKiBAc3VtbWFyeSBTdG9yZXMgdGhlIGN1cnJlbnQgcGFja2FnZSB2ZXJzaW9uIHN0cmluZyBmb3IgdGhlIGZvci1uYW5vIG1vZHVsZVxuICogQGNvbnN0IFZFUlNJT05cbiAqIEBtZW1iZXJPZiBtb2R1bGU6Zm9yLW5hbm9cbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG4iXX0=
|
package/lib/index.d.ts
CHANGED