@decaf-ts/for-fabric 0.4.9 → 0.5.1-query
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-fabric.cjs +18 -6
- package/dist/for-fabric.js +18 -6
- package/lib/contract/models/BaseModel.cjs +3 -3
- package/lib/contract/models/OtherProductShared.cjs +2 -3
- package/lib/contract/models/history-dec.cjs +15 -29
- package/lib/contracts/ContractAdapter.cjs +59 -39
- package/lib/contracts/ContractContext.cjs +10 -3
- package/lib/contracts/FabricContractSequence.cjs +114 -13
- package/lib/contracts/FabricContractSequence.d.ts +6 -0
- package/lib/contracts/crud/serialized-crud-contract.cjs +1 -1
- package/lib/esm/contract/models/BaseModel.js +3 -3
- package/lib/esm/contract/models/OtherProductShared.js +3 -4
- package/lib/esm/contract/models/history-dec.js +17 -31
- package/lib/esm/contracts/ContractAdapter.js +59 -39
- package/lib/esm/contracts/ContractContext.js +10 -3
- package/lib/esm/contracts/FabricContractSequence.d.ts +6 -0
- package/lib/esm/contracts/FabricContractSequence.js +114 -13
- package/lib/esm/contracts/crud/serialized-crud-contract.js +1 -1
- package/lib/esm/shared/decorators.js +27 -7
- package/lib/esm/version.d.ts +1 -1
- package/lib/esm/version.js +1 -1
- package/lib/shared/decorators.cjs +27 -7
- package/lib/version.cjs +1 -1
- package/lib/version.d.ts +1 -1
- package/package.json +1 -1
package/dist/for-fabric.cjs
CHANGED
|
@@ -1540,9 +1540,11 @@
|
|
|
1540
1540
|
}
|
|
1541
1541
|
async function ownedByOnCreate(context, data, key, model) {
|
|
1542
1542
|
const {stub: stub} = context;
|
|
1543
|
-
const allowGenerationOverride = context.
|
|
1543
|
+
const allowGenerationOverride = context.getOrUndefined("allowGenerationOverride") || false;
|
|
1544
1544
|
const creator = await stub.getCreator();
|
|
1545
|
-
|
|
1545
|
+
let owner = creator.mspid;
|
|
1546
|
+
context.log.info(`Expected mspid to be ${model[key]} | ${owner}. \n Using allowGenerationOverride: ${allowGenerationOverride}`);
|
|
1547
|
+
if (allowGenerationOverride) owner = model[key] ? model[key] : owner;
|
|
1546
1548
|
const setOwnedByKeyValue = function(target, propertyKey, value) {
|
|
1547
1549
|
Object.defineProperty(target, propertyKey, {
|
|
1548
1550
|
enumerable: true,
|
|
@@ -1784,8 +1786,18 @@
|
|
|
1784
1786
|
}
|
|
1785
1787
|
}
|
|
1786
1788
|
applySegregationFlags(model, collections, context);
|
|
1787
|
-
const
|
|
1788
|
-
|
|
1789
|
+
const keyArray = Array.isArray(keys) ? keys : [ keys ];
|
|
1790
|
+
const pkKey = decoratorValidation.Model.pk(model.constructor);
|
|
1791
|
+
const pkSeqName = decoratorValidation.Model.sequenceName(model, "pk");
|
|
1792
|
+
const idValue = model[pkKey];
|
|
1793
|
+
const canBuildPerInstance = typeof idValue !== "undefined" && idValue !== null;
|
|
1794
|
+
context.setSequenceSegregation(pkSeqName, context.isFullySegregated, collections);
|
|
1795
|
+
if (canBuildPerInstance) {
|
|
1796
|
+
for (const k of keyArray) {
|
|
1797
|
+
const propSeqName = decoratorValidation.Model.sequenceName(model, String(idValue), String(k));
|
|
1798
|
+
context.setSequenceSegregation(propSeqName, context.isFullySegregated, collections);
|
|
1799
|
+
}
|
|
1800
|
+
}
|
|
1789
1801
|
}
|
|
1790
1802
|
async function segregatedDataOnCreate(context, data, keys, model) {
|
|
1791
1803
|
const dataArray = Array.isArray(data) ? data : [ data ];
|
|
@@ -3685,7 +3697,7 @@
|
|
|
3685
3697
|
}
|
|
3686
3698
|
}
|
|
3687
3699
|
if (FabricClientAdapter) FabricClientAdapter["_baseDispatch"] = FabricClientDispatch;
|
|
3688
|
-
const VERSION = "0.
|
|
3700
|
+
const VERSION = "0.5.1";
|
|
3689
3701
|
const PACKAGE_NAME = "@decaf-ts/for-fabric";
|
|
3690
3702
|
decoration.Metadata.registerLibrary(PACKAGE_NAME, VERSION);
|
|
3691
3703
|
exports.AllowanceError = AllowanceError;
|
|
@@ -3775,4 +3787,4 @@
|
|
|
3775
3787
|
exports.writeDesignDocs = writeDesignDocs;
|
|
3776
3788
|
exports.writeIndexes = writeIndexes;
|
|
3777
3789
|
});
|
|
3778
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-fabric.cjs","sources":["../src/client/indexes/generation.ts","../src/client/collections/generation.ts","../src/client/FabricClientPaginator.ts","../src/client/FabricClientRepository.ts","../src/contracts/erc20/models.ts","../src/shared/ClientSerializer.ts","../src/client/erc20/FabricERC20ClientRepository.ts","../src/client/ids/id-extraction.ts","../src/shared/model/IdentityCredentials.ts","../src/shared/constants.ts","../src/shared/model/Identity.ts","../src/client/utils.ts","../src/client/crypto.ts","../src/shared/errors.ts","../src/client/services/FabricEnrollmentService.ts","../src/client/services/RegistrationRequestBuilder.ts","../src/shared/erc20/erc20-constants.ts","../src/shared/model/FabricBaseModel.ts","../src/shared/model/FabricIdentifiedBaseModel.ts","../src/shared/overrides/overrides.ts","../src/shared/decorators.ts","../src/shared/DeterministicSerializer.ts","../src/shared/events.ts","../src/shared/math.ts","../src/shared/SimpleDeterministicSerializer.ts","../src/client/services/FabricIdentityService.ts","../src/client/services/constants.ts","../src/client/constants.ts","../src/client/fabric-fs.ts","../src/client/FabricClientStatement.ts","../src/client/FabricClientAdapter.ts","../src/client/FabricClientDispatch.ts","../src/version.ts"],"sourcesContent":["import { Constructor } from \"@decaf-ts/decoration\";\nimport {\n  CreateIndexRequest,\n  CouchDBDesignDoc,\n  generateIndexes,\n  generateViews,\n} from \"@decaf-ts/for-couchdb\";\nimport { Model, ModelConstructor } from \"@decaf-ts/decorator-validation\";\n\nexport type Index = CreateIndexRequest;\n\nfunction ensureDirectoryExistence(filePath: string) {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n  const dirname: string = path.dirname(filePath);\n  if (fs.existsSync(dirname)) {\n    return true;\n  }\n  ensureDirectoryExistence(dirname);\n  fs.mkdirSync(dirname);\n}\n\nexport function generateModelIndexes<M extends Model>(\n  m: Constructor<M>\n): Index[] {\n  return generateIndexes([m]);\n}\n\nexport function generateModelDesignDocs<M extends Model>(\n  m: Constructor<M>,\n  accum?: Record<string, CouchDBDesignDoc>\n): CouchDBDesignDoc[] {\n  const views = generateViews([m]);\n  const storage: Record<string, CouchDBDesignDoc> = accum || {};\n  views.forEach((doc) => {\n    storage[doc._id] = doc;\n  });\n  return views;\n}\n\nexport function readModelFile(file: any) {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const exports = require(path.join(process.cwd(), file.parentPath, file.name));\n\n  const values = Object.values(exports).filter((e) => {\n    try {\n      const m = new (e as Constructor)();\n      return m instanceof Model;\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      return false;\n    }\n  }) as ModelConstructor<any>[];\n  return values;\n}\n\nexport async function readModelFolders(\n  ...folders: string[]\n): Promise<ModelConstructor<any>[]> {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n\n  const result: ModelConstructor<any>[] = [];\n\n  for (const folder of folders) {\n    const files = fs\n      .readdirSync(folder, {\n        withFileTypes: true,\n        recursive: true,\n      })\n      .filter((f: any) => f.isFile() && f.name.endsWith(\"js\"));\n    for (const file of files) {\n      result.push(...readModelFile(file));\n    }\n  }\n  return result;\n}\n\nexport function writeIndexes(\n  indexes: Index[],\n  p: string = process.cwd(),\n  collection?: string\n) {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n\n  indexes.forEach((index) => {\n    const file = path.resolve(\n      path.join(\n        p,\n        `./META-INF/statedb/couchdb/${collection ? `collections/${collection}/` : \"\"}indexes/${index.name}.json`\n      )\n    );\n    ensureDirectoryExistence(file);\n    fs.writeFileSync(file, JSON.stringify(index, undefined, 2));\n  });\n}\n\nexport function writeDesignDocs(\n  designDocs: CouchDBDesignDoc[],\n  p: string = process.cwd(),\n  collection?: string\n) {\n  if (!designDocs.length) return;\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n\n  designDocs.forEach((doc) => {\n    const docId = doc._id.replace(/^_design\\//, \"\");\n    const file = path.resolve(\n      path.join(\n        p,\n        `./META-INF/statedb/couchdb/${collection ? `collections/${collection}/` : \"\"}design_docs/${docId}.json`\n      )\n    );\n    ensureDirectoryExistence(file);\n    const payload = { ...doc };\n    delete payload._rev;\n    fs.writeFileSync(file, JSON.stringify(payload, undefined, 2));\n  });\n}\n","import { Constructor } from \"@decaf-ts/decoration\";\nimport { CouchDBDesignDoc } from \"@decaf-ts/for-couchdb\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport { CollectionResolver } from \"../../shared/index\";\nimport { writeDesignDocs } from \"../indexes/generation\";\n\n//\n// export type FabricCollection = {\n//   name: \"collectionMarbles\";\n//   policy: \"OR('Org1MSP.member', 'Org2MSP.member')\";\n//   requiredPeerCount: 0;\n//   maxPeerCount: 3;\n//   blockToLive: 0;\n//   memberOnlyRead: true;\n//   memberOnlyWrite: true;\n//   endorsementPolicy: {\n//     identities: [\n//       { role: { name: \"member\"; mspId: \"Org1MSP\" } },\n//       { role: { name: \"member\"; mspId: \"Org2MSP\" } },\n//     ];\n//     rule: \"OR('Org1MSP.member', 'Org2MSP.member')\";\n//   };\n// };\n\nexport type FabricPolicyIdentity = {\n  role: {\n    name: string;\n    mspId: string;\n  };\n};\n\nexport type FabricCollection = {\n  name: string;\n  policy: string;\n  requiredPeerCount: number;\n  maxPeerCount: number;\n  blockToLive: number;\n  memberOnlyRead: boolean;\n  memberOnlyWrite: boolean;\n  endorsementPolicy: {\n    identities: FabricPolicyIdentity[];\n    rule: string;\n  };\n};\n\nexport type PrivateCollection = {\n  name: string;\n  policy: string;\n  requiredPeerCount: number;\n  maxPeerCount: number;\n  blockToLive: number;\n  memberOnlyRead: boolean;\n  memberOnlyWrite: boolean;\n  endorsementPolicy?: {\n    signaturePolicy: string;\n  };\n};\n\nexport function collectionFor(\n  collectionName: string,\n  policy: string,\n  requiredPeerCount: number,\n  maxPeerCount: number,\n  blockToLive: number,\n  memberOnlyRead: boolean,\n  memberOnlyWrite: boolean\n): PrivateCollection {\n  return {\n    name: collectionName,\n    policy: policy,\n    requiredPeerCount,\n    maxPeerCount,\n    blockToLive,\n    memberOnlyRead,\n    memberOnlyWrite,\n  };\n}\n\nexport function privateCollectionFor(\n  mspId: string,\n  collectionName: string = `${mspId}Private`,\n  requiredPeerCount: number = 0,\n  maxPeerCount: number = 0,\n  blockToLive: number = 0,\n  memberOnlyRead: boolean = true,\n  memberOnlyWrite: boolean = true\n): PrivateCollection {\n  const c = collectionFor(\n    collectionName,\n    `OR('${mspId}.member')`,\n    requiredPeerCount,\n    maxPeerCount,\n    blockToLive,\n    memberOnlyRead,\n    memberOnlyWrite\n  );\n\n  c.endorsementPolicy = {\n    signaturePolicy: `OR('${mspId}.peer')`,\n  };\n  return c;\n}\n\nexport function sharedCollectionFor(\n  mspIds: string[],\n  collectionName: string,\n  requiredPeerCount: number = 1,\n  maxPeerCount: number = 2,\n  blockToLive: number = 0,\n  memberOnlyRead: boolean = true,\n  memberOnlyWrite: boolean = true\n): PrivateCollection {\n  const c = collectionFor(\n    collectionName,\n    `OR(${mspIds.map((m) => `'${m}.member'`).join(\",\")})`,\n    requiredPeerCount,\n    maxPeerCount,\n    blockToLive,\n    memberOnlyRead,\n    memberOnlyWrite\n  );\n  c.endorsementPolicy = {\n    signaturePolicy: `AND(${mspIds.map((m) => `'${m}.peer'`).join(\",\")})`,\n  };\n  return c;\n}\n\nexport async function extractCollections<M extends Model>(\n  m: Constructor<M>,\n  mspIds: string[],\n  overrides: {\n    privateCols?: Partial<PrivateCollection>;\n    sharedCols?: Partial<PrivateCollection>;\n  } = {},\n  mirror: boolean = false\n) {\n  let { privateCols, sharedCols } = Model.collectionsFor(m);\n\n  function resolveCollection(arg: string | CollectionResolver): string {\n    try {\n      if (typeof arg === \"string\") return arg;\n      return arg(m, mspIds[0]) as string;\n    } catch (e: unknown) {\n      throw new InternalError(e as Error);\n    }\n  }\n\n  privateCols = privateCols.map(resolveCollection);\n  sharedCols = sharedCols.map(resolveCollection);\n\n  const privateDefaults = Object.assign(\n    {},\n    {\n      requiredPeerCount: 0,\n      maxPeerCount: 0,\n      blockToLive: 0,\n      memberOnlyRead: true,\n      memberOnlyWrite: true,\n    },\n    overrides?.privateCols || {}\n  );\n  const sharedDefaults = Object.assign(\n    {},\n    {\n      requiredPeerCount: 1,\n      maxPeerCount: 2,\n      blockToLive: 0,\n      memberOnlyRead: true,\n      memberOnlyWrite: true,\n    },\n    overrides?.sharedCols || {}\n  );\n\n  const mirrorMeta = mirror ? Model.mirroredAt(m) : undefined;\n\n  const privates = mspIds\n    .map((mspId) =>\n      (privateCols as string[]).map((p) => {\n        const { requiredPeerCount, maxPeerCount, blockToLive, memberOnlyRead } =\n          privateDefaults;\n        return privateCollectionFor(\n          mspId,\n          p,\n          requiredPeerCount,\n          maxPeerCount,\n          blockToLive,\n          memberOnlyRead,\n          false\n        );\n      })\n    )\n    .flat();\n\n  if (mirrorMeta && mirrorMeta.mspId) {\n    const resolved =\n      typeof mirrorMeta.resolver === \"string\"\n        ? mirrorMeta.resolver\n        : mirrorMeta.resolver(m, mirrorMeta.mspId);\n    if (\n      resolved &&\n      !privates.some(\n        (p) => p.name === resolved && p.policy.includes(mirrorMeta.mspId)\n      )\n    ) {\n      const { requiredPeerCount, maxPeerCount, blockToLive, memberOnlyRead } =\n        privateDefaults;\n      privates.push(\n        privateCollectionFor(\n          mirrorMeta.mspId,\n          resolved,\n          requiredPeerCount,\n          maxPeerCount,\n          blockToLive,\n          memberOnlyRead,\n          false\n        )\n      );\n    }\n  }\n\n  const shared = (sharedCols as string[]).map((p) => {\n    const {\n      requiredPeerCount,\n      maxPeerCount,\n      blockToLive,\n      memberOnlyRead,\n      memberOnlyWrite,\n    } = sharedDefaults;\n    return sharedCollectionFor(\n      mspIds,\n      p,\n      requiredPeerCount,\n      maxPeerCount,\n      blockToLive,\n      memberOnlyRead,\n      memberOnlyWrite\n    );\n  });\n\n  return {\n    privates,\n    shared,\n  };\n}\n\nexport function writeCollections(\n  cols: PrivateCollection[],\n  p: string = process.cwd(),\n  fileName = \"collections_config\"\n) {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n\n  function ensureDirectoryExistence(filePath: string) {\n    const dirname: string = path.dirname(filePath) as string;\n    if (fs.existsSync(dirname)) {\n      return true;\n    }\n    ensureDirectoryExistence(dirname);\n    fs.mkdirSync(dirname);\n  }\n\n  const file = path.resolve(path.join(p, `./META-INF/${fileName}.json`));\n  ensureDirectoryExistence(file);\n  fs.writeFileSync(file, JSON.stringify(cols, undefined, 2));\n}\n\nexport function writeCollectionDesignDocs(\n  docs: CouchDBDesignDoc[],\n  p: string = process.cwd(),\n  collection?: string\n) {\n  if (!docs?.length) return;\n  writeDesignDocs(docs, p, collection);\n}\n","import {\n  MaybeContextualArg,\n  Paginator,\n  PreparedStatement,\n  SerializedPage,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { Constructor } from \"@decaf-ts/decoration\";\nimport { FabricClientAdapter } from \"./FabricClientAdapter\";\nimport { MangoQuery } from \"@decaf-ts/for-couchdb\";\n\nexport class FabricClientPaginator<M extends Model> extends Paginator<\n  M,\n  M[],\n  MangoQuery\n> {\n  bookmark?: string;\n\n  constructor(\n    adapter: FabricClientAdapter,\n    query: MangoQuery | PreparedStatement<any>,\n    size: number,\n    clazz: Constructor<M>\n  ) {\n    super(adapter, query, size, clazz);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected prepare(rawStatement: MangoQuery): MangoQuery {\n    throw new UnsupportedError(\n      `Raw query access must be implemented by a subclass. only prepared statements are natively available`\n    );\n  }\n\n  override page(\n    page: number = 1,\n    ...args: MaybeContextualArg<any>\n  ): Promise<M[]> {\n    return super.page(page, ...args); // this will fail for non-prepared statements\n  }\n\n  static override isSerializedPage(obj: SerializedPage<any> | any) {\n    return obj && typeof obj === \"object\" && Array.isArray(obj.data);\n  }\n}\n","import type { MaybeContextualArg } from \"@decaf-ts/core\";\nimport {\n  ContextOf,\n  DirectionLimitOffset,\n  FlagsOf,\n  ObserverHandler,\n  OrderDirection,\n  Paginator,\n  PersistenceKeys,\n  PreparedStatementKeys,\n  Repository,\n  SerializedPage,\n} from \"@decaf-ts/core\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { Constructor } from \"@decaf-ts/decoration\";\nimport { type FabricClientAdapter } from \"./FabricClientAdapter\";\nimport {\n  BulkCrudOperationKeys,\n  enforceDBDecorators,\n  OperationKeys,\n  PrimaryKeyType,\n  reduceErrorsToPrint,\n  ValidationError,\n} from \"@decaf-ts/db-decorators\";\nimport { CouchDBKeys } from \"@decaf-ts/for-couchdb\";\nimport { FabricClientPaginator } from \"./FabricClientPaginator\";\n\n/**\n * @description Repository implementation for Fabric client operations\n * @summary Extends the generic Repository to prepare context and arguments for CRUD operations executed via a Fabric client Adapter, wiring RepositoryFlags and Fabric-specific overrides.\n * @template M extends Model - The model type handled by this repository\n * @param {Adapter<any, MangoQuery, FabricFlags, Context<FabricFlags>>} [adapter] - Optional adapter instance used to execute operations\n * @param {Constructor<M>} [clazz] - Optional model constructor used by the repository\n * @return {void}\n * @class FabricClientRepository\n * @example\n * import { Repository } from \"@decaf-ts/core\";\n * import { FabricClientRepository } from \"@decaf-ts/for-fabric\";\n *\n * class User extends Model { id!: string; name!: string; }\n * const repo = new FabricClientRepository<User>();\n * const created = await repo.create(new User({ id: \"1\", name: \"Alice\" }));\n * const loaded = await repo.read(\"1\");\n *\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Repo as FabricClientRepository\n *   participant Adapter\n *   App->>Repo: create(model)\n *   Repo->>Repo: createPrefix(model, ...args)\n *   Repo->>Adapter: create(table, id, model, flags)\n *   Adapter-->>Repo: result\n *   Repo-->>App: model\n */\nexport class FabricClientRepository<\n  M extends Model,\n  A extends FabricClientAdapter = FabricClientAdapter,\n> extends Repository<M, A> {\n  protected override _overrides = Object.assign({}, super[\"_overrides\"], {\n    ignoreValidation: true,\n    ignoreHandlers: true,\n    allowRawStatements: false,\n    forcePrepareSimpleQueries: true,\n    forcePrepareComplexQueries: true,\n    allowGenerationOverride: false,\n    rebuildWithTransient: false,\n  });\n\n  constructor(adapter?: A, clazz?: Constructor<M>, force: boolean = false) {\n    super(adapter, clazz, force);\n  }\n\n  override override(flags: Partial<FlagsOf<ContextOf<A>>>): this {\n    return super\n      .override(Object.assign({}, flags, this._overrides))\n      .for(flags as any);\n  }\n\n  protected override ObserverHandler(): ObserverHandler {\n    return super.ObserverHandler();\n  }\n\n  override async paginateBy(\n    key: keyof M,\n    order: OrderDirection,\n    ref: Omit<DirectionLimitOffset, \"direction\"> = {\n      offset: 1,\n      limit: 10,\n    },\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<SerializedPage<M>> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.PAGE_BY, true)\n    ).for(this.paginateBy);\n    log.verbose(\n      `paginating ${Model.tableName(this.class)} with page size ${ref.limit}`\n    );\n    return this.statement(\n      this.paginateBy.name,\n      key,\n      order,\n      { limit: ref.limit, offset: ref.offset, bookmark: ref.bookmark },\n      ...ctxArgs\n    );\n  }\n\n  override async listBy(\n    key: keyof M,\n    order: OrderDirection,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.LIST_BY, true)\n    ).for(this.listBy);\n    log.verbose(\n      `listing ${Model.tableName(this.class)} by ${key as string} ${order}`\n    );\n    return (await this.statement(\n      this.listBy.name,\n      key,\n      order,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async findBy(\n    key: keyof M,\n    value: any,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.FIND_BY, true)\n    ).for(this.findBy);\n    log.verbose(\n      `finding all ${Model.tableName(this.class)} with ${key as string} ${value}`\n    );\n    return (await this.statement(\n      this.findBy.name,\n      key,\n      value,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async findOneBy(\n    key: keyof M,\n    value: any,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.FIND_ONE_BY, true)\n    ).for(this.findOneBy);\n    log.verbose(\n      `finding One ${Model.tableName(this.class)} with ${key as string} ${value}`\n    );\n    return (await this.statement(\n      this.findOneBy.name,\n      key,\n      value,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async find(\n    value: string,\n    order: OrderDirection = OrderDirection.ASC,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.FIND, true)\n    ).for(this.find);\n    log.verbose(\n      `finding ${Model.tableName(this.class)} by default query attributes`\n    );\n    return (await this.statement(\n      this.find.name,\n      value,\n      order,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async page(\n    value: string,\n    direction: OrderDirection = OrderDirection.ASC,\n    ref: Omit<DirectionLimitOffset, \"direction\"> = {\n      offset: 1,\n      limit: 10,\n    },\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<SerializedPage<M>> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.PAGE, true)\n    ).for(this.page);\n    log.verbose(\n      `paging ${Model.tableName(this.class)} by default query attributes`\n    );\n    return (await this.statement(\n      this.page.name,\n      value,\n      direction,\n      ref,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async statement(\n    name: string,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<any> {\n    const { log, ctx, ctxArgs } = (\n      await this.logCtx(args, PersistenceKeys.STATEMENT, true)\n    ).for(this.statement);\n    log.verbose(`Executing prepared statement ${name}`);\n    const callArgs = ctxArgs.slice(0, -1);\n    const result = JSON.parse(\n      this.adapter.decode(\n        await this.adapter.evaluateTransaction(\n          ctx,\n          PersistenceKeys.STATEMENT,\n          [name, JSON.stringify(callArgs)],\n          undefined,\n          undefined,\n          this.class.name\n        )\n      )\n    );\n\n    let hydrated: any;\n    if (Array.isArray(result)) {\n      hydrated = result.map((r: any) =>\n        (r as any)[CouchDBKeys.TABLE] &&\n        (r as any)[CouchDBKeys.TABLE] === Model.tableName(this.class)\n          ? (new this.class(r) as M)\n          : r\n      );\n    } else if (\n      (result as any)[CouchDBKeys.TABLE] &&\n      (result as any)[CouchDBKeys.TABLE] === Model.tableName(this.class)\n    ) {\n      hydrated = new this.class(result) as M;\n    } else if (FabricClientPaginator.isSerializedPage(result)) {\n      hydrated = Object.assign(result, {\n        data: result.data.map((d: any) => new this.class(d) as M),\n      });\n    } else {\n      hydrated = result;\n    }\n\n    return this.applyAfterRead(hydrated, ctx);\n  }\n\n  private async applyAfterRead(value: any, ctx: ContextOf<A>): Promise<any> {\n    if (!ctx.getOrUndefined(\"afterQueryHandlers\")) return value;\n    if (value instanceof Model) {\n      await enforceDBDecorators<M, Repository<M, A>, any>(\n        this,\n        ctx,\n        value as M,\n        OperationKeys.READ,\n        OperationKeys.AFTER\n      );\n      return value;\n    }\n    if (Array.isArray(value)) {\n      await Promise.all(value.map((entry) => this.applyAfterRead(entry, ctx)));\n      return value;\n    }\n    if (FabricClientPaginator.isSerializedPage(value)) {\n      await this.applyAfterRead(value.data, ctx);\n      return value;\n    }\n    return value;\n  }\n\n  override async countOf(\n    key?: keyof M,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.COUNT_OF, true)\n    ).for(this.countOf);\n    log.verbose(\n      `counting ${Model.tableName(this.class)}${key ? ` by ${key as string}` : \"\"}`\n    );\n    const stmtArgs = key ? [key, ...ctxArgs] : ctxArgs;\n    return this.statement(PreparedStatementKeys.COUNT_OF, ...stmtArgs);\n  }\n\n  override async maxOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[K]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.MAX_OF, true)\n    ).for(this.maxOf);\n    log.verbose(\n      `finding max of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.MAX_OF, key, ...ctxArgs);\n  }\n\n  override async minOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[K]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.MIN_OF, true)\n    ).for(this.minOf);\n    log.verbose(\n      `finding min of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.MIN_OF, key, ...ctxArgs);\n  }\n\n  override async avgOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.AVG_OF, true)\n    ).for(this.avgOf);\n    log.verbose(\n      `calculating avg of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.AVG_OF, key, ...ctxArgs);\n  }\n\n  override async sumOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.SUM_OF, true)\n    ).for(this.sumOf);\n    log.verbose(\n      `calculating sum of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.SUM_OF, key, ...ctxArgs);\n  }\n\n  override async distinctOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[K][]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.DISTINCT_OF, true)\n    ).for(this.distinctOf);\n    log.verbose(\n      `finding distinct values of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.DISTINCT_OF, key, ...ctxArgs);\n  }\n\n  override async groupOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<Record<string, M[]>> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.GROUP_OF, true)\n    ).for(this.groupOf);\n    log.verbose(`grouping ${Model.tableName(this.class)} by ${key as string}`);\n    return this.statement(PreparedStatementKeys.GROUP_OF, key, ...ctxArgs);\n  }\n\n  async healthcheck(...args: MaybeContextualArg<ContextOf<A>>) {\n    const { ctxArgs } = this.logCtx(args, this.healthcheck);\n\n    const result = await this.adapter.healthcheck(this.class, ...ctxArgs);\n\n    return result;\n  }\n\n  override async create(\n    model: M,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M> {\n    const { ctx, log, ctxArgs } = this.logCtx(args, this.create);\n    log.debug(\n      `Creating new ${this.class.name} in table ${Model.tableName(this.class)}`\n    );\n    this.ensureLegacyMirrorFlag(ctx, model);\n    const prepared = this.adapter.prepare(model, ctx);\n    const { record, id, transient } = prepared;\n    const result = await this.adapter.create(\n      this.class,\n      id,\n      record,\n      transient,\n      ...ctxArgs\n    );\n    return this.adapter.revert<M>(result, this.class, id, transient, ctx);\n  }\n\n  override async update(\n    model: M,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M> {\n    const { ctxArgs, log, ctx } = this.logCtx(args, this.update);\n    this.ensureLegacyMirrorFlag(ctx, model);\n    const prepared = this.adapter.prepare(model, ctx);\n    const { id, transient } = prepared;\n    let record = prepared.record;\n    log.debug(\n      `updating ${this.class.name} in table ${Model.tableName(this.class)} with id ${id}`\n    );\n    record = await this.adapter.update(\n      this.class,\n      id,\n      record,\n      transient,\n      ...ctxArgs\n    );\n    return this.adapter.revert<M>(record, this.class, id, transient, ctx);\n  }\n\n  protected override async createAllPrefix(\n    models: M[],\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<[M[], ...any[], ContextOf<A>]> {\n    const { ctx, ctxArgs } = (\n      await this.logCtx(args, OperationKeys.CREATE, true)\n    ).for(this.createAllPrefix);\n    const ignoreHandlers = ctx.get(\"ignoreHandlers\");\n    const ignoreValidate = ctx.get(\"ignoreValidation\");\n    if (!models.length) return [models, ...ctxArgs] as any;\n\n    models = await Promise.all(\n      models.map(async (m) => {\n        m = new this.class(m);\n        if (!ignoreHandlers)\n          await enforceDBDecorators<M, Repository<M, A>, any>(\n            this,\n            ctx,\n            m,\n            OperationKeys.CREATE,\n            OperationKeys.ON\n          );\n        return m;\n      })\n    );\n\n    if (!ignoreValidate) {\n      const ignoredProps = ctx.get(\"ignoredValidationProperties\") || [];\n\n      const errors = await Promise.all(\n        models.map((m) => Promise.resolve(m.hasErrors(...ignoredProps)))\n      );\n\n      const errorMessages = reduceErrorsToPrint(errors);\n\n      if (errorMessages) throw new ValidationError(errorMessages);\n    }\n    return [models, ...ctxArgs] as any;\n  }\n\n  override async createAll(\n    models: M[],\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    if (!models.length) return models;\n    const { ctx, log, ctxArgs } = this.logCtx(args, this.createAll);\n    log.debug(\n      `Creating ${models.length} new ${this.class.name} in table ${Model.tableName(this.class)}`\n    );\n\n    models.forEach((model) => this.ensureLegacyMirrorFlag(ctx, model));\n    const prepared = models.map((m) => this.adapter.prepare(m, ctx));\n    const ids = prepared.map((p) => p.id);\n    const payloads = prepared.map((p) => p.record);\n    const transients = prepared.map((p) => p.transient);\n    const created = await this.adapter.createAll(\n      this.class,\n      ids as PrimaryKeyType[],\n      payloads,\n      transients,\n      ...ctxArgs\n    );\n    return Promise.all(\n      created.map(async (r, i) => {\n        const id = ids[i];\n        return this.adapter.revert<M>(r, this.class, id, transients[i], ctx);\n      })\n    );\n  }\n\n  override async readAll(\n    keys: PrimaryKeyType[],\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ) {\n    const { ctx, log, ctxArgs } = this.logCtx(args, this.readAll);\n    log.debug(\n      `reading ${keys.length} ${this.class.name} in table ${Model.tableName(this.class)}`\n    );\n    const records = await this.adapter.readAll(this.class, keys, ...ctxArgs);\n    return records.map((r, i) =>\n      this.adapter.revert(r, this.class, keys[i], {}, ctx)\n    );\n  }\n\n  override async updateAll(\n    models: M[],\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    const { ctx, log, ctxArgs } = this.logCtx(args, this.updateAll);\n    log.debug(\n      `Updating ${models.length} new ${this.class.name} in table ${Model.tableName(this.class)}`\n    );\n\n    models.forEach((model) => this.ensureLegacyMirrorFlag(ctx, model));\n    const prepared = models.map((m) => this.adapter.prepare(m, ctx));\n    const ids = prepared.map((p) => p.id);\n    const updated = await this.adapter.updateAll(\n      this.class,\n      ids as PrimaryKeyType[],\n      prepared.map((r) => r.record),\n      prepared.map((r) => r.transient),\n      ...ctxArgs\n    );\n    return Promise.all(\n      updated.map(async (u, i) => {\n        const id = ids[i];\n        return this.adapter.revert<M>(\n          u,\n          this.class,\n          id,\n          prepared[i].transient,\n          ctx\n        );\n      })\n    );\n  }\n\n  private ensureLegacyMirrorFlag(ctx: ContextOf<A>, model: M): void {\n    if (Model.mirroredAt(model)) {\n      ctx.accumulate({ legacy: true });\n    }\n  }\n}\n","import { BaseModel, column, pk, table } from \"@decaf-ts/core\";\nimport { model, type ModelArg, required } from \"@decaf-ts/decorator-validation\";\n\n/**\n * @description ERC20 token metadata model\n * @summary Represents an ERC20 token definition within the Fabric ERC20 sample, including name, symbol, decimals, and the owning identity. Used to define the unique token managed by the contract.\n * @param {ModelArg<ERC20Token>} [m] - Optional partial data or another instance to initialize the model\n * @return {void}\n * @class ERC20Token\n * @example\n * const token = new ERC20Token({ name: \"MyToken\", symbol: \"MTK\", decimals: 18, owner: \"x509::...\" });\n * // Persist through a repository: await repo.create(token, ctx)\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Repo\n *   participant Adapter\n *   App->>Repo: create(new ERC20Token({...}), ctx)\n *   Repo->>Adapter: create(table, id=name, record, flags)\n *   Adapter-->>Repo: stored\n *   Repo-->>App: model\n */\n@table(\"erc20_tokens\")\n@model()\nexport class ERC20Token extends BaseModel {\n  @pk({ type: String })\n  /**\n   * @description Token unique name\n   * @summary Serves as the primary key for the ERC20 token definition; typically a human-readable identifier\n   */\n  name!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Owning identity of the token\n   * @summary X.509 subject or MSP identity string that denotes who owns/controls the token definition\n   */\n  owner!: string;\n  @column()\n  @required()\n  /**\n   * @description Token symbol\n   * @summary Short ticker-like symbol used to represent the token (e.g., MTK)\n   */\n  symbol!: string;\n  @column()\n  @required()\n  /**\n   * @description Decimal precision for token amounts\n   * @summary Number of digits after the decimal separator used when formatting token balances\n   */\n  decimals!: number;\n\n  constructor(m?: ModelArg<ERC20Wallet>) {\n    super(m);\n  }\n}\n\n/**\n * @description ERC20 wallet model\n * @summary Represents a holder account for an ERC20 token within the Fabric network, tracking balance and token association.\n * @param {ModelArg<ERC20Wallet>} [m] - Optional partial data or another instance to initialize the model\n * @return {void}\n * @class ERC20Wallet\n * @example\n * const wallet = new ERC20Wallet({ id: \"acct1\", token: \"MyToken\", balance: 1000 });\n * // Update balance via repository: await repo.update(wallet, ctx)\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Repo\n *   App->>Repo: read(\"acct1\", ctx)\n *   Repo-->>App: ERC20Wallet\n */\n@table(\"erc20_wallets\")\n@model()\nexport class ERC20Wallet extends BaseModel {\n  @pk({ type: String })\n  /**\n   * @description Wallet unique identifier\n   * @summary Primary key for the wallet; commonly references an account or identity\n   */\n  id!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Associated token name\n   * @summary References the ERC20Token this wallet holds; maintained as a relationship for cascading updates/deletes\n   */\n  token!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Token balance for this wallet\n   * @summary Current amount of the associated token held by this wallet\n   */\n  balance!: number;\n\n  @column()\n  /**\n   * @description Captive flag or identifier\n   * @summary Optional field used by some flows to mark non-transferable funds or managed custody\n   */\n  captive!: string;\n\n  constructor(m?: ModelArg<ERC20Wallet>) {\n    super(m);\n  }\n}\n\n/**\n * @description ERC20 allowance model\n * @summary Captures an approval relationship where an owner allows a spender to transfer up to a certain value from the owner's wallet.\n * @param {ModelArg<Allowance>} [m] - Optional partial data or another instance to initialize the model\n * @return {void}\n * @class Allowance\n * @example\n * const allowance = new Allowance({ owner: \"acct1\", spender: \"acct2\", value: 50 });\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   App->>App: new Allowance({ owner, spender, value })\n */\n@table(\"erc20_allowances\")\n@model()\nexport class Allowance extends BaseModel {\n  @pk({ type: String })\n  /**\n   * @description Allowance unique identifier\n   * @summary Primary key for the allowance; typically a unique identifier for the approval relationship\n   */\n  @column()\n  @required()\n  /**\n   * @description Owner wallet identifier\n   * @summary Wallet that authorizes the allowance\n   */\n  owner!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Spender wallet identifier\n   * @summary Wallet allowed to spend up to the approved value from the owner\n   */\n  spender!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Approved value\n   * @summary Maximum token amount the spender may transfer on behalf of the owner\n   */\n  value!: number;\n\n  constructor(m?: ModelArg<Allowance>) {\n    super(m);\n  }\n}\n","import {\n  JSONSerializer,\n  Model,\n  ModelKeys,\n} from \"@decaf-ts/decorator-validation\";\nimport { SerializationError } from \"@decaf-ts/db-decorators\";\nimport { Constructor, Metadata } from \"@decaf-ts/decoration\";\n\n/**\n * @description Client-side JSON serializer for Decaf models targeting Hyperledger Fabric\n * @summary Extends the base JSONSerializer to embed model metadata (anchor) required to reconstruct instances on the client, and to safely serialize/deserialize Fabric-bound models.\n * @template M extends Model - The Decaf model type handled by this serializer\n * @param {void} [constructor] No public constructor arguments; provided for documentation completeness\n * @return {void}\n * @class ClientSerializer\n * @example\n * const serializer = new ClientSerializer<User>();\n * const json = serializer.serialize(new User({ id: \"1\", name: \"Alice\" }));\n * const user = serializer.deserialize(json);\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Serializer as ClientSerializer\n *   participant Model\n *   App->>Serializer: serialize(model)\n *   Serializer->>Serializer: preSerialize(model)\n *   Serializer-->>App: JSON string\n *   App->>Serializer: deserialize(json)\n *   Serializer->>Serializer: JSON.parse(json)\n *   Serializer->>Model: Model.build(parsed, anchor)\n *   Model-->>App: instance\n */\nexport class ClientSerializer<M extends Model> extends JSONSerializer<M> {\n  constructor() {\n    super();\n  }\n  /**\n   * @description Prepare a model for JSON serialization embedding class anchor\n   * @summary Clones the model and injects the class metadata anchor so it can be reconstructed during deserialization. Falls back to provided table name if metadata is not available.\n   * @template M - Model type handled by this serializer\n   * @param {M} model - The model instance to serialize\n   * @param {string} [modelName] - Optional table name to use when metadata cannot be derived\n   * @return {Record<string, any>} A plain object ready to be JSON.stringify'd\n   */\n  protected override preSerialize(model: M, modelName?: string) {\n    // TODO: nested preserialization (so increase performance when deserializing)\n    const toSerialize: Record<string, any> = Object.assign({}, model);\n    let metadata = Metadata.modelName(model.constructor as Constructor<M>);\n\n    if (!metadata || metadata === \"Object\")\n      if (modelName) metadata = modelName;\n      else\n        throw new SerializationError(\n          `Could not find metadata for ${model.constructor.name}`\n        );\n    toSerialize[ModelKeys.ANCHOR] = metadata;\n    return toSerialize;\n  }\n\n  /**\n   * @description Rebuilds a model from its JSON serialization\n   * @summary Parses the JSON string, retrieves the embedded model anchor, and uses Model.build to reconstruct the original instance\n   * @param {string} str - The JSON string previously produced by serialize\n   * @return {M} The reconstructed model instance\n   */\n  override deserialize(str: string): M {\n    const deserialization = JSON.parse(str);\n    const className = deserialization[ModelKeys.ANCHOR];\n    if (!className)\n      throw new Error(\"Could not find class reference in serialized model\");\n    const model: M = Model.build(deserialization, className) as unknown as M;\n    return model;\n  }\n\n  /**\n   * @description Serializes a model to a JSON string\n   * @summary Prepares the model via preSerialize, embedding metadata needed for reconstruction, and returns a JSON string representation\n   * @param {M} model - The model instance to serialize\n   * @param {string} [table] - Optional table name to include as anchor when metadata is unavailable\n   * @return {string} A JSON string containing the serialized model with anchor metadata\n   */\n  override serialize(model: M, modelName?: string): string {\n    return JSON.stringify(this.preSerialize(model, modelName));\n  }\n}\n","import { FabricClientRepository } from \"../FabricClientRepository\";\nimport { ERC20Token, ERC20Wallet } from \"../../contracts/erc20/models\";\nimport { Model, Serializer } from \"@decaf-ts/decorator-validation\";\nimport { FabricClientAdapter } from \"../FabricClientAdapter\";\nimport { ClientSerializer } from \"../../shared/ClientSerializer\";\nimport {\n  Context,\n  ContextOf,\n  ContextualArgs,\n  EventIds,\n  MaybeContextualArg,\n  Sequence,\n} from \"@decaf-ts/core\";\nimport {\n  BulkCrudOperationKeys,\n  InternalError,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { Constructor } from \"@decaf-ts/decoration\";\n/**\n * Repository for interacting with ERC20 contracts on a Hyperledger Fabric network.\n * Extends the base FabricClientRepository class and utilizes the ClientSerializer for data serialization.\n */\nexport class FabricERC20ClientRepository<\n  A extends FabricClientAdapter,\n> extends FabricClientRepository<ERC20Wallet, A> {\n  private static serializer = new ClientSerializer();\n\n  protected readonly serializer: Serializer<any> =\n    FabricERC20ClientRepository.serializer;\n\n  private static decoder = new TextDecoder(\"utf8\");\n\n  /**\n   * @description Notifies all observers of an event.\n   * @summary Updates all registered observers with information about a database event.\n   * @param {string} table - The table name where the event occurred.\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of event that occurred.\n   * @param {EventIds} id - The ID or IDs of the affected records.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<void>} A promise that resolves when all observers have been notified.\n   * @throws {InternalError} If the observer handler is not initialized.\n   */\n  override async updateObservers<M extends Model>(\n    table: Constructor<M> | string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: ContextualArgs<ContextOf<A>>\n  ): Promise<void> {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    const { log, ctxArgs } = this.logCtx(args, this.updateObservers);\n    log.verbose(\n      `Updating ${this.observerHandler.count()} observers for ${this}`\n    );\n\n    table = (\n      typeof table === \"string\" ? Model.get(table) : table\n    ) as Constructor<M>;\n    let parsedId: string | string[] | undefined;\n\n    if (id === undefined) {\n      parsedId = undefined;\n    } else if (Array.isArray(id)) {\n      parsedId = id.map(\n        (i) => Sequence.parseValue(Model.sequenceFor(table).type, i) as string\n      );\n    } else {\n      parsedId = Sequence.parseValue(\n        Model.sequenceFor(table).type,\n        id\n      ) as string;\n    }\n    await this.observerHandler.updateObservers(\n      table,\n      event,\n      parsedId!,\n      ...ctxArgs\n    );\n  }\n\n  /**\n   * Decodes a Uint8Array into a string using the TextDecoder.\n   *\n   * @param data - The Uint8Array to decode.\n   * @returns The decoded string.\n   */\n  decode(data: Uint8Array): string {\n    return FabricERC20ClientRepository.decoder.decode(data);\n  }\n\n  constructor(adapter?: A) {\n    super(adapter, ERC20Wallet);\n  }\n\n  /**\n   * Retrieves the name of the ERC20 token.\n   *\n   * @description\n   * This function interacts with the blockchain network to fetch the name of the ERC20 token.\n   * It calls the \"TokenName\" transaction on the smart contract and decodes the returned data.\n   *\n   * @returns {Promise<string>} A promise that resolves with the name of the ERC20 token.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async tokenName(...args: MaybeContextualArg<ContextOf<A>>): Promise<string> {\n    const { ctx } = (await this.logCtx(args, \"tokenName\", true)).for(\n      this.tokenName\n    );\n    const name = await this.adapter.evaluateTransaction(ctx, \"TokenName\");\n    return this.decode(name);\n  }\n\n  /**\n   * Retrieves the symbol of the ERC20 token.\n   *\n   * This function interacts with the blockchain network to fetch the symbol of the ERC20 token.\n   * It calls the \"Symbol\" transaction on the smart contract and decodes the returned data.\n   *\n   * @returns {Promise<string>} A promise that resolves with the symbol of the ERC20 token.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async symbol(...args: MaybeContextualArg<ContextOf<A>>): Promise<string> {\n    const { ctx } = (await this.logCtx(args, \"symbol\", true)).for(this.symbol);\n    const symbol = await this.adapter.evaluateTransaction(ctx, \"Symbol\");\n    return this.decode(symbol);\n  }\n\n  /**\n   * Retrieves the number of decimal places for the ERC20 token.\n   *\n   * This function interacts with the blockchain network to fetch the number of decimal places for the ERC20 token.\n   * It calls the \"Decimals\" transaction on the smart contract and decodes the returned data.\n   *\n   * @returns {Promise<number>} A promise that resolves with the number of decimal places for the ERC20 token.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async decimals(...args: MaybeContextualArg<ContextOf<A>>): Promise<number> {\n    const { ctx } = (await this.logCtx(args, \"decimals\", true)).for(\n      this.decimals\n    );\n    const decimals = await this.adapter.evaluateTransaction(ctx, \"Decimals\");\n    return Number(this.decode(decimals));\n  }\n\n  /**\n   * Retrieves the total supply of the ERC20 token.\n   *\n   * This function interacts with the blockchain network to fetch the total supply of the ERC20 token.\n   * It calls the \"TotalSupply\" transaction on the smart contract and decodes the returned data.\n   *\n   * @returns {Promise<number>} A promise that resolves with the total supply of the ERC20 token.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async totalSupply(\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { ctx } = (await this.logCtx(args, \"totalSupply\", true)).for(\n      this.totalSupply\n    );\n    const total = await this.adapter.evaluateTransaction(ctx, \"TotalSupply\");\n    return Number(this.decode(total));\n  }\n\n  /**\n   * Retrieves the balance of the ERC20 token for a specified owner.\n   *\n   * @description\n   * This function interacts with the blockchain network to fetch the balance of the ERC20 token for a given owner.\n   * It calls the \"BalanceOf\" transaction on the smart contract with the provided owner's address as a parameter.\n   * The returned data is then decoded and converted to a number.\n   *\n   * @param owner - The address of the ERC20 token owner.\n   *\n   * @returns {Promise<number>} A promise that resolves with the balance of the ERC20 token for the specified owner.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async balanceOf(\n    owner: string,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { ctx } = (await this.logCtx(args, \"balance\", true)).for(\n      this.balanceOf\n    );\n    const balance = await this.adapter.evaluateTransaction(ctx, \"BalanceOf\", [\n      owner,\n    ]);\n    return Number(this.decode(balance));\n  }\n\n  /**\n   * Transfers a specified amount of ERC20 tokens to a recipient.\n   *\n   * @description\n   * This function interacts with the blockchain network to transfer a specified amount of ERC20 tokens to a recipient.\n   * It calls the \"Transfer\" transaction on the smart contract with the recipient's address and the transfer amount as parameters.\n   * The returned data is then decoded and checked to determine if the transfer was successful.\n   *\n   * @param to - The address of the recipient.\n   * @param value - The amount of ERC20 tokens to transfer.\n   *\n   * @returns {Promise<boolean>} A promise that resolves with `true` if the transfer was successful, and `false` otherwise.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async transfer(\n    to: string,\n    value: number,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<boolean> {\n    const { ctx } = (await this.logCtx(args, \"transfer\", true)).for(\n      this.transfer\n    );\n    const transferred = await this.adapter.submitTransaction(ctx, \"Transfer\", [\n      to,\n      value.toString(),\n    ]);\n    return this.decode(transferred) === \"true\" ? true : false;\n  }\n\n  /**\n   * Transfers a specified amount of ERC20 tokens from one account to another.\n   *\n   * @description\n   * This function interacts with the blockchain network to transfer a specified amount of ERC20 tokens from one account to another.\n   * For this transfer to work the spender ( account that will trigger this function ) need to have the value approved as an allowance by the sender.\n   * It calls the \"TransferFrom\" transaction on the smart contract with the sender's address, recipient's address, and the transfer amount as parameters.\n   * The returned data is then decoded and checked to determine if the transfer was successful.\n   *\n   * @param from - The address of the sender.\n   * @param to - The address of the recipient.\n   * @param value - The amount of ERC20 tokens to transfer.\n   *\n   * @returns {Promise<boolean>} A promise that resolves with `true` if the transfer was successful, and `false` otherwise.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async transferFrom(\n    from: string,\n    to: string,\n    value: number\n  ): Promise<boolean> {\n    const contextArgs = await Context.args(\n      \"transferFrom\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.transferFrom);\n    const transferred = await this.adapter.submitTransaction(\n      ctx,\n      \"TransferFrom\",\n      [from, to, value.toString()]\n    );\n\n    return this.decode(transferred) === \"true\" ? true : false;\n  }\n\n  /**\n   * Approves a specified amount of ERC20 tokens to be spent by a specified spender.\n   *\n   * This function interacts with the blockchain network to approve a specified amount of ERC20 tokens to be spent by a specified spender.\n   * It calls the \"Approve\" transaction on the smart contract with the spender's address and the approval amount as parameters.\n   * The returned data is then decoded and checked to determine if the approval was successful.\n   *\n   * @param spender - The address of the spender.\n   * @param value - The amount of ERC20 tokens to approve for the spender.\n   *\n   * @returns {Promise<boolean>} A promise that resolves with `true` if the approval was successful, and `false` otherwise.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async approve(spender: string, value: number): Promise<boolean> {\n    const contextArgs = await Context.args(\n      \"approve\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.approve);\n    const approved = await this.adapter.submitTransaction(ctx, \"Approve\", [\n      spender,\n      value.toString(),\n    ]);\n    return this.decode(approved) === \"true\" ? true : false;\n  }\n\n  /**\n   * Retrieves the allowance of ERC20 tokens that the specified owner has approved for a spender.\n   *\n   * @description\n   * This function interacts with the blockchain network to fetch the allowance of ERC20 tokens that the specified owner has approved for a spender.\n   * It calls the \"Allowance\" transaction on the smart contract with the owner's address and the spender's address as parameters.\n   * The returned data is then decoded and converted to a number.\n   *\n   * @param owner - The address of the ERC20 token owner.\n   * @param spender - The address of the spender.\n   *\n   * @returns {Promise<number>} A promise that resolves with the allowance of ERC20 tokens that the specified owner has approved for the spender.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async allowance(owner: string, spender: string): Promise<number> {\n    const contextArgs = await Context.args(\n      \"allowance\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.allowance);\n    const allowance = await this.adapter.submitTransaction(ctx, \"Allowance\", [\n      owner,\n      spender,\n    ]);\n    return Number(this.decode(allowance));\n  }\n\n  /**\n   * Initializes the ERC20 contract with the provided token information.\n   *\n   * @description\n   * This function interacts with the blockchain network to initialize the ERC20 contract with the given token information.\n   * It calls the \"Initialize\" transaction on the smart contract with the serialized token data as a parameter.\n   * The returned data is then decoded and checked to determine if the initialization was successful.\n   *\n   * @param token - The ERC20 token information to initialize the contract with.\n   *\n   * @returns {Promise<boolean>} A promise that resolves with `true` if the initialization was successful, and `false` otherwise.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async initialize(token: ERC20Token): Promise<boolean> {\n    const contextArgs = await Context.args(\n      \"initialize\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.initialize);\n    const initiliazed = await this.adapter.submitTransaction(\n      ctx,\n      \"Initialize\",\n      [FabricERC20ClientRepository.serializer.serialize(token)]\n    );\n\n    return this.decode(initiliazed) === \"true\" ? true : false;\n  }\n\n  /**\n   * Checks if the ERC20 contract has been initialized.\n   *\n   * This function interacts with the blockchain network to verify if the ERC20 contract has been initialized.\n   * It calls the \"CheckInitialized\" transaction on the smart contract, which does not require any parameters.\n   *\n   * @returns {Promise<void>} A promise that resolves when the initialization check is completed.\n   *\n   * @throws {Error} If the transaction fails.\n   */\n  async checkInitialized(): Promise<void> {\n    const contextArgs = await Context.args(\n      \"checkInitialized\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.checkInitialized);\n    await this.adapter.evaluateTransaction(ctx, \"CheckInitialized\");\n  }\n\n  /**\n   * Mints a specified amount of ERC20 tokens.\n   *\n   * @description\n   * This function interacts with the blockchain network to mint a specified amount of ERC20 tokens.\n   * It calls the \"Mint\" transaction on the smart contract with the minting amount as a parameter.\n   * The function does not return any value, but it updates the minter's number of tokens.\n   *\n   * @param amount - The amount of ERC20 tokens to mint.\n   *\n   * @returns {Promise<void>} A promise that resolves when the minting process is completed.\n   *\n   * @throws {Error} If the transaction fails.\n   */\n  async mint(amount: number): Promise<void> {\n    const contextArgs = await Context.args(\n      \"mint\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.mint);\n    await this.adapter.submitTransaction(ctx, \"Mint\", [amount.toString()]);\n  }\n\n  /**\n   * Burns a specified amount of ERC20 tokens from the minter's account.\n   *\n   * This function interacts with the blockchain network to burn a specified amount of ERC20 tokens.\n   * It calls the \"Burn\" transaction on the smart contract with the burning amount as a parameter.\n   * The function does not return any value, but it decreases the minter's number of tokens.\n   *\n   * @param amount - The amount of ERC20 tokens to burn.\n   *\n   * @returns {Promise<void>} A promise that resolves when the burning process is completed.\n   *\n   * @throws {Error} If the transaction fails.\n   */\n  async burn(amount: number): Promise<void> {\n    const contextArgs = await Context.args(\n      \"burn\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.burn);\n    await this.adapter.submitTransaction(ctx, \"Burn\", [amount.toString()]);\n  }\n\n  /**\n   * Burns a specified amount of ERC20 tokens from a specified account.\n   *\n   * This function interacts with the blockchain network to burn a specified amount of ERC20 tokens from a given account.\n   * It calls the \"BurnFrom\" transaction on the smart contract with the account's address and the burning amount as parameters.\n   * The function does not return any value, but it decreases the specified account's number of tokens.\n   *\n   * @param account - The address of the account from which to burn the ERC20 tokens.\n   * @param amount - The amount of ERC20 tokens to burn.\n   *\n   * @returns {Promise<void>} A promise that resolves when the burning process is completed.\n   *\n   * @throws {Error} If the transaction fails.\n   */\n  async burnFrom(account: string, amount: number): Promise<void> {\n    const contextArgs = await Context.args(\n      \"burnFrom\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.burnFrom);\n    await this.adapter.submitTransaction(ctx, \"BurnFrom\", [\n      account,\n      amount.toString(),\n    ]);\n  }\n\n  /**\n   * Retrieves the balance of ERC20 tokens associated with the client's account.\n   *\n   * This function interacts with the blockchain network to fetch the balance of ERC20 tokens associated with the client's account.\n   * It calls the \"ClientAccountBalance\" transaction on the smart contract, which does not require any parameters.\n   * The returned data is then decoded and converted to a number.\n   *\n   * @returns {Promise<number>} A promise that resolves with the balance of ERC20 tokens associated with the client's account.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async clientAccountBalance(): Promise<number> {\n    const contextArgs = await Context.args(\n      \"accountBalance\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.clientAccountBalance);\n    const serializedAccountBalance = await this.adapter.evaluateTransaction(\n      ctx,\n      \"ClientAccountBalance\"\n    );\n\n    return Number(this.decode(serializedAccountBalance));\n  }\n\n  /**\n   * Retrieves the client's account ID from the blockchain network.\n   *\n   * This function interacts with the blockchain network to fetch the client's account ID.\n   * It calls the \"ClientAccountID\" transaction on the smart contract, which does not require any parameters.\n   * The returned data is then decoded and returned as a string.\n   *\n   * @returns {Promise<string>} A promise that resolves with the client's account ID.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async clientAccountID(): Promise<string> {\n    const contextArgs = await Context.args(\n      \"accountId\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.clientAccountID);\n    const clientAccountID = await this.adapter.evaluateTransaction(\n      ctx,\n      \"ClientAccountID\"\n    );\n\n    return this.decode(clientAccountID);\n  }\n}\n","import { Model } from \"@decaf-ts/decorator-validation\";\nimport { InternalError, PrimaryKeyType } from \"@decaf-ts/db-decorators\";\nimport { Constructor } from \"@decaf-ts/decoration\";\nimport { SequenceOptions } from \"@decaf-ts/core\";\nimport { composeAttributeValue } from \"@decaf-ts/db-decorators\";\n\nexport function extractIds<M extends Model>(\n  clazz: Constructor<M>,\n  models: M | M[] | Record<string, any> | Record<string, any>[],\n  ids: PrimaryKeyType | PrimaryKeyType[]\n) {\n  let pk: keyof M;\n  let composed: any;\n  let pkProps: SequenceOptions;\n\n  function extractId(m: M | Record<string, any>, ids: PrimaryKeyType) {\n    pk = pk || Model.pk(clazz);\n    pkProps = pkProps || Model.sequenceFor(clazz);\n    composed = composed || Model.composed(clazz, pk);\n\n    if (composed) {\n      return composeAttributeValue(m as any, composed);\n    }\n\n    const id = (m as any)[pk] || ids;\n    if (typeof id === \"undefined\")\n      throw new InternalError(`could not rebuild id for ${m.constructor.name}`);\n    return id;\n  }\n\n  if (Array.isArray(models)) {\n    if (!Array.isArray(ids) || ids.length !== models.length)\n      throw new InternalError(\n        \"inconsistent parameters. both must be arrays of equal length\"\n      );\n    return models.map((m, i) => extractId(m, ids[i]));\n  }\n  return extractId(models, ids as PrimaryKeyType);\n}\n","import { BaseModel, column, pk } from \"@decaf-ts/core\";\nimport { model, type ModelArg, required } from \"@decaf-ts/decorator-validation\";\nimport { description } from \"@decaf-ts/decoration\";\n\n/**\n * @description Identity credential model storing cryptographic materials\n * @summary Holds certificate chain and private key information for a Fabric identity, managed as a separate entity linked from Identity\n * @param {ModelArg<IdentityCredentials>} [arg] - Optional initialization object used to populate model fields\n * @class IdentityCredentials\n * @example\n * // Create credentials entry\n * const creds = new IdentityCredentials({ id: \"creds1\", certificate: \"...\", rootCertificate: \"...\", privateKey: \"...\" });\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Model as IdentityCredentials\n *   App->>Model: new IdentityCredentials({ id, certificate, rootCertificate, privateKey })\n *   Model-->>App: instance\n * @see model\n */\n@model()\nexport class IdentityCredentials extends BaseModel {\n  /**\n   * @description Unique identifier of the credentials record\n   * @summary Primary key for referencing this credentials entry\n   */\n  @description(\"Unique identifier of the credentials record\")\n  @column()\n  @pk()\n  id!: string;\n\n  /**\n   * @description PEM-encoded X.509 certificate for the identity\n   * @summary Leaf certificate associated with the identity\n   */\n  @description(\"PEM-encoded X.509 certificate for the identity\")\n  @column()\n  @required()\n  certificate!: string;\n\n  /**\n   * @description PEM-encoded root or intermediate certificate\n   * @summary Root of trust used to validate the leaf certificate\n   */\n  @description(\"PEM-encoded root or intermediate certificate\")\n  @column()\n  @required()\n  rootCertificate!: string;\n\n  /**\n   * @description PEM-encoded private key material\n   * @summary Private key corresponding to the identity certificate\n   */\n  @description(\"PEM-encoded private key\")\n  @column()\n  @required()\n  privateKey!: string;\n\n  constructor(arg?: ModelArg<IdentityCredentials>) {\n    super(arg);\n  }\n}\n","/**\n * @description Keys used to mark Fabric-specific model metadata\n * @summary Enumeration of special keys used by the serialization layer to persist Fabric-related flags on models\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.shared\n */\nexport enum FabricModelKeys {\n  /** Private data marker used to tag properties or models for Fabric private collections */\n  PRIVATE = \"private\",\n  SHARED = \"shared\",\n  /** Namespace prefix used for Fabric-specific metadata keys */\n  FABRIC = \"fabric\",\n  OWNED_BY = \"owned-by\",\n  TRANSACTION_ID = \"transaction-id\",\n  MIRROR = \"mirror\",\n}\n/**\n * @description Supported identity types for Fabric credentials\n * @summary Enumeration of identity formats recognized by this library\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.shared\n */\nexport enum IdentityType {\n  /** Standard X.509 identity format used by Hyperledger Fabric */\n  X509 = \"X.509\",\n}\n\n/**\n * @description String identifier for the Fabric adapter flavour\n * @summary Used to tag adapters/repositories that operate against Hyperledger Fabric\n * @const FabricFlavour\n * @memberOf module:for-fabric.shared\n */\nexport const FabricFlavour = \"hlf-fabric\";\n","import {\n  BaseModel,\n  Cascade,\n  column,\n  index,\n  oneToOne,\n  pk,\n} from \"@decaf-ts/core\";\nimport { model, type ModelArg, required } from \"@decaf-ts/decorator-validation\";\nimport { IdentityCredentials } from \"./IdentityCredentials\";\nimport { IdentityType } from \"../constants\";\nimport { description } from \"@decaf-ts/decoration\";\n\n/**\n * @description Identity model representing a Fabric wallet entry\n * @summary Encapsulates an identity stored in a Fabric wallet, including its MSP identifier, credential linkage, and type information. Built on BaseModel for integration with Decaf validation and persistence.\n * @param {ModelArg<Identity>} [arg] - Optional initialization object used to populate model fields\n * @class Identity\n * @example\n * // Create a new identity referencing existing credentials\n * const id = new Identity({ id: \"user1\", mspId: \"Org1MSP\", type: IdentityType.X509 });\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Model as Identity\n *   App->>Model: new Identity({ id, mspId, type })\n *   Model-->>App: instance\n */\n@model()\nexport class Identity extends BaseModel {\n  /**\n   * @description Unique identifier of the identity in the wallet\n   * @summary Primary key used to reference this identity record\n   */\n  @description(\"Unique identifier of the identity\")\n  @pk()\n  id!: string;\n\n  /**\n   * @description Link to the identity credentials stored separately\n   * @summary One-to-one relationship to the credentials entity; cascades on update and delete\n   */\n  @oneToOne(IdentityCredentials, {\n    update: Cascade.CASCADE,\n    delete: Cascade.CASCADE,\n  })\n  credentials!: IdentityCredentials;\n\n  /**\n   * @description Membership Service Provider identifier\n   * @summary The MSP ID corresponding to the organization that issued this identity\n   */\n  @column()\n  @required()\n  @index()\n  mspId!: string;\n\n  /**\n   * @description Type of identity\n   * @summary Indicates the identity encoding/format; defaults to X.509\n   */\n  @column()\n  @required()\n  type: IdentityType = IdentityType.X509;\n\n  constructor(arg: ModelArg<Identity>) {\n    super(arg);\n  }\n}\n","import { stringFormat } from \"@decaf-ts/decorator-validation\";\nimport { Logger, MiniLogger } from \"@decaf-ts/logging\";\nimport { Identity, Signer, signers } from \"@hyperledger/fabric-gateway\";\nimport { CryptoSetting, ICryptoSuite, User } from \"fabric-common\";\nimport { HSMOptions } from \"../shared/types\";\nimport { normalizeImport } from \"@decaf-ts/core\";\nimport crypto, { X509Certificate } from \"crypto\";\nimport { X509Certificate as X509Cert } from \"@peculiar/x509\";\n\n/**\n * @description Core utilities for interacting with files, crypto identities, and Fabric SDK helpers\n * @summary Provides static helper methods to read credentials and keys from disk or raw content, construct Fabric gateway Identities and Signers, and perform common filesystem operations used by the Fabric client tooling.\n * @class CoreUtils\n * @example\n * // Read an identity and signer from directories\n * const identity = await CoreUtils.getIdentity('Org1MSP', '/msp/signcerts');\n * const signer = await CoreUtils.getSigner('/msp/keystore');\n * // Build a CA user\n * const user = await CoreUtils.getCAUser('appUser', pemKey, pemCert, 'Org1MSP');\n */\nexport class CoreUtils {\n  private static logger: Logger = new MiniLogger(CoreUtils.name);\n\n  private static cryptoSuite: ICryptoSuite;\n\n  private constructor() {}\n\n  /**\n   * @description Resolve file content from a path or return provided raw content\n   * @summary If the input is a Uint8Array or PEM content, returns it as-is; otherwise uses a provided async fileReader to load the content from disk.\n   * @param {string|Uint8Array} contentOrPath - Either a raw content buffer/string or a filesystem path\n   * @param {function(string): Promise<string|Uint8Array|Buffer>} fileReader - Async function to read file content when a path is provided\n   * @return {Promise<string|Uint8Array|Buffer>} The content to be used downstream\n   */\n  private static async contentOfLoadFile(\n    contentOrPath: string | Uint8Array,\n    fileReader: (path: string) => Promise<string | Uint8Array | Buffer>\n  ) {\n    if (contentOrPath instanceof Uint8Array) return contentOrPath;\n    if (\n      contentOrPath.match(\n        /-----BEGIN (CERTIFICATE|KEY|PRIVATE KEY)-----.+?-----END \\1-----$/gms\n      )\n    )\n      return contentOrPath;\n    return await fileReader(contentOrPath);\n  }\n\n  /**\n   * @description Read file content from a path or return provided Buffer\n   * @summary Convenience wrapper that loads a file using fs.promises when a path string is provided; otherwise returns the given Buffer directly.\n   * @param {string|Buffer} contentOrPath - Path to a file on disk or an already-loaded Buffer\n   * @return {Promise<string|Uint8Array|Buffer>} The file content as a Buffer/string depending on reader\n   */\n  static async readFile(contentOrPath: string | Buffer) {\n    if (typeof contentOrPath !== \"string\") return contentOrPath;\n\n    const fileReader = async (path: string) => {\n      const { promises } = await normalizeImport(import(\"fs\"));\n      return await promises.readFile(path);\n    };\n\n    return await fileReader(contentOrPath);\n  }\n\n  /**\n   * @description Create a Fabric CA User object with enrollment\n   * @summary Constructs a fabric-common User, sets a crypto suite, imports the provided private key, and sets enrollment with certificate and MSP ID.\n   * @param {string} userName - The user name for the CA user\n   * @param {string} privateKey - PEM-encoded private key\n   * @param {string} certificate - PEM-encoded X.509 certificate\n   * @param {string} mspId - Membership Service Provider identifier\n   * @return {Promise<User>} The enrolled Fabric User instance\n   */\n  static async getCAUser(\n    userName: string,\n    privateKey: string | undefined,\n    certificate: string,\n    mspId: string,\n    options?: { hsm?: HSMOptions }\n  ): Promise<User> {\n    this.logger.debug(\n      stringFormat(\n        \"Creating CA {0} user {1} with certificate {2}\",\n        mspId,\n        userName,\n        certificate\n      )\n    );\n    const user = new User(userName);\n    const config = options?.hsm\n      ? {\n          software: false,\n          lib: options.hsm.library,\n          slot: options.hsm.slot,\n          label: options.hsm.tokenLabel,\n          pin: String(options.hsm.pin),\n        }\n      : undefined;\n    const cryptoSuite = this.getCryptoSuite(config);\n\n    user.setCryptoSuite(cryptoSuite);\n    const enrollmentKey = options?.hsm\n      ? await this.getHSMEnrollmentKey(cryptoSuite, certificate, options.hsm)\n      : this.getSoftwareEnrollmentKey(cryptoSuite, privateKey);\n    await user.setEnrollment(enrollmentKey, certificate, mspId);\n    return user;\n  }\n\n  static getCryptoSuite(options?: CryptoSetting): ICryptoSuite {\n    if (!options) return User.newCryptoSuite();\n    if (CoreUtils.cryptoSuite) return CoreUtils.cryptoSuite;\n\n    CoreUtils.cryptoSuite = User.newCryptoSuite(options);\n    return CoreUtils.cryptoSuite;\n  }\n\n  private static getSoftwareEnrollmentKey(\n    cryptoSuite: any,\n    privateKey?: string\n  ) {\n    if (!privateKey) {\n      throw new Error(\n        \"Private key must be provided when HSM configuration is not supplied\"\n      );\n    }\n    return cryptoSuite.createKeyFromRaw(privateKey);\n  }\n\n  private static async getHSMEnrollmentKey(\n    cryptoSuite: any,\n    certificate: string,\n    hsm: HSMOptions\n  ) {\n    const ski =\n      hsm.keyIdHex && hsm.keyIdHex.trim().length > 0\n        ? Buffer.from(hsm.keyIdHex, \"hex\")\n        : await this.getCertificateSKI(certificate);\n    const key = await cryptoSuite.getKey(ski);\n    if (!key || (typeof key.isPrivate === \"function\" && !key.isPrivate())) {\n      throw new Error(\"Unable to resolve private key from HSM\");\n    }\n    return key;\n  }\n\n  static async getCertificateSKI(certificate: string): Promise<Buffer> {\n    const x509 = new X509Certificate(certificate);\n    const jwk = x509.publicKey.export({ format: \"jwk\" });\n    const prefix = Buffer.from([0x04]);\n    const x = Buffer.from(jwk.x || \"\", \"base64url\");\n    const y = Buffer.from(jwk.y || \"\", \"base64url\");\n    return crypto\n      .createHash(\"sha256\")\n      .update(Buffer.concat([prefix, x, y]))\n      .digest();\n  }\n\n  /**\n   * @description Build a Fabric Gateway Identity from an MSP ID and certificate\n   * @summary Reads a certificate from a directory path or accepts raw content and returns an Identity object suitable for the Fabric Gateway.\n   * @param {string} mspId - Membership Service Provider ID\n   * @param {string} certDirectoryPath - Path to a directory containing the certificate file, or PEM content\n   * @return {Promise<Identity>} The identity containing mspId and certificate credentials\n   */\n  static async getIdentity(\n    mspId: string,\n    certDirectoryPath: string\n  ): Promise<Identity> {\n    const identityFileReader = async (path: string) => {\n      const { promises } = await normalizeImport(import(\"fs\"));\n      const certPath = await this.getFirstDirFileName(path);\n      const credentials = await promises.readFile(certPath);\n      return credentials;\n    };\n\n    const credentials: Uint8Array = (await this.contentOfLoadFile(\n      certDirectoryPath,\n      identityFileReader\n    )) as Uint8Array;\n\n    return { mspId, credentials };\n  }\n\n  static async getFirstDirFileName(dirPath: string): Promise<string> {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    const { join } = await normalizeImport(import(\"path\"));\n    const files = await promises.readdir(dirPath);\n    return join(dirPath, files[0]);\n  }\n\n  static async getFirstDirFileNameContent(dirPath: string): Promise<string> {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    const { join } = await normalizeImport(import(\"path\"));\n    const files = await promises.readdir(dirPath);\n    return (await promises.readFile(join(dirPath, files[0]))).toString();\n  }\n\n  static async getFileContent(filePath: string): Promise<string> {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    return (await promises.readFile(filePath)).toString();\n  }\n\n  static async getSigner(keyDirectoryPath: string): Promise<Signer> {\n    const signerFileReader = async (path: string) => {\n      const { promises } = await normalizeImport(import(\"fs\"));\n      const keyPath = await this.getFirstDirFileName(path);\n      return await promises.readFile(keyPath);\n    };\n\n    const privateKeyPem = (await this.contentOfLoadFile(\n      keyDirectoryPath,\n      signerFileReader\n    )) as Buffer;\n    const privateKey = await this.extractPrivateKey(privateKeyPem);\n    const keys = Object.getOwnPropertySymbols(privateKey);\n    const k = (privateKey as any)[keys[0]];\n    // --\n\n    return signers.newPrivateKeySigner(k as any);\n  }\n\n  private static async extractPrivateKey(pem: Buffer) {\n    const libName = \"crypto\";\n    let subtle: any;\n    if (\n      (globalThis as any).window &&\n      ((globalThis as any).window as { Crypto: any }).Crypto\n    ) {\n      subtle = ((globalThis as any).Crypto as any).subtle;\n    } else {\n      const lib = (await normalizeImport(import(libName))) as any;\n      subtle = lib.subtle || lib.webcrypto.subtle;\n    }\n\n    if (!subtle) throw new Error(\"Could not load SubtleCrypto module\");\n\n    function str2ab(str: string) {\n      const buf = new ArrayBuffer(str.length);\n      const bufView = new Uint8Array(buf);\n      for (let i = 0, strLen = str.length; i < strLen; i++) {\n        bufView[i] = str.charCodeAt(i);\n      }\n      return buf;\n    }\n\n    const str = pem\n      .toString(\"utf8\")\n      .replace(\"-----BEGIN PRIVATE KEY-----\", \"\")\n      .replaceAll(\"\\n\", \"\")\n      .replace(\"-----END PRIVATE KEY-----\", \"\");\n    const decoded = Buffer.from(str, \"base64\").toString(\"binary\");\n    const binaryDer = str2ab(decoded);\n    const key = await subtle.importKey(\n      \"pkcs8\",\n      binaryDer,\n      {\n        name: \"ECDSA\",\n        namedCurve: \"P-256\",\n      },\n      true,\n      [\"sign\"]\n    );\n\n    return key;\n  }\n}\n\n/**\n * Extracts the certificate Serial Number and the AKI (Authority Key Identifier)\n * in the format Fabric CA expects (plain hex, no colons).\n */\nexport function getAkiAndSerialFromCert(cert: string): {\n  aki: string;\n  serial: string;\n} {\n  const x509Certificate = new X509Cert(cert);\n\n  // Find the AKI (Authority Key Identifier) extension by its OID: 2.5.29.35\n  const akiExt = x509Certificate.extensions?.find(\n    (e) => e.type === \"2.5.29.35\"\n  );\n  if (!akiExt) {\n    throw new Error(\n      \"Authority Key Identifier (AKI) extension not found in certificate.\"\n    );\n  }\n\n  // akiExt.value is the extension content in DER bytes. Convert it to a hex string.\n  let aki = Buffer.from(new Uint8Array(akiExt.value))\n    .toString(\"hex\")\n    .toUpperCase();\n\n  /**\n   * Common case:\n   * The DER-encoded AKI extension often starts with:\n   *   30 16 80 14 <20-byte keyIdentifier>\n   * In hex, that's \"30168014\" + 40 hex chars (20 bytes).\n   *\n   * Fabric CA expects ONLY the 20-byte keyIdentifier (40 hex chars),\n   * so we strip the \"30168014\" prefix when present.\n   */\n  if (aki.startsWith(\"30168014\") && aki.length >= 8 + 40)\n    aki = aki.slice(8, 8 + 40);\n\n  return { aki, serial: x509Certificate.serialNumber };\n}\n","import * as x509 from \"@peculiar/x509\";\nimport { Crypto, CryptoKey } from \"@peculiar/webcrypto\";\nimport { stringFormat } from \"@decaf-ts/decorator-validation\";\nimport { isBrowser, MiniLogger } from \"@decaf-ts/logging\";\n\nconst crypto = new Crypto();\nx509.cryptoProvider.set(crypto);\n\nexport enum BASE_ALPHABET {\n  BASE2 = \"01\",\n  BASE8 = \"01234567\",\n  BASE11 = \"0123456789a\",\n  BASE16 = \"0123456789abcdef\",\n  BASE32 = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\",\n  BASE32_Z = \"ybndrfg8ejkmcpqxot1uwisza345h769\",\n  BASE36 = \"0123456789abcdefghijklmnopqrstuvwxyz\",\n  BASE58 = \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\",\n  BASE62 = \"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ\",\n  BASE64 = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\",\n  BASE67 = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.!~\",\n}\n\nexport type keyObject = {\n  iv: ArrayBuffer;\n  key: CryptoKey;\n};\n\nexport enum CRYPTO {\n  HASH = \"SHA-256\",\n  ITERATIONS = 1000,\n  KEYLENGTH = 48,\n  DERIVED_IV_LENGTH = 16,\n  DERIVED_KEY_LENGTH = 32, // Because SHA-256 used has a native size of 32 bytes\n  ALGORYTHM = \"AES-GCM\",\n  KEY_ALGORYTHM = \"PBKDF2\",\n}\n\nexport class BaseEncoder {\n  private readonly baseMap: Uint8Array = new Uint8Array(256);\n  private readonly base: number;\n  private readonly leader: string;\n  private readonly factor: number;\n  private readonly iFactor: number;\n\n  constructor(private alphabet: BASE_ALPHABET) {\n    if (this.alphabet.length >= 255) throw new Error(\"Alphabet too long\");\n\n    for (let j = 0; j < this.baseMap.length; j++) this.baseMap[j] = 255;\n\n    for (let i = 0; i < alphabet.length; i++) {\n      const x = alphabet.charAt(i);\n      const xc = x.charCodeAt(0);\n      if (this.baseMap[xc] !== 255) throw new Error(x + \" is ambiguous\");\n\n      this.baseMap[xc] = i;\n    }\n\n    this.base = this.alphabet.length;\n    this.leader = this.alphabet.charAt(0);\n    this.factor = Math.log(this.base) / Math.log(256); // log(BASE) / log(256), rounded up\n    this.iFactor = Math.log(256) / Math.log(this.base); // log(256) / log(BASE), rounded up\n  }\n\n  encode(source: Uint8Array | DataView | any[] | string) {\n    if (typeof source === \"string\") {\n      source = Buffer.from(source);\n    } else if (ArrayBuffer.isView(source)) {\n      source = new Uint8Array(\n        source.buffer,\n        source.byteOffset,\n        source.byteLength\n      );\n    } else if (Array.isArray(source)) {\n      source = Uint8Array.from(source);\n    }\n\n    if (source.length === 0) return \"\";\n\n    // Skip & count leading zeroes.\n    let zeroes = 0;\n    let length = 0;\n    let pbegin = 0;\n    const pend = source.length;\n    while (pbegin !== pend && source[pbegin] === 0) {\n      pbegin++;\n      zeroes++;\n    }\n    // Allocate enough space in big-endian base58 representation.\n    const size = ((pend - pbegin) * this.iFactor + 1) >>> 0;\n    const b58 = new Uint8Array(size);\n    // Process the bytes.\n    while (pbegin !== pend) {\n      let carry = source[pbegin];\n      // Apply \"b58 = b58 * 256 + ch\".\n      let i = 0;\n      for (\n        let it1 = size - 1;\n        (carry !== 0 || i < length) && it1 !== -1;\n        it1--, i++\n      ) {\n        carry += (256 * b58[it1]) >>> 0;\n        b58[it1] = carry % this.base >>> 0;\n        carry = (carry / this.base) >>> 0;\n      }\n      if (carry !== 0) throw new Error(\"Non-zero carry\");\n\n      length = i;\n      pbegin++;\n    }\n    // Skip leading zeroes in base58 result.\n    let it2 = size - length;\n    while (it2 !== size && b58[it2] === 0) it2++;\n\n    // Translate the result into a string.\n    let str = this.leader.repeat(zeroes);\n    for (; it2 < size; ++it2) {\n      str += this.alphabet.charAt(b58[it2]);\n    }\n    return str;\n  }\n\n  private decodeUnsafe(source: string): Uint8Array | undefined {\n    if (source.length === 0) return new Uint8Array(0);\n\n    let psz = 0;\n    // Skip and count leading '1's.\n    let zeroes = 0;\n    let length = 0;\n    while (source[psz] === this.leader) {\n      zeroes++;\n      psz++;\n    }\n    // Allocate enough space in big-endian base256 representation.\n    const size = ((source.length - psz) * this.factor + 1) >>> 0; // log(58) / log(256), rounded up.\n    const b256 = new Uint8Array(size);\n    // Process the characters.\n    while (source[psz]) {\n      // Decode character\n      let carry = this.baseMap[source.charCodeAt(psz)];\n      // Invalid character\n      if (carry === 255) return;\n\n      let i = 0;\n      for (\n        let it3 = size - 1;\n        (carry !== 0 || i < length) && it3 !== -1;\n        it3--, i++\n      ) {\n        carry += (this.base * b256[it3]) >>> 0;\n        b256[it3] = carry % 256 >>> 0;\n        carry = (carry / 256) >>> 0;\n      }\n      if (carry !== 0) throw new Error(\"Non-zero carry\");\n\n      length = i;\n      psz++;\n    }\n    // Skip leading zeroes in b256.\n    let it4 = size - length;\n    while (it4 !== size && b256[it4] === 0) it4++;\n\n    const vch = new Uint8Array(zeroes + (size - it4));\n    let j = zeroes;\n    while (it4 !== size) vch[j++] = b256[it4++];\n\n    return vch;\n  }\n\n  decode(source: string) {\n    const buffer = this.decodeUnsafe(source);\n    if (buffer) return buffer;\n    throw new Error(\"Non-base\" + this.base + \" character\");\n  }\n}\n\nexport class CryptoUtils {\n  private static readonly b58encoder = new BaseEncoder(BASE_ALPHABET.BASE58);\n  private static readonly logger = new MiniLogger(CryptoUtils.name);\n  private constructor() {}\n\n  static fabricIdFromCertificate(certificate: string) {\n    this.logger.debug(stringFormat(\"Parsing certificate: {0}\", certificate));\n    const cert = new x509.X509Certificate(certificate);\n    const { subject, issuer } = cert;\n    this.logger.debug(\n      stringFormat(\n        \"Certificate parsed with subject {0} and issuer {1}\",\n        subject,\n        issuer\n      )\n    );\n    return `x509::/${subject.replaceAll(\", \", \"/\")}::/${issuer.replaceAll(\", \", \"/\")}`;\n  }\n\n  static encode(str: string): string {\n    return this.b58encoder.encode(str);\n  }\n  static decode(str: string): string {\n    const decoded = this.b58encoder.decode(str);\n    const result = new TextDecoder().decode(decoded);\n    return result;\n  }\n\n  static stringToArrayBuffer(str: string) {\n    const buf = new ArrayBuffer(str.length);\n    const bufView = new Uint8Array(buf);\n    for (let i = 0, strLen = str.length; i < strLen; i++) {\n      bufView[i] = str.charCodeAt(i);\n    }\n    return buf;\n  }\n\n  private static async extractKey(\n    type: \"private\" | \"public\",\n    pem: Buffer | string,\n    usages?: any[]\n  ) {\n    const subtle = crypto.subtle;\n\n    const str = pem\n      .toString(\"utf8\")\n      .replace(\n        new RegExp(`-----BEGIN (${type.toUpperCase()} KEY|CERTIFICATE)-----`),\n        \"\"\n      )\n      .replaceAll(\"\\n\", \"\")\n      .replace(\n        new RegExp(`-----END (${type.toUpperCase()} KEY|CERTIFICATE)-----`),\n        \"\"\n      );\n    const decoded = Buffer.from(str, \"base64\").toString(\"binary\");\n    const binaryDer = this.stringToArrayBuffer(decoded);\n    const key = await subtle.importKey(\n      \"pkcs8\",\n      binaryDer,\n      {\n        name: \"ECDSA\",\n        namedCurve: \"P-256\",\n      },\n      true,\n      usages ? usages : [\"sign\"]\n    );\n\n    return key;\n  }\n\n  static async extractPrivateKey(pem: Buffer | string, usages?: any[]) {\n    return this.extractKey(\"private\", pem, usages);\n  }\n\n  static async extractPublicKey(pem: Buffer | string, usages?: any[]) {\n    return this.extractKey(\"public\", pem, usages);\n  }\n\n  static async sign(privateKey: string, data: Buffer): Promise<string> {\n    const key = await this.extractPrivateKey(privateKey);\n    const buff = (await crypto.subtle.sign(\n      {\n        name: \"ECDSA\",\n        hash: \"SHA-256\",\n      },\n      key,\n      data as any\n    )) as ArrayBuffer;\n\n    return Array.from(new Uint8Array(buff))\n      .map((b) => b.toString(16).padStart(2, \"0\"))\n      .join(\"\");\n  }\n\n  static async verify(\n    certificate: string,\n    signature: Buffer | string,\n    data: Buffer | string\n  ): Promise<boolean> {\n    const cert = new x509.X509Certificate(certificate);\n    const key = await cert.publicKey.export();\n    signature = (\n      typeof signature === \"string\" ? Buffer.from(signature, \"hex\") : signature\n    ) as Buffer;\n    data = (typeof data === \"string\" ? Buffer.from(data) : data) as Buffer;\n    return crypto.subtle.verify(\n      {\n        name: \"ECDSA\",\n        hash: \"SHA-256\",\n      },\n      key,\n      signature as any,\n      data as any\n    );\n  }\n\n  static async encrypt(certificate: string, data: string | Buffer) {\n    const cert = new x509.X509Certificate(certificate);\n    const key = await cert.publicKey.export();\n    data = (typeof data === \"string\" ? Buffer.from(data) : data) as Buffer;\n    const buff = await this.getSubtleCrypto().encrypt(\n      {\n        name: \"ECDSA\",\n      },\n      key,\n      data\n    );\n\n    return Array.from(new Uint8Array(buff))\n      .map((b) => b.toString(16).padStart(2, \"0\"))\n      .join(\"\");\n  }\n\n  private static getSubtleCrypto() {\n    return isBrowser()\n      ? (globalThis as any).window.crypto.subtle\n      : crypto.subtle;\n  }\n\n  static async decrypt(privateKey: string, data: string | Buffer) {\n    const key = await this.extractPrivateKey(privateKey);\n    data = (\n      typeof data === \"string\" ? Buffer.from(data, \"hex\") : data\n    ) as Buffer;\n    return this.getSubtleCrypto().decrypt(\n      {\n        name: \"ECDSA\",\n      },\n      key,\n      data\n    );\n  }\n\n  /**\n   * @summary Util function to get a random master key\n   *\n   * @description If data is not passed, a random ArrayBuffer will be generated\n   *\n   * @param {ArrayBuffer} data encrytion data\n   *\n   * @function getMaster\n   */\n  static async getMaster(data?: ArrayBuffer): Promise<keyObject> {\n    const textEncoder = new TextEncoder();\n    if (data === undefined) {\n      const genGenesis = crypto.randomUUID();\n      data = textEncoder.encode(genGenesis).buffer;\n    }\n\n    const importedKey = await this.getSubtleCrypto().importKey(\n      \"raw\",\n      data,\n      CRYPTO.KEY_ALGORYTHM as string,\n      false,\n      [\"deriveBits\"]\n    );\n\n    return {\n      key: importedKey,\n      iv: data!,\n    };\n  }\n\n  /**\n   * @summary Util function to derive a key from another key\n   *\n   * @param {string} salt\n   * @param {CryptoKey} key Original key\n   *\n   * @function getDerivationKey\n   */\n  static async getDerivationKey(salt: string, key: CryptoKey) {\n    const textEncoder = new TextEncoder();\n    const saltBuffer = textEncoder.encode(salt);\n    const saltHashed = await this.getSubtleCrypto().digest(\n      \"SHA-256\",\n      saltBuffer\n    );\n    const params = {\n      name: CRYPTO.KEY_ALGORYTHM as string,\n      hash: CRYPTO.HASH,\n      salt: saltHashed,\n      iterations: CRYPTO.ITERATIONS,\n    };\n    const derivation = await this.getSubtleCrypto().deriveBits(\n      params,\n      key,\n      CRYPTO.KEYLENGTH * 8\n    );\n    return this.getKey(derivation);\n  }\n\n  /**\n   * @summary Util function to get the key and IV from the CrytoKey array\n   *\n   * @param {ArrayBuffer} derivation\n   *\n   * @function getKey\n   */\n  static async getKey(derivation: ArrayBuffer) {\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    const ivlen = 16;\n    const keylen = 32;\n    const derivedKey = derivation.slice(0, keylen);\n    const iv = derivation.slice(keylen);\n    const importedEncryptionKey = await this.getSubtleCrypto().importKey(\n      \"raw\",\n      derivedKey,\n      { name: CRYPTO.ALGORYTHM as string },\n      false,\n      [\"encrypt\", \"decrypt\"]\n    );\n    return {\n      key: importedEncryptionKey,\n      iv: iv,\n    };\n  }\n\n  /**\n   * @summary Util function to decrypt data\n   *\n   * @param {string} text\n   * @param {keyObject} keyObject\n   *\n   * @function encrypt\n   */\n  static async encryptPin(\n    text: string,\n    keyObject: keyObject\n  ): Promise<ArrayBuffer> {\n    const textEncoder = new TextEncoder();\n    const textBuffer = textEncoder.encode(text);\n    const encryptedText = await this.getSubtleCrypto().encrypt(\n      { name: CRYPTO.ALGORYTHM as string, iv: keyObject.iv },\n      keyObject.key,\n      textBuffer\n    );\n    return encryptedText;\n  }\n\n  /**\n   * @summary Util function to decrypt data\n   *\n   * @param {BufferSource} encryptedText\n   * @param {keyObject} keyObject\n   *\n   * @function decrypt\n   */\n  static async decryptPin(\n    encryptedText: ArrayBuffer,\n    keyObject: keyObject\n  ): Promise<string> {\n    const textDecoder = new TextDecoder();\n    const decryptedText = await this.getSubtleCrypto().decrypt(\n      { name: CRYPTO.ALGORYTHM as string, iv: keyObject.iv },\n      keyObject.key,\n      encryptedText\n    );\n    return textDecoder.decode(decryptedText);\n  }\n}\n","import { BaseError, InternalError } from \"@decaf-ts/db-decorators\";\nimport { AuthorizationError } from \"@decaf-ts/core\";\n// import { MISSING_PRIVATE_DATA_ERROR_MESSAGE } from \"../contracts/private-data\";\n/**\n * @summary Represents an overflow error in arithmetic operations in Smart Contracts\n *\n * @param {string} msg the error message\n *\n * @class OverflowError\n * @extends InternalError\n *\n * @category Errors\n */\nexport class OverflowError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, OverflowError.name);\n  }\n}\n\n/**\n * @summary Represents a failure in balance to perform a transaction in Smart Contracts\n *\n * @param {string} msg the error message\n *\n * @class BalanceError\n * @extends InternalError\n *\n * @category Errors\n */\nexport class BalanceError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, BalanceError.name);\n  }\n}\n\n/**\n * @summary Represents a failure in balance to perform a transaction in Smart Contracts\n *\n * @param {string} msg the error message\n *\n * @class BalanceError\n * @extends InternalError\n *\n * @category Errors\n */\nexport class AllowanceError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, AllowanceError.name);\n  }\n}\n\n/**\n * @summary Represents a failure registrating new entities\n *\n * @param {string} msg the error message\n *\n * @class RegistrationError\n *\n * @categort Errors\n */\nexport class RegistrationError extends AuthorizationError {\n  constructor(msg: string | Error) {\n    super(msg, RegistrationError.name);\n  }\n}\n\n/**\n * @description Error thrown when an unsupported operation is attempted\n * @summary This error is thrown when an operation is requested that is not supported by the current\n * persistence adapter or configuration. It extends the BaseError class and sets a 500 status code.\n * @param {string|Error} msg - The error message or an Error object to wrap\n * @class UnsupportedError\n * @example\n * ```typescript\n * // Throwing an UnsupportedError\n * if (!adapter.supportsTransactions()) {\n *   throw new UnsupportedError('Transactions are not supported by this adapter');\n * }\n *\n * // Catching an UnsupportedError\n * try {\n *   await adapter.beginTransaction();\n * } catch (error) {\n *   if (error instanceof UnsupportedError) {\n *     console.error('Operation not supported:', error.message);\n *   }\n * }\n * ```\n *\n * @category Errors\n */\nexport class MissingContextError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, MissingContextError.name, 500);\n  }\n}\n\nexport class UnauthorizedPrivateDataAccess extends BaseError {\n  constructor(msg: string | Error = \"MISSING_PRIVATE_DATA_ERROR_MESSAGE\") {\n    super(UnauthorizedPrivateDataAccess.name, msg, 403);\n  }\n}\n\n/**\n * Represents an error that occurs when a required initialization step is not performed.\n *\n * @class NotInitializedError\n * @extends BaseError\n *\n * @category Errors\n *\n * @param {string | Error} msg - The error message or an Error object to wrap.\n *\n * @throws {NotInitializedError} - Throws an error when a required initialization step is not performed.\n *\n * @example\n * ```typescript\n * // Initialize the application\n * if (!isInitialized) {\n *   throw new NotInitializedError('Application is not initialized');\n * }\n *\n * // Catching an NotInitializedError\n * try {\n *   // Perform operations that require initialization\n * } catch (error) {\n *   if (error instanceof NotInitializedError) {\n *     console.error('Initialization error:', error.message);\n *   }\n * }\n * ```\n */\nexport class NotInitializedError extends BaseError {\n  constructor(msg: string | Error) {\n    super(NotInitializedError.name, msg, 409);\n  }\n}\n\nexport class MissingPKCSS11Lib extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, MissingPKCSS11Lib.name, 500);\n  }\n}\n\nexport class EndorsementError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, EndorsementError.name, 500);\n  }\n}\n\nexport class MvccReadConflictError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, MvccReadConflictError.name, 500);\n  }\n}\n\nexport class PhantomReadConflictError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, PhantomReadConflictError.name, 500);\n  }\n}\n\nexport class EndorsementPolicyError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, EndorsementPolicyError.name, 500);\n  }\n}\n\nexport class TransactionLimitsError extends InternalError {\n  constructor(\n    message: string | Error,\n    name: string = TransactionLimitsError.name,\n    code = 590\n  ) {\n    super(message, name, code);\n  }\n}\n\nexport class TransactionTimeoutError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, TransactionTimeoutError.name, 591);\n  }\n}\n\nexport class TransactionBufferSizeError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, TransactionBufferSizeError.name, 592);\n  }\n}\n","import FabricCAServices from \"fabric-ca-client\";\nimport {\n  AffiliationService,\n  IdentityService,\n  IEnrollResponse,\n  IRegisterRequest,\n  IServiceResponse,\n  TLSOptions,\n} from \"fabric-ca-client\";\nimport { User } from \"fabric-common\";\nimport { CAConfig, Credentials } from \"../../shared/types\";\nimport { Identity } from \"../../shared/model/Identity\";\nimport { AuthorizationError } from \"@decaf-ts/core\";\nimport {\n  ConflictError,\n  InternalError,\n  NotFoundError,\n} from \"@decaf-ts/db-decorators\";\nimport { CoreUtils } from \"../utils\";\nimport { CA_ROLE } from \"./constants\";\nimport { CryptoUtils } from \"../crypto\";\nimport {\n  CertificateResponse,\n  FabricIdentity,\n  GetCertificatesRequest,\n  IdentityResponse,\n} from \"../../shared/fabric-types\";\nimport { RegistrationError } from \"../../shared/errors\";\nimport { LoggedClass, Logging } from \"@decaf-ts/logging\";\n\n/**\n * @description Hyperledger Fabric CA identity types.\n * @summary Enumerates the supported identity types recognized by Fabric CA for registration and identity management.\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.client\n */\nexport enum HFCAIdentityType {\n  PEER = \"peer\",\n  ORDERER = \"orderer\",\n  CLIENT = \"client\",\n  USER = \"user\",\n  ADMIN = \"admin\",\n}\n/**\n * @description Key/value attribute used during CA registration.\n * @summary Represents an attribute entry that can be attached to a Fabric CA identity during registration, optionally marking it for inclusion in ecert.\n * @interface IKeyValueAttribute\n * @template T\n * @param {string} name - Attribute name.\n * @param {string} value - Attribute value.\n * @param {boolean} [ecert] - Whether the attribute should be included in the enrollment certificate (ECert).\n * @memberOf module:for-fabric.client\n */\nexport interface IKeyValueAttribute {\n  name: string;\n  value: string;\n  ecert?: boolean;\n}\n\n/**\n * @description Standard Fabric CA identity attribute keys.\n * @summary Enumerates well-known Fabric CA attribute keys that can be assigned to identities for delegations and permissions.\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.client\n */\nexport enum HFCAIdentityAttributes {\n  HFREGISTRARROLES = \"hf.Registrar.Roles\",\n  HFREGISTRARDELEGATEROLES = \"hf.Registrar.DelegateRoles\",\n  HFREGISTRARATTRIBUTES = \"hf.Registrar.Attributes\",\n  HFINTERMEDIATECA = \"hf.IntermediateCA\",\n  HFREVOKER = \"hf.Revoker\",\n  HFAFFILIATIONMGR = \"hf.AffiliationMgr\",\n  HFGENCRL = \"hf.GenCRL\",\n}\n\n/**\n * @description Service wrapper for interacting with a Fabric CA.\n * @summary Provides high-level operations for managing identities against a Hyperledger Fabric Certificate Authority, including registration, enrollment, revocation, and administrative queries. Encapsulates lower-level Fabric CA client calls with consistent logging and error mapping.\n * @param {CAConfig} caConfig - Connection and TLS configuration for the target CA.\n * @class FabricEnrollmentService\n * @example\n * // Register and enroll a new user\n * const svc = new FabricEnrollmentService({\n *   url: 'https://localhost:7054',\n *   caName: 'Org1CA',\n *   tls: { trustedRoots: ['/path/to/ca.pem'], verify: false },\n *   caCert: '/path/to/admin/certDir',\n *   caKey: '/path/to/admin/keyDir'\n * });\n * await svc.register({ userName: 'alice', password: 's3cr3t' }, false, 'org1.department1', CA_ROLE.USER);\n * const id = await svc.enroll('alice', 's3cr3t');\n * @mermaid\n * sequenceDiagram\n *   autonumber\n *   participant App\n *   participant Svc as FabricEnrollmentService\n *   participant CA as Fabric CA\n *   App->>Svc: register(credentials, ...)\n *   Svc->>CA: register(request, adminUser)\n *   CA-->>Svc: enrollmentSecret\n *   Svc-->>App: secret\n *   App->>Svc: enroll(enrollmentId, secret)\n *   Svc->>CA: enroll({enrollmentID, secret})\n *   CA-->>Svc: certificates\n *   Svc-->>App: Identity\n */\nexport class FabricEnrollmentService extends LoggedClass {\n  private ca?: FabricCAServices;\n\n  private certificateService?: any;\n\n  private affiliationService?: AffiliationService;\n\n  private identityService?: IdentityService;\n\n  private client?: any;\n\n  private user?: User;\n\n  constructor(private caConfig: CAConfig) {\n    CoreUtils.getCryptoSuite(\n      caConfig.hsm\n        ? {\n            software: false,\n            lib: caConfig.hsm.library,\n            slot: caConfig.hsm.slot,\n            label: caConfig.hsm.tokenLabel,\n            pin: String(caConfig.hsm.pin),\n          }\n        : undefined\n    );\n    super();\n  }\n\n  protected async User(): Promise<User> {\n    if (this.user) return this.user;\n    const { caName, caCert, caKey, url, hsm } = this.caConfig;\n    const log = this.log.for(this.User);\n    log.debug(`Creating CA user for ${caName} at ${url}`);\n    log.debug(`Retrieving CA certificate from ${caCert}`);\n    const certificate = await CoreUtils.getFirstDirFileNameContent(caCert);\n    let key: string | undefined;\n    if (!hsm) {\n      if (!caKey) {\n        throw new InternalError(\n          `Missing caKey configuration for CA ${caName}. Provide a key directory or configure HSM support.`\n        );\n      }\n      log.debug(`Retrieving CA key from ${caKey}`);\n      key = await CoreUtils.getFirstDirFileNameContent(caKey);\n    } else {\n      log.debug(\n        `Using HSM configuration for CA ${caName} with library ${hsm.library}`\n      );\n    }\n    log.debug(`Loading Admin user for ca ${caName}`);\n    this.user = await CoreUtils.getCAUser(\"admin\", key, certificate, caName, {\n      hsm,\n    });\n    return this.user;\n  }\n\n  protected async CA(): Promise<FabricCAServices> {\n    if (this.ca) return this.ca;\n    const log = this.log.for(this.CA);\n    const { url, tls, caName } = this.caConfig;\n\n    // FOR Some Reason the verification fails need to investigate this works for now\n    // eslint-disable-next-line prefer-const\n    let { trustedRoots, verify } = tls as TLSOptions;\n\n    const root = (trustedRoots as string[])[0] as string;\n    log.debug(`Retrieving CA certificate from ${root}. cwd: ${process.cwd()}`);\n\n    const certificate = await CoreUtils.getFileContent(root);\n    log.debug(`Creating CA Client for CA ${caName} under ${url}`);\n    this.ca = new FabricCAServices(\n      url,\n      {\n        trustedRoots: Buffer.from(certificate),\n        verify,\n      } as TLSOptions,\n      caName\n    );\n    return this.ca;\n  }\n\n  protected async Client(): Promise<{ newCertificateService: any }> {\n    if (this.client) return this.client;\n    const ca = await this.CA();\n    this.client = (ca as any)[\"_FabricCAServices\"];\n    return this.client;\n  }\n\n  protected async Certificate() {\n    if (!this.certificateService)\n      this.certificateService = (await this.Client()).newCertificateService();\n    return this.certificateService;\n  }\n\n  protected async Affiliations() {\n    if (!this.affiliationService)\n      this.affiliationService = (await this.CA()).newAffiliationService();\n    return this.affiliationService;\n  }\n\n  protected async Identities() {\n    if (!this.identityService)\n      this.identityService = (await this.CA()).newIdentityService();\n    return this.identityService;\n  }\n\n  /**\n   * @description Retrieve certificates from the CA.\n   * @summary Calls the CA certificate service to list certificates, optionally mapping to PEM strings only.\n   * @param {GetCertificatesRequest} [request] - Optional filter request for certificate lookup.\n   * @param {boolean} [doMap=true] - When true, returns array of PEM strings; otherwise returns full response object.\n   * @return {Promise<string[] | CertificateResponse>} Array of PEM strings or the full certificate response.\n   */\n  async getCertificates(\n    request?: GetCertificatesRequest,\n    doMap = true\n  ): Promise<string[] | CertificateResponse> {\n    const certificateService = await this.Certificate();\n    const user = await this.User();\n    const log = this.log.for(this.getCertificates);\n    log.debug(\n      `Retrieving certificates${request ? ` for ${request.id}` : \"\"} for CA ${this.caConfig.caName}`\n    );\n    const response: CertificateResponse = (\n      await certificateService.getCertificates(request || {}, user)\n    ).result;\n    log.debug(\n      `Found ${response.certs.length} certificates: ${JSON.stringify(response)}`\n    );\n    return doMap ? response.certs.map((c) => c.PEM) : response;\n  }\n\n  /**\n   * @description List identities registered in the CA.\n   * @summary Queries the CA identity service to fetch all identities and returns the list as FabricIdentity objects.\n   * @return {Promise<FabricIdentity[]>} The list of identities registered in the CA.\n   */\n  async getIdentities(): Promise<FabricIdentity[]> {\n    const identitiesService = await this.Identities();\n    const log = this.log.for(this.getIdentities);\n    log.debug(`Retrieving Identities under CA ${this.caConfig.caName}`);\n    const response: IdentityResponse = (\n      await identitiesService.getAll(await this.User())\n    ).result;\n    log.debug(\n      `Found ${response.identities.length} Identities: ${JSON.stringify(response)}`\n    );\n    return response.identities;\n  }\n\n  protected parseError(e: Error) {\n    const regexp = /.*code:\\s(\\d+).*?message:\\s[\"'](.+)[\"']/gs;\n    const match = regexp.exec(e.message);\n    if (!match) return new RegistrationError(e);\n    const [, code, message] = match;\n    switch (code) {\n      case \"74\":\n      case \"71\":\n        return new ConflictError(message);\n      case \"20\":\n        return new AuthorizationError(message);\n      default:\n        return new RegistrationError(message);\n    }\n  }\n\n  /**\n   * @description Retrieve affiliations from the CA.\n   * @summary Queries the CA for the list of affiliations available under the configured CA.\n   * @return {string} The affiliations result payload.\n   */\n  async getAffiliations() {\n    const affiliationService = await this.Affiliations();\n    const log = this.log.for(this.getAffiliations);\n    log.debug(`Retrieving Affiliations under CA ${this.caConfig.caName}`);\n    const response = (await affiliationService.getAll(await this.User()))\n      .result;\n    log.debug(\n      `Found ${response.a.length} Affiliations: ${JSON.stringify(response)}`\n    );\n    return response;\n  }\n\n  /**\n   * @description Read identity details from the CA by enrollment ID.\n   * @summary Retrieves and validates a single identity, throwing NotFoundError when missing.\n   * @param {string} enrollmentId - Enrollment ID to lookup.\n   * @return {Promise<FabricIdentity>} The identity details stored in the CA.\n   */\n  async read(enrollmentId: string) {\n    const ca = await this.CA();\n    const user = await this.User();\n    let result: IServiceResponse;\n    try {\n      result = await ca.newIdentityService().getOne(enrollmentId, user);\n    } catch (e: any) {\n      throw new NotFoundError(\n        `Couldn't find enrollment with id ${enrollmentId}: ${e}`\n      );\n    }\n\n    if (!result.success)\n      throw new NotFoundError(\n        `Couldn't find enrollment with id ${enrollmentId}: ${result.errors.join(\"\\n\")}`\n      );\n\n    return result.result as FabricIdentity;\n  }\n\n  /**\n   * @description Register a new identity with the CA.\n   * @summary Submits a registration request for a new enrollment ID, returning the enrollment secret upon success.\n   * @param {Credentials} model - Credentials containing userName and password for the new identity.\n   * @param {boolean} [isSuperUser=false] - Whether to register the identity as a super user.\n   * @param {string} [affiliation=\"\"] - Affiliation string (e.g., org1.department1).\n   * @param {CA_ROLE | string} [userRole] - Role to assign to the identity.\n   * @param {IKeyValueAttribute} [attrs] - Optional attributes to attach to the identity.\n   * @param {number} [maxEnrollments] - Maximum number of enrollments allowed for the identity.\n   * @return {Promise<string>} The enrollment secret for the registered identity.\n   */\n  async register(\n    model: Credentials,\n    isSuperUser: boolean = false,\n    affiliation: string = \"\",\n    userRole?: CA_ROLE | string,\n    attrs?: IKeyValueAttribute,\n    maxEnrollments?: number\n  ): Promise<string> {\n    let registration: string;\n    const log = this.log.for(this.register);\n    try {\n      const { userName, password } = model;\n      const ca = await this.CA();\n      const user = await this.User();\n      const props = {\n        enrollmentID: userName as string,\n        enrollmentSecret: password,\n        affiliation: affiliation,\n        userRole: userRole,\n        attrs: attrs,\n        maxEnrollments: maxEnrollments,\n      } as IRegisterRequest;\n      registration = await ca.register(props, user);\n      log.info(\n        `Registration for ${userName} created with user type ${userRole ?? \"Undefined Role\"} ${isSuperUser ? \"as super user\" : \"\"}`\n      );\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return registration;\n  }\n\n  protected static identityFromEnrollment(\n    enrollment: IEnrollResponse,\n    mspId: string\n  ): Identity {\n    const { certificate, key, rootCertificate } = enrollment;\n    const log = Logging.for(FabricEnrollmentService, {}).for(\n      this.identityFromEnrollment\n    );\n    log.debug(\n      `Generating Identity from certificate ${certificate} in msp ${mspId}`\n    );\n    const clientId = CryptoUtils.fabricIdFromCertificate(certificate);\n    const id = CryptoUtils.encode(clientId);\n    log.debug(`Identity ${clientId} and encodedId ${id}`);\n    const now = new Date();\n    return new Identity({\n      id: id,\n      credentials: {\n        id: id,\n        certificate: certificate,\n        privateKey: key.toBytes(),\n        rootCertificate: rootCertificate,\n        createdOn: now,\n        updatedOn: now,\n      },\n      mspId: mspId,\n      createdOn: now,\n      updatedOn: now,\n    });\n  }\n\n  /**\n   * @description Enroll an identity with the CA using a registration secret.\n   * @summary Exchanges the enrollment ID and secret for certificates, returning a constructed Identity model.\n   * @param {string} enrollmentId - Enrollment ID to enroll.\n   * @param {string} registration - Enrollment secret returned at registration time.\n   * @return {Promise<Identity>} The enrolled identity object with credentials.\n   */\n  async enroll(enrollmentId: string, registration: string) {\n    let identity: Identity;\n    const log = this.log.for(this.enroll);\n    try {\n      const ca = await this.CA();\n      log.debug(`Enrolling ${enrollmentId}`);\n      const enrollment: IEnrollResponse = await ca.enroll({\n        enrollmentID: enrollmentId,\n        enrollmentSecret: registration,\n      });\n      identity = FabricEnrollmentService.identityFromEnrollment(\n        enrollment,\n        this.caConfig.caName\n      );\n      log.info(\n        `Successfully enrolled ${enrollmentId} under ${this.caConfig.caName} as ${identity.id}`\n      );\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return identity;\n  }\n\n  /**\n   * @description Register and enroll a new identity in one step.\n   * @summary Registers a new enrollment ID with the CA and immediately exchanges the secret to enroll, returning the created Identity.\n   * @param {Credentials} model - Credentials for the new identity containing userName and password.\n   * @param {boolean} [isSuperUser=false] - Whether to register the identity as a super user.\n   * @param {string} [affiliation=\"\"] - Affiliation string (e.g., org1.department1).\n   * @param {CA_ROLE | string} [userRole] - Role to assign to the identity.\n   * @param {IKeyValueAttribute} [attrs] - Optional attributes to attach to the identity.\n   * @param {number} [maxEnrollments] - Maximum number of enrollments allowed for the identity.\n   * @return {Promise<Identity>} The enrolled identity.\n   */\n  async registerAndEnroll(\n    model: Credentials,\n    isSuperUser: boolean = false,\n    affiliation: string = \"\",\n    userRole?: CA_ROLE | string,\n    attrs?: IKeyValueAttribute,\n    maxEnrollments?: number\n  ): Promise<Identity> {\n    const registration = await this.register(\n      model,\n      isSuperUser,\n      affiliation,\n      userRole,\n      attrs,\n      maxEnrollments\n    );\n    const { userName } = model;\n    return this.enroll(userName as string, registration);\n  }\n\n  /**\n   * Revokes the enrollment of an identity with the specified enrollment ID.\n   *\n   * @param enrollmentId - The enrollment ID of the identity to be revoked.\n   *\n   * @returns A Promise that resolves to the result of the revocation operation.\n   *\n   * @throws {NotFoundError} If the enrollment with the specified ID does not exist.\n   * @throws {InternalError} If there is an error during the revocation process.\n   */\n  async revoke(enrollmentId: string) {\n    const ca = await this.CA();\n    const user = await this.User();\n    const identity = await this.read(enrollmentId);\n    if (!identity)\n      throw new NotFoundError(\n        `Could not find enrollment with id ${enrollmentId}`\n      );\n    let result: IServiceResponse;\n    try {\n      result = await ca.revoke(\n        { enrollmentID: identity.id, reason: \"User Deletation\" },\n        user\n      );\n    } catch (e: unknown) {\n      throw new InternalError(\n        `Could not revoke enrollment with id ${enrollmentId}: ${e}`\n      );\n    }\n    if (!result.success)\n      throw new InternalError(\n        `Could not revoke enrollment with id ${enrollmentId}: ${result.errors.join(\"\\n\")}`\n      );\n    return result;\n  }\n}\n","import { IRegisterRequest, IKeyValueAttribute } from \"fabric-ca-client\";\nimport { CA_ROLE } from \"./constants\";\nimport {\n  min,\n  minlength,\n  Model,\n  required,\n} from \"@decaf-ts/decorator-validation\";\nimport { ValidationError } from \"@decaf-ts/db-decorators\";\n\nexport class RegistrationRequestBuilder extends Model {\n  @required()\n  affiliation: string = \"\";\n  @minlength(1)\n  attrs?: IKeyValueAttribute[];\n  @required()\n  enrollmentID!: string;\n  @required()\n  enrollmentSecret!: string;\n  @min(0)\n  maxEnrollments?: number;\n  @required()\n  role!: string;\n\n  build(): IRegisterRequest {\n    const errs = this.hasErrors();\n    if (errs) throw new ValidationError(errs.toString());\n    const response: IRegisterRequest = {\n      enrollmentID: this.enrollmentID,\n      enrollmentSecret: this.enrollmentSecret,\n      role: this.role,\n      affiliation: this.affiliation,\n    };\n    if (typeof this.maxEnrollments !== \"undefined\")\n      response.maxEnrollments = this.maxEnrollments;\n    if (this.attrs) response.attrs = this.attrs;\n    return response;\n  }\n\n  setAffiliation(value: string) {\n    this.affiliation = value;\n    return this;\n  }\n\n  addAttr(attr: IKeyValueAttribute) {\n    this.attrs = this.attrs || [];\n    this.attrs.push(attr);\n    return this;\n  }\n\n  setAttrs(value: IKeyValueAttribute[]) {\n    this.attrs = value;\n    return this;\n  }\n\n  setEnrollmentID(value: string) {\n    this.enrollmentID = value;\n    return this;\n  }\n\n  setEnrollmentSecret(value: string) {\n    this.enrollmentSecret = value;\n    return this;\n  }\n\n  setMaxEnrollments(value: number) {\n    this.maxEnrollments = value;\n    return this;\n  }\n\n  setRole(value: CA_ROLE | string) {\n    this.role = value;\n    return this;\n  }\n}\n","/**\n * Enum representing the events emitted by an ERC20 contract.\n *\n * @remarks\n * This enum is used to identify the specific events that can be emitted by an ERC20 contract.\n * The events are named according to the EIP-20 standard.\n */\nexport enum ERC20Events {\n  /**\n   * Emitted when a `transfer` function is called successfully.\n   *\n   * @param from - The address of the sender.\n   * @param to - The address of the recipient.\n   * @param value - The amount of tokens transferred.\n   */\n  TRANSFER = \"Transfer\",\n\n  /**\n   * Emitted when an `approve` function is called successfully.\n   *\n   * @param owner - The address of the token owner.\n   * @param spender - The address of the approved spender.\n   * @param value - The amount of tokens approved for the spender.\n   */\n  APPROVAL = \"Approval\",\n}\n","import { Model, type ModelArg } from \"@decaf-ts/decorator-validation\";\nimport { column, createdAt, updatedAt } from \"@decaf-ts/core\";\nimport { version } from \"@decaf-ts/db-decorators\";\nimport { description, uses } from \"@decaf-ts/decoration\";\nimport { FabricFlavour } from \"../constants\";\n\n@uses(FabricFlavour)\nexport class FabricBaseModel extends Model {\n  @description(\"Stores the original timestamp of creation\")\n  @column()\n  @createdAt()\n  createdAt!: Date;\n\n  @description(\"Stores the timestamp of the last update\")\n  @column()\n  @updatedAt()\n  updatedAt!: Date;\n\n  @description(\"Stores the version of the model\")\n  @column()\n  @version()\n  version!: number;\n\n  constructor(arg?: ModelArg<FabricBaseModel>) {\n    super(arg);\n  }\n}\n","import { type ModelArg } from \"@decaf-ts/decorator-validation\";\nimport { column, createdBy, updatedBy } from \"@decaf-ts/core\";\nimport { description, uses } from \"@decaf-ts/decoration\";\nimport { FabricFlavour } from \"../constants\";\nimport { FabricBaseModel } from \"./FabricBaseModel\";\n\n@uses(FabricFlavour)\nexport abstract class FabricIdentifiedBaseModel extends FabricBaseModel {\n  @description(\"Stores the creator\")\n  @column()\n  @createdBy()\n  createdBy!: string;\n\n  @description(\"Stores the user that last updated the model\")\n  @column()\n  @updatedBy()\n  updatedBy!: string;\n\n  protected constructor(arg?: ModelArg<FabricIdentifiedBaseModel>) {\n    super(arg);\n  }\n}\n","import { Model } from \"@decaf-ts/decorator-validation\";\nimport { Constructor, Metadata } from \"@decaf-ts/decoration\";\nimport { FabricModelKeys } from \"../constants\";\nimport { SegregatedModel } from \"../types\";\nimport { DBKeys } from \"@decaf-ts/db-decorators\";\nimport { CollectionResolver, MirrorMetadata } from \"../decorators\";\n\nModel.prototype.isShared = function isShared<M extends Model>(\n  this: M\n): boolean {\n  return Model.isShared(this.constructor as Constructor<M>);\n};\n\nModel.prototype.isPrivate = function isPrivate<M extends Model>(\n  this: M\n): boolean {\n  return Model.isPrivate(this.constructor as Constructor<M>);\n};\n\nModel.prototype.segregate = function segregate<M extends Model>(\n  this: M\n): SegregatedModel<M> {\n  return Model.segregate(this);\n};\n\n(Model as any).segregate = function segregate<M extends Model>(\n  model: M\n): SegregatedModel<M> {\n  if (!Model.isTransient(model)) return { model: model };\n  const decoratedProperties =\n    Metadata.getAttributes(model.constructor as any) || [];\n\n  const transientProps = Metadata.get(\n    model.constructor as any,\n    DBKeys.TRANSIENT\n  );\n  const privateProperties = Metadata.get(\n    model.constructor as any,\n    FabricModelKeys.PRIVATE\n  );\n  const sharedProperties = Metadata.get(\n    model.constructor as any,\n    FabricModelKeys.SHARED\n  );\n\n  const result: SegregatedModel<M> = {\n    model: {} as Record<keyof M, any>,\n    public: {} as Record<keyof M, any>,\n    transient: {} as Record<keyof M, any>,\n    privates: {} as Record<keyof M, any>,\n    shared: {} as Record<keyof M, any>,\n  };\n\n  const transientKeys = Object.keys(transientProps || {});\n  const privateKeys = Object.keys(privateProperties || {});\n  const sharedKeys = Object.keys(sharedProperties || {});\n\n  // const pkKey = Model.pk(model.constructor as any);\n  for (const key of decoratedProperties) {\n    const value = model[key as keyof M];\n    const isTransient = transientKeys.includes(key);\n    const isPublic = !isTransient;\n    const isPrivate = privateKeys.includes(key);\n    const isShared = sharedKeys.includes(key);\n    // const isPrimaryKey = key === pkKey;\n\n    if (isTransient || isPrivate || isShared) {\n      result.transient = result.transient || ({} as any);\n      (result.transient as any)[key] = value;\n    }\n    if (isPrivate) {\n      result.privates = result.privates || ({} as any);\n      (result.privates as any)[key] = value;\n    }\n    if (isShared) {\n      result.shared = result.shared || ({} as any);\n      (result.shared as any)[key] = value;\n    }\n    if (isPublic) {\n      result.public = (result.public || {}) as any;\n      (result.public as any)[key] = value;\n    }\n  }\n\n  result.model = Model.build(result.public, model.constructor.name);\n  return result as SegregatedModel<M>;\n}.bind(Model);\n\n(Model as any).isPrivate = function isPrivate<M extends Model>(\n  model: M | Constructor<M>\n): boolean {\n  return !!Metadata.get(\n    typeof model !== \"function\" ? (model.constructor as any) : model,\n    FabricModelKeys.PRIVATE\n  );\n}.bind(Model);\n\n(Model as any).isShared = function isShared<M extends Model>(\n  model: M | Constructor<M>\n): boolean {\n  return !!Metadata.get(\n    typeof model !== \"function\" ? (model.constructor as any) : model,\n    FabricModelKeys.SHARED\n  );\n}.bind(Model);\n\n(Model as any).mirrored = function mirrored<M extends Model>(\n  model: M | Constructor<M>\n): boolean {\n  return Metadata.get(\n    typeof model !== \"function\" ? (model.constructor as any) : model,\n    Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.MIRROR)\n  );\n}.bind(Model);\n\n(Model as any).ownerOf = function ownerOf<M extends Model>(\n  model: M\n): string | undefined {\n  const meta = Metadata.get(\n    model.constructor as any,\n    Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.OWNED_BY)\n  );\n  if (!meta) return undefined;\n  return model[meta as keyof M] as string;\n}.bind(Model);\n\n(Model as any).mirroredAt = function mirroredAt<M extends Model>(\n  model: M | Constructor<M>\n): MirrorMetadata | undefined {\n  model = typeof model !== \"function\" ? (model.constructor as any) : model;\n  return Metadata.get(\n    model as any,\n    Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.MIRROR)\n  );\n}.bind(Model);\n\n(Model as any).collectionsFor = function collectionsFor<M extends Model>(\n  model: M | Constructor<M>\n): {\n  privateCols: (string | CollectionResolver)[];\n  sharedCols: (string | CollectionResolver)[];\n} {\n  const privateKeys: string[] = [FabricModelKeys.PRIVATE] as string[];\n  const sharedKeys: string[] = [FabricModelKeys.SHARED] as string[];\n\n  const privateKey = Metadata.key(...privateKeys);\n  const sharedKey = Metadata.key(...sharedKeys);\n\n  const constr = typeof model === \"function\" ? model : model.constructor;\n\n  const privateMeta: { collections: string[] } = Metadata.get(\n    constr as any,\n    privateKey\n  );\n  const sharedMeta: { collections: string[] } = Metadata.get(\n    constr as any,\n    sharedKey\n  );\n\n  return {\n    privateCols: privateMeta?.collections || [],\n    sharedCols: sharedMeta?.collections || [],\n  };\n}.bind(Model);\n","import {\n  AuthorizationError,\n  Repo,\n  Context,\n  UnsupportedError,\n  Repository,\n  ContextOf,\n} from \"@decaf-ts/core\";\nimport {\n  generated,\n  InternalError,\n  NotFoundError,\n  onCreate,\n  onDelete,\n  onRead,\n  onUpdate,\n  readonly,\n  transient,\n  ValidationError,\n  DBKeys,\n  DBOperations,\n  on,\n} from \"@decaf-ts/db-decorators\";\nimport { Model, required } from \"@decaf-ts/decorator-validation\";\nimport { FabricModelKeys } from \"./constants\";\nimport type { Context as HLContext } from \"fabric-contract-api\";\nimport { ClientIdentity } from \"fabric-shim-api\";\nimport { FabricERC20Contract } from \"../contracts/erc20/erc20contract\";\nimport {\n  apply,\n  Constructor,\n  Decoration,\n  metadata,\n  Metadata,\n  prop,\n  propMetadata,\n} from \"@decaf-ts/decoration\";\nimport { FabricFlags } from \"./types\";\nimport { toPascalCase } from \"@decaf-ts/logging\";\nimport { FabricContractFlags } from \"../contracts/types\";\nimport \"../shared/overrides\";\nimport { type FabricContractContext } from \"../contracts/ContractContext\";\n\n/**\n * @description Extracts the MSP ID from either a string or ClientIdentity object\n * @param identity - The identity value which can be a string MSP ID or ClientIdentity object\n * @returns The MSP ID as a string, or undefined if not available\n */\nexport function extractMspId(\n  identity: string | ClientIdentity | undefined\n): string | undefined {\n  if (!identity) return undefined;\n  if (typeof identity === \"string\") return identity;\n  return identity.getMSPID();\n}\n\n/**\n * Decorator for marking methods that require ownership authorization.\n * Checks the owner of the token before allowing the method to be executed.\n *\n * @example\n * ```typescript\n * class TokenContract extends Contract {\n *   @Owner()\n *   async Mint(ctx: Context, amount: number) {\n *     // Mint token logic\n *   }\n * }\n * ```\n *\n * @returns {MethodDecorator} A method decorator that checks ownership authorization.\n */\nexport function Owner() {\n  return function (\n    target: any,\n    propertyKey: string,\n    descriptor: PropertyDescriptor\n  ) {\n    const originalMethod = descriptor.value;\n\n    descriptor.value = async function (\n      this: FabricERC20Contract,\n      ...args: any[]\n    ) {\n      const ctx: HLContext = args[0];\n      const acountId = ctx.clientIdentity.getID();\n\n      const select = await (this as FabricERC20Contract)[\n        \"tokenRepository\"\n      ].select();\n\n      const tokens = await select.execute(ctx);\n\n      if (tokens.length == 0) {\n        throw new NotFoundError(\"No tokens avaialble\");\n      }\n\n      if (tokens.length > 1) {\n        throw new NotFoundError(`To many token available : ${tokens.length}`);\n      }\n\n      if (tokens[0].owner != acountId) {\n        throw new AuthorizationError(\n          `User not authorized to run ${propertyKey} on the token`\n        );\n      }\n\n      return await originalMethod.apply(this, args);\n    };\n\n    return descriptor;\n  };\n}\n\nexport async function ownedByOnCreate<\n  M extends Model<boolean>,\n  R extends Repo<M>,\n  V,\n>(\n  this: R,\n  context: ContextOf<R>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const { stub } = context as any;\n\n  const allowGenerationOverride =\n    context.get(\"allowGenerationOverride\") || false;\n\n  const creator = await stub.getCreator();\n  const owner = allowGenerationOverride ? model[key] : creator.mspid;\n\n  const setOwnedByKeyValue = function <M extends Model>(\n    target: M,\n    propertyKey: string,\n    value: string | number | bigint\n  ) {\n    Object.defineProperty(target, propertyKey, {\n      enumerable: true,\n      writable: false,\n      configurable: true,\n      value: value,\n    });\n  };\n\n  setOwnedByKeyValue(model, key as string, owner);\n}\n\nexport function ownedBy() {\n  function ownedBy() {\n    return function (obj: any, attribute?: any) {\n      return apply(\n        required(),\n        generated(),\n        readonly(),\n        onCreate(ownedByOnCreate),\n        propMetadata(\n          Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.OWNED_BY),\n          attribute\n        )\n      )(obj, attribute);\n    };\n  }\n\n  return Decoration.for(FabricModelKeys.OWNED_BY)\n    .define({\n      decorator: ownedBy,\n      args: [],\n    })\n    .apply();\n}\n\nexport async function transactionIdOnCreate<\n  M extends Model<boolean>,\n  R extends Repo<M>,\n  V,\n>(\n  this: R,\n  context: ContextOf<R>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const { stub } = context as any;\n  model[key] = stub.getTxID();\n}\n\nexport function transactionId() {\n  function transactionId() {\n    return function (obj: any, attribute?: any) {\n      return apply(\n        required(),\n        readonly(),\n        onCreate(transactionIdOnCreate),\n        onUpdate(transactionIdOnCreate),\n        propMetadata(\n          Metadata.key(\n            FabricModelKeys.FABRIC,\n            attribute,\n            FabricModelKeys.TRANSACTION_ID\n          ),\n          attribute\n        )\n      )(obj, attribute);\n    };\n  }\n\n  return Decoration.for(FabricModelKeys.TRANSACTION_ID)\n    .define({\n      decorator: transactionId,\n      args: [],\n    })\n    .apply();\n}\n\nexport type MirrorCondition = (msp: string) => boolean;\n\nexport type MirrorMetadata = {\n  condition?: MirrorCondition;\n  resolver: CollectionResolver | string;\n  mspId: string;\n};\n\nexport async function evalMirrorMetadata<M extends Model>(\n  model: M,\n  resolver: undefined | string | CollectionResolver,\n  ctx: Context<FabricContractFlags>\n) {\n  let collection: CollectionResolver | string | undefined = resolver;\n  if (typeof collection !== \"string\") {\n    try {\n      const owner =\n        Model.ownerOf(model) || ctx.get(\"stub\").getCreator().toString();\n      if (resolver && typeof resolver === \"function\")\n        collection = await resolver(model, owner, ctx);\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to resolve collection mirror name: ${e}`);\n    }\n  }\n\n  if (!collection || typeof collection !== \"string\")\n    throw new InternalError(\n      `No collection found model ${model.constructor.name}`\n    );\n  return collection;\n}\n\nexport async function createMirrorHandler<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const collection = await evalMirrorMetadata(model, data.resolver, context);\n  const fabricCtx = context as FabricContractContext;\n  const sourceModel = model;\n  // Put mirror flags directly on context so adapter.prepare() and adapter.create() can see them\n  fabricCtx.put(\"mirror\" as any, true);\n  fabricCtx.put(\"mirrorCollection\" as any, collection);\n  try {\n    const repo = this.override(\n      Object.assign({}, (this as any)._overrides, {\n        mirror: true,\n        mirrorCollection: collection,\n        ignoreValidation: true,\n        ignoreHandlers: true,\n      } as any)\n    );\n    const mirror = await repo.create(sourceModel, context);\n    context.logger.info(\n      `Mirror for ${Model.tableName(this.class)} created with ${Model.pk(model) as string}: ${mirror[Model.pk(model)]}`\n    );\n  } finally {\n    // Clean up mirror flags from context\n    fabricCtx.put(\"mirror\" as any, undefined);\n    fabricCtx.put(\"mirrorCollection\" as any, undefined);\n  }\n}\n\nexport async function updateMirrorHandler<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const collection = await evalMirrorMetadata(model, data.resolver, context);\n  const fabricCtx = context as FabricContractContext;\n  const sourceModel = model;\n  fabricCtx.put(\"mirror\" as any, true);\n  fabricCtx.put(\"mirrorCollection\" as any, collection);\n  try {\n    const repo = this.override(\n      Object.assign({}, (this as any)._overrides, {\n        mirror: true,\n        mirrorCollection: collection,\n        ignoreValidation: true,\n        ignoreHandlers: true,\n        applyUpdateValidation: false,\n        mergeForUpdate: false,\n      } as any)\n    );\n    await repo.update(sourceModel, context);\n    context.logger.info(\n      `Mirror for ${Model.tableName(this.class)} updated: ${(model as any)[Model.pk(model)]}`\n    );\n  } finally {\n    fabricCtx.put(\"mirror\" as any, undefined);\n    fabricCtx.put(\"mirrorCollection\" as any, undefined);\n  }\n}\n\nexport async function deleteMirrorHandler<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const collection = await evalMirrorMetadata(model, data.resolver, context);\n  const fabricCtx = context as FabricContractContext;\n  fabricCtx.put(\"mirror\" as any, true);\n  fabricCtx.put(\"mirrorCollection\" as any, collection);\n  fabricCtx.put(\"segregated\" as any, collection);\n  try {\n    const pkProp = Model.pk(model) as keyof M;\n    const id = model[pkProp];\n    const repo = this.override(\n      Object.assign({}, (this as any)._overrides, {\n        segregated: collection,\n        mirror: true,\n        ignoreValidation: true,\n        ignoreHandlers: true,\n      } as any)\n    );\n    try {\n      await repo.delete(id as any, context);\n    } catch {\n      // May already be deleted by adapter.deleteSegregatedCollections\n    }\n    context.logger.info(\n      `Mirror for ${Model.tableName(this.class)} deleted: ${String(id)}`\n    );\n  } finally {\n    fabricCtx.put(\"mirror\" as any, undefined);\n    fabricCtx.put(\"mirrorCollection\" as any, undefined);\n    fabricCtx.put(\"segregated\" as any, undefined);\n  }\n}\n\nexport async function mirrorWriteGuard<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  key: keyof M,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  model: M\n): Promise<void> {\n  const msp = extractMspId(\n    context.get(\"identity\") as string | ClientIdentity | undefined\n  );\n  if (!msp) return;\n  if (msp === data.mspId || (data.condition && data.condition(msp))) {\n    throw new AuthorizationError(\n      `Organization ${msp} is not authorized to modify mirrored data`\n    );\n  }\n}\n\nexport async function readMirrorHandler<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const msp = extractMspId(\n    context.get(\"identity\") as string | ClientIdentity | undefined\n  );\n\n  if (!msp) return;\n\n  const collection = await evalMirrorMetadata(model, data.resolver, context);\n  const fabricCtx = context as FabricContractContext;\n  const matches = msp === data.mspId || (data.condition && data.condition(msp));\n\n  if (matches) {\n    context.logger.info(\n      `Mirror read: MSP ${msp} matches, routing reads to mirror collection ${collection}`\n    );\n    // Route reads exclusively through the mirror collection\n    fabricCtx.put(\"mirror\" as any, true);\n    fabricCtx.put(\"mirrorCollection\" as any, collection);\n    fabricCtx.put(\"fullySegregated\", true);\n    fabricCtx.readFrom(collection);\n  }\n  // When MSP does NOT match, normal read flow — all data is in public state\n}\n\nexport function mirror(\n  collection: CollectionResolver | string,\n  mspIdOrCondition?: string | MirrorCondition,\n  condition?: MirrorCondition\n) {\n  const isConditionOnly =\n    typeof mspIdOrCondition !== \"string\" && Boolean(mspIdOrCondition);\n  const mspId = isConditionOnly\n    ? undefined\n    : (mspIdOrCondition as string | undefined);\n  const cond = isConditionOnly\n    ? (mspIdOrCondition as MirrorCondition)\n    : condition;\n\n  function mirror(\n    resolver: CollectionResolver | string,\n    mspId: string,\n    condition?: MirrorCondition\n  ) {\n    const meta: MirrorMetadata = {\n      condition: condition,\n      mspId: mspId,\n      resolver: resolver,\n    };\n    return apply(\n      metadata(\n        Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.MIRROR),\n        meta\n      ),\n      // Read handler runs early (priority 30) to set up context before any reads\n      onRead(readMirrorHandler as any, meta, { priority: 30 }),\n      // Write guards — reject matching MSPs before any processing\n      onCreate(mirrorWriteGuard as any, meta, { priority: 20 }),\n      onUpdate(mirrorWriteGuard as any, meta, { priority: 20 }),\n      onDelete(mirrorWriteGuard as any, meta, { priority: 20 }),\n      // Mirror sync handlers — write full model after other handlers (priority 100)\n      onCreate(createMirrorHandler as any, meta, { priority: 100 }),\n      onUpdate(updateMirrorHandler as any, meta, { priority: 100 }),\n      onDelete(deleteMirrorHandler as any, meta, { priority: 100 })\n    );\n  }\n\n  return Decoration.for(FabricModelKeys.MIRROR)\n    .define({\n      decorator: mirror,\n      args: [collection, mspId, cond],\n    })\n    .apply();\n}\n\nexport type CollectionResolver = <M extends Model>(\n  model: M | Constructor<M>,\n  msp?: string,\n  ...args: any[]\n) => string;\n\nexport const ModelCollection: CollectionResolver = <M extends Model>(\n  model: M | Constructor<M>,\n  mspId?: string\n) => {\n  const orgName =\n    mspId || (typeof model !== \"function\" ? Model.ownerOf(model) : undefined);\n  const constr = typeof model === \"function\" ? model : model.constructor;\n  if (!orgName)\n    throw new InternalError(\n      `Model ${constr.name} is not owned by any organization. did you use @ownedBy() (or provide the name)?`\n    );\n  return `${toPascalCase(constr.name)}${orgName ? toPascalCase(orgName) : \"\"}`;\n};\n\nexport function NamespaceCollection(namespace: string): CollectionResolver {\n  return <M extends Model>(model: M | Constructor<M>, mspId?: string) => {\n    const orgName =\n      mspId || (typeof model !== \"function\" ? Model.ownerOf(model) : undefined);\n    const constr = typeof model === \"function\" ? model : model.constructor;\n    if (!orgName)\n      throw new InternalError(\n        `Model ${constr.name} is not owned by any organization. did you use @ownedBy() (or provide the name)?`\n      );\n    return `${namespace}${orgName ? toPascalCase(orgName) : \"\"}`;\n  };\n}\n\nexport const ImplicitPrivateCollection: CollectionResolver = <M extends Model>(\n  model: M | Constructor<M>,\n  mspId?: string\n) => {\n  const orgName =\n    mspId || (typeof model !== \"function\" ? Model.ownerOf(model) : undefined);\n  if (!orgName)\n    throw new InternalError(\n      `Model ${model.constructor.name} is not owned by any organization. did you use @ownedBy() (or provide the name)?`\n    );\n  return `__${toPascalCase(orgName)}PrivateCollection`;\n};\n\nexport type SegregatedDataMetadata = {\n  collections: string | CollectionResolver;\n};\n\n/**\n * @description Priority for early collection extraction (before pk generation at priority 60)\n * @summary This priority ensures collections are registered in context before any sequence\n * operations occur, allowing sequences to be replicated to private/shared collections.\n */\nexport const SEGREGATED_COLLECTION_EXTRACTION_PRIORITY = 35;\n\nexport function applySegregationFlags<M extends Model>(\n  clazz: M,\n  collections: string[],\n  ctx: any\n) {\n  // Register collections early using readFrom - this allows sequence code\n  // to know which collections to replicate to during pk generation\n  if (collections.length > 0) {\n    (ctx as FabricContractContext).readFrom(collections);\n  }\n\n  // Check if model is fully segregated (all non-pk properties are private/shared/transient).\n  // Use Model.segregate() which is the canonical way to determine what's transient,\n  // rather than reading DBKeys.TRANSIENT metadata which may not accumulate correctly\n  // when class-level @privateData applies decorators iteratively.\n  if (!ctx.isFullySegregated && collections.length) {\n    if (!hasPublicProperties(clazz.constructor as Constructor<M>)) {\n      ctx.markFullySegregated();\n    }\n  }\n}\n\nexport async function applyMirrorFlags<M extends Model>(\n  clazz: Constructor<M>,\n  msp: string | undefined,\n  ctx: FabricContractContext\n) {\n  if (!msp) return;\n  const mirrorMeta = Model.mirroredAt(clazz);\n  if (!mirrorMeta) return;\n  const matches =\n    msp === mirrorMeta.mspId ||\n    (mirrorMeta.condition && mirrorMeta.condition(msp));\n  if (!matches) return;\n  const collection = await evalMirrorMetadata(\n    new clazz(),\n    mirrorMeta.resolver,\n    ctx\n  );\n  // Mirror MSP matches — route reads exclusively through the mirror\n  // collection. Clear any previously registered collections so queries\n  // go ONLY to the mirror, not to the regular private/shared ones.\n  ctx.put(\"segregateRead\", undefined);\n  ctx.put(\"segregateReadStack\", undefined);\n  ctx.put(\"fullySegregated\", true);\n  ctx.put(\"mirror\" as any, true);\n  ctx.put(\"mirrorCollection\" as any, collection);\n  ctx.readFrom(collection);\n}\n\nfunction hasPublicProperties<M extends Model>(clazz: Constructor<M>): boolean {\n  const attributes = Metadata.getAttributes(clazz) || [];\n  const pk = Model.pk(clazz);\n  const transientMeta = Metadata.get(clazz as any, DBKeys.TRANSIENT) || {};\n  const privateMeta =\n    Metadata.get(clazz as any, Metadata.key(FabricModelKeys.PRIVATE)) || {};\n  const sharedMeta =\n    Metadata.get(clazz as any, Metadata.key(FabricModelKeys.SHARED)) || {};\n\n  return attributes.some((attr) => {\n    if (attr === pk) return false;\n    if (attr in transientMeta) return false;\n    if (attr in privateMeta) return false;\n    if (attr in sharedMeta) return false;\n    return true;\n  });\n}\n\n/**\n * @description Early handler to extract and register collections in context\n * @summary Runs with priority < 40 to extract collection names before pk generation (priority 60).\n * This allows FabricContractSequence to know which collections to replicate to.\n * @template M - Type that extends Model\n * @param {ContextOf<Repository<M, any>>} context - The execution context\n * @param {SegregatedDataMetadata | SegregatedDataMetadata[]} data - The segregated data metadata\n * @param {string | string[]} keys - The property key(s) being segregated\n * @param {M} model - The model instance\n * @return {Promise<void>}\n */\nexport async function extractSegregatedCollections<M extends Model>(\n  this: Repository<M, any>,\n  context: ContextOf<typeof this>,\n  data: SegregatedDataMetadata | SegregatedDataMetadata[],\n  keys: keyof M | (keyof M)[],\n  model: M\n): Promise<void> {\n  const dataArray = (\n    Array.isArray(data) ? data : [data]\n  ) as SegregatedDataMetadata[];\n\n  const msp =\n    Model.ownerOf(model) ||\n    extractMspId(\n      context.get(\"identity\") as string | ClientIdentity | undefined\n    );\n  if (!msp) {\n    // Can't extract collections without MSP, will be caught by later handlers\n    return;\n  }\n\n  const collections: string[] = [];\n  for (const metadata of dataArray) {\n    const collectionResolver = metadata.collections;\n    const collection =\n      typeof collectionResolver === \"string\"\n        ? collectionResolver\n        : collectionResolver(model, msp, context);\n    if (collection && !collections.includes(collection)) {\n      collections.push(collection);\n    }\n  }\n  applySegregationFlags(model, collections, context);\n\n  // Store segregation metadata on the adapter (persists across context chains).\n  // The Sequence creates its own context via logCtx, losing context-stored flags.\n  const seqName = Model.sequenceName(model, \"pk\");\n  (context as any).setSequenceSegregation(\n    seqName,\n    (context as any).isFullySegregated,\n    collections\n  );\n}\n\nexport async function segregatedDataOnCreate<M extends Model>(\n  this: Repository<M, any>,\n  context: ContextOf<typeof this>,\n  data: SegregatedDataMetadata | SegregatedDataMetadata[],\n  keys: keyof M | (keyof M)[],\n  model: M\n): Promise<void> {\n  const dataArray = (\n    Array.isArray(data) ? data : [data]\n  ) as SegregatedDataMetadata[];\n  const keyArray = (Array.isArray(keys) ? keys : [keys]) as (keyof M)[];\n  if (keyArray.length !== dataArray.length)\n    throw new InternalError(\n      `Segregated data keys and metadata length mismatch`\n    );\n\n  const msp =\n    Model.ownerOf(model) ||\n    extractMspId(\n      context.get(\"identity\") as string | ClientIdentity | undefined\n    );\n  if (!msp)\n    throw new ValidationError(\n      `There's no assigned organization for model ${model.constructor.name}`\n    );\n\n  const collectionResolver = dataArray[0].collections;\n  const collection =\n    typeof collectionResolver === \"string\"\n      ? collectionResolver\n      : collectionResolver(model, msp, context);\n\n  // Validate all keys resolve to the same collection\n  keyArray.forEach((_k, i) => {\n    const c =\n      typeof dataArray[i].collections === \"string\"\n        ? dataArray[i].collections\n        : dataArray[i].collections(model, msp, context);\n    if (c !== collection)\n      throw new UnsupportedError(\n        `Segregated data collection mismatch: ${c} vs ${collection}`\n      );\n  });\n\n  const keyStrings = keyArray.map((key) => String(key));\n  // Store the segregated model — prepare() will filter to collection-specific fields\n  (context as FabricContractContext).writeTo(collection, keyStrings);\n}\n\nexport async function segregatedDataOnRead<M extends Model>(\n  this: Repository<M, any>,\n  context: Context<FabricFlags>,\n  data: SegregatedDataMetadata | SegregatedDataMetadata[],\n  keys: keyof M | (keyof M)[],\n  model: M\n): Promise<void> {\n  const dataArray = (\n    Array.isArray(data) ? data : [data]\n  ) as SegregatedDataMetadata[];\n  const keyArray = (Array.isArray(keys) ? keys : [keys]) as (keyof M)[];\n  if (keyArray.length !== dataArray.length)\n    throw new InternalError(\n      `Segregated data keys and metadata length mismatch`\n    );\n\n  const msp = Model.ownerOf(model) || extractMspId(context.get(\"identity\"));\n  if (!msp)\n    throw new ValidationError(\n      `There's no assigned organization for model ${model.constructor.name}`\n    );\n\n  const collectionResolver = dataArray[0].collections;\n  const collection =\n    typeof collectionResolver === \"string\"\n      ? collectionResolver\n      : await collectionResolver(model, msp, context);\n\n  (context as FabricContractContext).readFrom(collection);\n}\n\nexport async function segregatedDataOnUpdate<M extends Model>(\n  this: Repository<M, any>,\n  context: ContextOf<typeof this>,\n  data: SegregatedDataMetadata | SegregatedDataMetadata[],\n  key: keyof M | (keyof M)[],\n  model: M,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  oldModel: M\n): Promise<void> {\n  const dataArray = (\n    Array.isArray(data) ? data : [data]\n  ) as SegregatedDataMetadata[];\n  const keyArray = (Array.isArray(key) ? key : [key]) as (keyof M)[];\n  if (keyArray.length !== dataArray.length)\n    throw new InternalError(\n      `Segregated data keys and metadata length mismatch`\n    );\n\n  const msp =\n    Model.ownerOf(model) ||\n    extractMspId(\n      context.get(\"identity\") as string | ClientIdentity | undefined\n    );\n  if (!msp)\n    throw new ValidationError(\n      `There's no assigned organization for model ${model.constructor.name}`\n    );\n\n  const collectionResolver = dataArray[0].collections;\n  const collection =\n    typeof collectionResolver === \"string\"\n      ? collectionResolver\n      : collectionResolver(model, msp, context);\n\n  keyArray.forEach((k, i) => {\n    const c =\n      typeof dataArray[i].collections === \"string\"\n        ? dataArray[i].collections\n        : dataArray[i].collections(model, msp, context);\n    if (c !== collection)\n      throw new UnsupportedError(\n        `Segregated data collection mismatch: ${c} vs ${collection}`\n      );\n  });\n\n  const keyStrings = (keyArray as (keyof M)[]).map((key) => String(key));\n  // Store the original model — prepare() will filter to collection-specific fields\n  (context as FabricContractContext).writeTo(collection, keyStrings);\n}\n\nexport async function segregatedDataOnDelete<\n  M extends Model,\n  R extends Repository<M, any>,\n  V extends SegregatedDataMetadata,\n>(\n  this: R,\n  context: ContextOf<R>,\n  data: V | V[],\n  key: (keyof M)[],\n  model: M\n): Promise<void> {\n  const dataArray = (Array.isArray(data) ? data : [data]) as V[];\n  const keyArray = (Array.isArray(key) ? key : [key]) as (keyof M)[];\n  if (keyArray.length !== dataArray.length)\n    throw new InternalError(\n      `Segregated data keys and metadata length mismatch`\n    );\n\n  const msp =\n    Model.ownerOf(model) ||\n    extractMspId(\n      context.get(\"identity\") as string | ClientIdentity | undefined\n    );\n  if (!msp)\n    throw new ValidationError(\n      `There's no assigned organization for model ${model.constructor.name}`\n    );\n\n  const collectionResolver = dataArray[0].collections;\n  const collection =\n    typeof collectionResolver === \"string\"\n      ? collectionResolver\n      : collectionResolver(model, msp, context);\n\n  (context as FabricContractContext).readFrom(collection);\n}\n\nfunction segregated(\n  collection: string | CollectionResolver,\n  type: FabricModelKeys.PRIVATE | FabricModelKeys.SHARED,\n  filter?: (propName: string) => boolean\n) {\n  return function innerSegregated(target: object, propertyKey?: any) {\n    function segregatedDec(target: object, propertyKey?: any) {\n      const key = Metadata.key(type, propertyKey);\n      const constr: Constructor = target.constructor as Constructor;\n\n      const meta = Metadata.get(constr as Constructor, key) || {};\n      const collections = new Set(meta.collections || []);\n      collections.add(collection);\n      meta.collections = [...collections];\n      Metadata.set(constr as Constructor, key, meta);\n\n      const constrMeta = Metadata.get(constr as Constructor, type) || {};\n      const constrCollections = new Set(constrMeta.collections || []);\n      constrCollections.add(collection);\n      constrMeta.collections = [...constrCollections];\n      Metadata.set(constr as Constructor, type, constrMeta);\n\n      const transientMeta =\n        Metadata.get(constr as Constructor, DBKeys.TRANSIENT) || {};\n      const updatedTransientMeta = {\n        ...transientMeta,\n        [propertyKey as any]: {},\n      };\n      Metadata.set(\n        constr as Constructor,\n        DBKeys.TRANSIENT,\n        updatedTransientMeta\n      );\n    }\n\n    const decs: any[] = [];\n    if (!propertyKey) {\n      // decorated at the class level\n      const properties = Metadata.getAttributes(target as Constructor);\n      properties?.forEach((p) => {\n        if (!filter || filter(p)) {\n          segregated(collection, type)((target as any).prototype, p);\n        }\n      });\n      return target;\n    } else {\n      const groupName =\n        typeof collection === \"string\" ? collection : collection.toString();\n      // Use different group names for extraction vs data handlers to prevent merging\n      const extractGroupName = `${groupName}:extract`;\n      const dataGroupName = `${groupName}:data`;\n      const earlyExtractionMeta = { collections: collection };\n      const earlyExtractionGroupSort = {\n        priority: SEGREGATED_COLLECTION_EXTRACTION_PRIORITY,\n        group: extractGroupName,\n      };\n      decs.push(\n        prop(),\n        transient(),\n        segregatedDec,\n        // Early extraction handlers - run BEFORE pk generation (priority 60)\n        // This ensures collections are registered in context for sequence replication\n        // We register for each operation explicitly to ensure proper handler lookup\n        on(\n          DBOperations.ALL,\n          extractSegregatedCollections as any,\n          earlyExtractionMeta,\n          earlyExtractionGroupSort\n        ),\n        // Main handlers for segregated data operations (priority 95)\n        onCreate(\n          segregatedDataOnCreate,\n          { collections: collection },\n          {\n            priority: 95,\n            group: dataGroupName,\n          }\n        ),\n        onRead(\n          segregatedDataOnRead as any,\n          { collections: collection },\n          {\n            priority: 95,\n            group: dataGroupName,\n          }\n        ),\n        onUpdate(\n          segregatedDataOnUpdate as any,\n          { collections: collection },\n          {\n            priority: 95,\n            group: dataGroupName,\n          }\n        ),\n        onDelete(\n          segregatedDataOnDelete as any,\n          { collections: collection },\n          {\n            priority: 95,\n            group: dataGroupName,\n          }\n        )\n      );\n    }\n    return apply(...decs)(target, propertyKey);\n  };\n}\n\nexport function privateData(\n  collection: string | CollectionResolver = ImplicitPrivateCollection\n) {\n  function privateData(collection: string | CollectionResolver) {\n    return segregated(collection, FabricModelKeys.PRIVATE);\n  }\n\n  return Decoration.for(FabricModelKeys.PRIVATE)\n    .define({\n      decorator: privateData,\n      args: [collection],\n    })\n    .apply();\n}\n\nexport function sharedData(collection: string | CollectionResolver) {\n  function sharedData(collection: string | CollectionResolver) {\n    return segregated(collection, FabricModelKeys.SHARED);\n  }\n\n  return Decoration.for(FabricModelKeys.SHARED)\n    .define({\n      decorator: sharedData,\n      args: [collection],\n    })\n    .apply();\n}\n","/* eslint-disable @typescript-eslint/no-require-imports */\nimport { Constructor, Metadata } from \"@decaf-ts/decoration\";\nimport {\n  JSONSerializer,\n  Model,\n  ModelKeys,\n} from \"@decaf-ts/decorator-validation\";\n\n/**\n * @description Recursively sorts object keys without reordering arrays\n * @param {any} obj - The value to process\n * @return {any} A copy with sorted object keys but preserved array order\n */\nexport function sortKeysOnlyRecursive(obj: any): any {\n  if (obj === null || typeof obj !== \"object\") return obj;\n  if (Array.isArray(obj)) return obj.map(sortKeysOnlyRecursive);\n  if (obj.constructor !== Object) return obj;\n  return Object.keys(obj)\n    .sort()\n    .reduce((acc: Record<string, any>, key) => {\n      acc[key] = sortKeysOnlyRecursive(obj[key]);\n      return acc;\n    }, {});\n}\n\n/**\n * @description Deterministic JSON serializer for Fabric models\n * @summary Ensures stable, deterministic JSON output by sorting object keys recursively before stringification, which is important for Fabric endorsement and hashing. Extends JSONSerializer to plug into existing Decaf model serialization flow.\n * @template M - The Decaf Model subtype serialized by this instance\n * @param {void} [constructor] No public constructor arguments\n * @class DeterministicSerializer\n * @example\n * const serializer = new DeterministicSerializer<MyModel>();\n * const json = serializer.serialize(model);\n * const rebuilt = serializer.deserialize(json);\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant DS as DeterministicSerializer\n *   Caller->>DS: serialize(model)\n *   DS->>DS: preSerialize(model)\n *   DS->>DS: sort-keys-recursive\n *   DS->>DS: json-stringify-deterministic\n *   DS-->>Caller: string\n *   Caller->>DS: deserialize(string)\n *   DS-->>Caller: model\n */\nexport class DeterministicSerializer<\n  M extends Model,\n> extends JSONSerializer<M> {\n  constructor() {\n    super();\n  }\n  protected override preSerialize(model: M) {\n    // TODO: nested preserialization (so increase performance when deserializing)\n    // TODO: Verify why there is no metadata\n    const toSerialize: Record<string, any> = Object.assign({}, model);\n    let metadata;\n    try {\n      metadata = Metadata.modelName(model.constructor as Constructor);\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (error: unknown) {\n      metadata = undefined;\n    }\n    toSerialize[ModelKeys.ANCHOR] = metadata || model.constructor.name;\n\n    const preSerialize = function preSerialize(\n      this: DeterministicSerializer<any>,\n      obj: any\n    ): any {\n      // eslint-disable-next-line @typescript-eslint/no-this-alias\n      const self = this;\n      if (typeof obj !== \"object\") return obj;\n      if (Array.isArray(obj)) return obj.map((o) => preSerialize.call(self, o));\n      return this.preSerialize.call(this, obj);\n    }.bind(this);\n\n    Model.relations(model).forEach((r) => {\n      toSerialize[r] = preSerialize(toSerialize[r]);\n    });\n    return toSerialize;\n  }\n\n  /**\n   * @summary Rebuilds a model from a serialization\n   * @param {string} str\n   *\n   * @throws {Error} If it fails to parse the string, or to build the model\n   */\n  override deserialize(str: string): M {\n    const deserialization = JSON.parse(str);\n    const className = deserialization[ModelKeys.ANCHOR];\n    if (!className)\n      throw new Error(\"Could not find class reference in serialized model\");\n    const model: M = Model.build(deserialization, className) as unknown as M;\n    return model;\n  }\n\n  /**\n   * @description Serialize a model into a deterministic JSON string\n   * @summary Prepares the model with preSerialize, sorts keys recursively, and stringifies deterministically for stable ordering\n   * @param {M} model - The model instance to serialize\n   * @return {string} Deterministic JSON representation of the model\n   */\n  override serialize(model: M): string {\n    const stringify = require(\"json-stringify-deterministic\");\n    return stringify(sortKeysOnlyRecursive(this.preSerialize(model)));\n  }\n}\n","import { BulkCrudOperationKeys, OperationKeys } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Generates a Fabric event name from components\n * @summary Creates a standardized event name by joining table, event, and optional owner with underscores\n * @param {string} table - The table/collection name\n * @param {OperationKeys | BulkCrudOperationKeys | string} event - The event type\n * @param {string} [owner] - Optional owner identifier\n * @return {string} The generated event name in format \"table_event\" or \"table_event_owner\"\n * @function generateFabricEventName\n * @memberOf module:for-fabric.shared\n */\nexport function generateFabricEventName(\n  table: string,\n  event: OperationKeys | BulkCrudOperationKeys | string,\n  owner?: string\n) {\n  const params = [table, event];\n  if (owner) params.push(owner);\n  return params.join(\"_\");\n}\n\n/**\n * @description Parses a Fabric event name into its components\n * @summary Splits an event name by underscores and extracts table, event, and optional owner\n * @param {string} name - The event name to parse\n * @return {{table: string, event: OperationKeys | BulkCrudOperationKeys | string, owner: string}} The parsed components as a structured object\n * @throws {InternalError} If the event name format is invalid\n * @function parseEventName\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant Parser as parseEventName\n *   Caller->>Parser: parseEventName(name)\n *   Parser->>Parser: split name by \"_\"\n *   alt parts length invalid\n *     Parser-->>Caller: throw InternalError\n *   else\n *     Parser-->>Caller: { table, event, owner? }\n *   end\n * @memberOf module:for-fabric.shared\n */\nexport function parseEventName(name: string): {\n  table?: string;\n  event: OperationKeys | BulkCrudOperationKeys | string;\n  owner?: string;\n} {\n  const parts = name.split(\"_\");\n  if (parts.length < 2 || parts.length > 3)\n    return { table: undefined, event: name, owner: undefined };\n  return {\n    table: parts[0],\n    event: parts[1],\n    owner: parts[2],\n  } as {\n    table: string;\n    event: OperationKeys | BulkCrudOperationKeys | string;\n    owner?: string;\n  };\n}\n","import { stringFormat } from \"@decaf-ts/decorator-validation\";\nimport { OverflowError } from \"./errors\";\nimport { ValidationError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Overflow-safe addition operation\n * @summary Adds two numbers and verifies no overflow by reverse-checking the operands\n * @param {number} a - First operand\n * @param {number} b - Second operand\n * @return {number} The sum of a and b\n * @function add\n * @throws {OverflowError} on addition overflow\n * @memberOf module:for-fabric.shared\n */\nexport function add(a: number, b: number): number {\n  const c = a + b;\n  if (a !== c - b || b !== c - a) {\n    throw new OverflowError(`Addition overflow: ${a} + ${b}`);\n  }\n  return c;\n}\n\n/**\n * @description Overflow-safe subtraction operation\n * @summary Subtracts b from a and validates no overflow by reverse-checking the operands\n * @param {number} a - Minuend\n * @param {number} b - Subtrahend\n * @return {number} The difference a - b\n * @function sub\n * @throws {OverflowError} on subtaction overflow\n * @memberOf module:for-fabric.shared\n */\nexport function sub(a: number, b: number): number {\n  const c = a - b;\n  if (a !== c + b || b !== a - c) {\n    throw new OverflowError(`Subtraction overflow: ${a} - ${b}`);\n  }\n  return c;\n}\n\n/**\n * @summary Safe Integer Parse\n *\n * @param {string} string\n *\n * @function safeParseInt\n *\n * @throws {ValidationError} if parseInt returns NaN\n *\n * @memberOf module:for-fabric.shared\n */\nexport function safeParseInt(string: string): number {\n  // Regular expression to check if string only have digits\n  const digitRegex = /^\\d+$/;\n  if (!digitRegex.test(string)) {\n    throw new ValidationError(\n      stringFormat(\"Failed to parse: {0}\", \"string contains digits\")\n    );\n  }\n  const parsedint = parseInt(string);\n  if (isNaN(parsedint)) {\n    throw new ValidationError(\n      stringFormat(\"Failed to parse: {0}\", \"string is not a parsable integer\")\n    );\n  }\n  return parsedint;\n}\n","import {\n  JSONSerializer,\n  Model,\n  ModelKeys,\n} from \"@decaf-ts/decorator-validation\";\nimport { Constructor, Metadata } from \"@decaf-ts/decoration\";\nimport { sortKeysOnlyRecursive } from \"./DeterministicSerializer\";\n\nexport class SimpleDeterministicSerializer<\n  M extends Model,\n> extends JSONSerializer<M> {\n  constructor() {\n    super();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  override deserialize(str: string, tableName?: string): M {\n    const deserialization = JSON.parse(str);\n    // const className = tableName;\n    // if (!className)\n    //   throw new Error(\"Could not find class reference in serialized model\");\n\n    // // this will return undefined values\n    // const model: M = Model.build(deserialization, className) as unknown as M;\n\n    // // Populate Model\n    // const processedDesealization = Object.keys(model).reduce(\n    //   (accum: M, key) => {\n    //     (accum as Record<string, any>)[key] =\n    //       deserialization[Repository.column(accum, key)];\n    //     return accum;\n    //   },\n    //   model\n    // );\n\n    // const result = Model.build(\n    //   processedDesealization,\n    //   className\n    // ) as unknown as M;\n\n    // return result;\n    return deserialization;\n  }\n\n  override serialize(model: M, putAnchor = true): string {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    const stringify = require(\"json-stringify-deterministic\");\n    const preSerialization = this.preSerialize(model, putAnchor);\n    return stringify(sortKeysOnlyRecursive(preSerialization));\n  }\n\n  protected override preSerialize(model: M, putAnchor: boolean = true) {\n    // TODO: nested preserialization (so increase performance when deserializing)\n    // TODO: Verify why there is no metadata\n    const toSerialize: Record<string, any> = Object.assign({}, model);\n    let metadata;\n    try {\n      metadata = Metadata.modelName(model.constructor as Constructor);\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (error: unknown) {\n      metadata = undefined;\n    }\n    if (putAnchor)\n      toSerialize[ModelKeys.ANCHOR] = metadata || model.constructor.name;\n\n    function preSerialize(\n      this: SimpleDeterministicSerializer<any>,\n      obj: any\n    ): any {\n      if (typeof obj !== \"object\") return obj;\n      if (Array.isArray(obj)) return obj.map(preSerialize);\n      return this.preSerialize(obj);\n    }\n    Model.relations(model).forEach((r) => {\n      toSerialize[r] = preSerialize.call(this, toSerialize[r]);\n    });\n    return toSerialize;\n  }\n}\n","import {\n  AuthorizationError,\n  ClientBasedService,\n  Context,\n  MaybeContextualArg,\n  PersistenceKeys,\n} from \"@decaf-ts/core\";\nimport FabricCAServices, {\n  AffiliationService,\n  IAttributeRequest,\n  IdentityService,\n  IEnrollResponse,\n  IIdentityRequest,\n  IRegisterRequest,\n  IRevokeRequest,\n  IServiceResponse,\n  TLSOptions,\n} from \"fabric-ca-client\";\nimport { CAConfig, Credentials } from \"../../shared/types\";\nimport {\n  ConflictError,\n  InternalError,\n  NotFoundError,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { CoreUtils, getAkiAndSerialFromCert } from \"../utils\";\nimport {\n  CertificateResponse,\n  FabricIdentity,\n  GetCertificatesRequest,\n  IdentityResponse,\n} from \"../../shared/fabric-types\";\nimport { User } from \"fabric-common\";\nimport { RegistrationError } from \"../../shared/errors\";\nimport { CA_ROLE } from \"./constants\";\nimport { IKeyValueAttribute } from \"./FabricEnrollmentService\";\nimport { Identity } from \"../../shared/index\";\nimport { CryptoUtils } from \"../crypto\";\n\nexport class FabricIdentityService extends ClientBasedService<\n  FabricCAServices,\n  CAConfig\n> {\n  protected _user!: User;\n\n  constructor() {\n    super();\n  }\n\n  protected get rootClient(): { newCertificateService: any } {\n    return (this.client as any)[\"_FabricCaServices\"] as any;\n  }\n\n  protected get user(): User {\n    if (!this._user)\n      throw new InternalError(\n        \"Fabric identity service not properly setup: missing user\"\n      );\n    return this._user;\n  }\n\n  protected get certificates() {\n    return this.rootClient.newCertificateService();\n  }\n\n  protected get affiliations(): AffiliationService {\n    return this.client.newAffiliationService();\n  }\n\n  protected get identities(): IdentityService {\n    return this.client.newIdentityService();\n  }\n\n  protected async getUser(cfg: CAConfig, ctx: Context) {\n    const log = ctx.logger.for(this.getUser);\n    const { caName, caCert, caKey, url, hsm } = cfg;\n\n    log.info(`Creating CA user for ${caName} at ${url}`);\n    log.verbose(`Retrieving CA certificate from ${caCert}`);\n    const certificate = await CoreUtils.getFirstDirFileNameContent(caCert);\n    let key: string | undefined;\n    if (!hsm) {\n      if (!caKey) {\n        throw new InternalError(\n          `Missing caKey configuration for CA ${caName}. Provide a key directory or configure HSM support.`\n        );\n      }\n      log.debug(`Retrieving CA key from ${caKey}`);\n      key = await CoreUtils.getFirstDirFileNameContent(caKey);\n    } else {\n      log.debug(\n        `Using HSM configuration for CA ${caName} with library ${hsm.library}`\n      );\n    }\n    log.debug(`Loading Admin user for ca ${caName}`);\n    this._user = await CoreUtils.getCAUser(\"admin\", key, certificate, caName, {\n      hsm,\n    });\n    return this._user;\n  }\n\n  override async initialize(\n    ...args: MaybeContextualArg<any>\n  ): Promise<{ config: CAConfig; client: FabricCAServices }> {\n    const { log, ctx } = (\n      await this.logCtx(args, PersistenceKeys.INITIALIZATION, true)\n    ).for(this.initialize);\n    const [config] = args;\n    if (!config) throw new InternalError(\"Missing Fabric CA configuration\");\n\n    const { url, tls, caName } = config;\n    log.info(`Initializing CA Client for CA ${config.caName} at ${config.url}`);\n    const { trustedRoots, verify } = tls as TLSOptions;\n\n    const root = (trustedRoots as string[])[0] as string;\n    log.debug(`Retrieving CA certificate from ${root}. cwd: ${process.cwd()}`);\n\n    const certificate = await CoreUtils.getFileContent(root);\n\n    log.debug(`CA Certificate: ${certificate.toString()}`);\n\n    const client = new FabricCAServices(\n      url,\n      {\n        trustedRoots: Buffer.from(certificate),\n        verify,\n      } as TLSOptions,\n      caName\n    );\n\n    const user = await this.getUser(config, ctx);\n    log.debug(`CA user loaded: ${user.getName()}`);\n    return {\n      config,\n      client,\n    };\n  }\n\n  async getCertificates(...args: MaybeContextualArg<any>): Promise<string[]>;\n  async getCertificates(\n    request: GetCertificatesRequest,\n    ...args: MaybeContextualArg<any>\n  ): Promise<string[]>;\n  async getCertificates<MAP extends boolean>(\n    doMap: MAP,\n    ...args: MaybeContextualArg<any>\n  ): Promise<MAP extends false ? CertificateResponse : string[]>;\n  async getCertificates<MAP extends boolean>(\n    request: GetCertificatesRequest,\n    doMap: MAP,\n    ...args: MaybeContextualArg<any>\n  ): Promise<MAP extends false ? CertificateResponse : string[]>;\n  async getCertificates<MAP extends boolean>(\n    request?: GetCertificatesRequest | MAP,\n    doMap: MAP = true as MAP,\n    ...args: MaybeContextualArg<any>\n  ): Promise<MAP extends false ? CertificateResponse : string[]> {\n    if (request instanceof Context) {\n      args = [request];\n      doMap = true as MAP;\n      request = undefined;\n    } else if (typeof request === \"boolean\") {\n      doMap = request;\n      request = undefined;\n    } else if (typeof doMap !== \"boolean\") {\n      args = [doMap as MaybeContextualArg<any>, ...args];\n      doMap = true as MAP;\n    }\n\n    const { log } = (await this.logCtx(args, OperationKeys.READ, true)).for(\n      this.getCertificates\n    );\n    log.debug(\n      `Retrieving certificates${request ? ` for ${request.id}` : \"\"} for CA ${this.config.caName}`\n    );\n    const response: CertificateResponse = (\n      await this.certificates.getCertificates(request || {}, this.user)\n    ).result;\n    log.verbose(`Found ${response.certs.length} certificates`);\n    log.debug(response.certs);\n    return (\n      doMap ? response.certs.map((c) => c.PEM) : response\n    ) as MAP extends false ? CertificateResponse : string[];\n  }\n\n  async getIdentities(ctx: Context): Promise<FabricIdentity[]> {\n    const log = ctx.logger.for(this.getIdentities);\n    log.verbose(`Retrieving Identities under CA ${this.config.caName}`);\n    const response: IdentityResponse = (await this.identities.getAll(this.user))\n      .result;\n    log.verbose(`Found ${response.identities.length} Identities`);\n    log.debug(response.identities);\n    return response.identities;\n  }\n\n  /**\n   * @description Retrieve affiliations from the CA.\n   * @summary Queries the CA for the list of affiliations available under the configured CA.\n   * @return {string} The affiliations result payload.\n   */\n  async getAffiliations(ctx: Context) {\n    const log = ctx.logger.for(this.getAffiliations);\n    log.verbose(`Retrieving Affiliations under CA ${this.config.caName}`);\n    const response = (await this.affiliations.getAll(this.user)).result;\n    log.verbose(`Found ${response.a.length} Affiliations`);\n    log.debug(JSON.stringify(response));\n    return response;\n  }\n\n  protected parseError(e: Error) {\n    const regexp = /.*code:\\s(\\d+).*?message:\\s[\"'](.+)[\"']/gs;\n    const match = regexp.exec(e.message);\n    if (!match) return new RegistrationError(e);\n    const [, code, message] = match;\n    switch (code) {\n      case \"74\":\n      case \"71\":\n        return new ConflictError(message);\n      case \"20\":\n        return new AuthorizationError(message);\n      default:\n        return new RegistrationError(message);\n    }\n  }\n\n  /**\n   * @description Read identity details from the CA by enrollment ID.\n   * @summary Retrieves and validates a single identity, throwing NotFoundError when missing.\n   * @param {string} enrollmentId - Enrollment ID to lookup.\n   * @return {Promise<FabricIdentity>} The identity details stored in the CA.\n   */\n  async read(\n    enrollmentId: string,\n    ...args: MaybeContextualArg<any>\n  ): Promise<FabricIdentity> {\n    const { log } = (await this.logCtx(args, OperationKeys.READ, true)).for(\n      this.read\n    );\n    log.verbose(`Retrieving identity with enrollment ID ${enrollmentId}`);\n    let result: IServiceResponse;\n    try {\n      result = await this.identities.getOne(enrollmentId, this.user);\n    } catch (e: any) {\n      throw new NotFoundError(\n        `Couldn't find enrollment with id ${enrollmentId}: ${e}`\n      );\n    }\n\n    if (!result.success)\n      throw new NotFoundError(\n        `Couldn't find enrollment with id ${enrollmentId}: ${result.errors.join(\"\\n\")}`\n      );\n\n    return result.result as FabricIdentity;\n  }\n\n  /**\n   * @description Register a new identity with the CA.\n   * @summary Submits a registration request for a new enrollment ID, returning the enrollment secret upon success.\n   * @param {Credentials} model - Credentials containing userName and password for the new identity.\n   * @param {boolean} [isSuperUser=false] - Whether to register the identity as a super user.\n   * @param {string} [affiliation=\"\"] - Affiliation string (e.g., org1.department1).\n   * @param {CA_ROLE | string} [userRole] - Role to assign to the identity.\n   * @param {IKeyValueAttribute} [attrs] - Optional attributes to attach to the identity.\n   * @param {number} [maxEnrollments] - Maximum number of enrollments allowed for the identity.\n   * @return {Promise<string>} The enrollment secret for the registered identity.\n   */\n  async register(\n    model: Credentials,\n    isSuperUser: boolean = false,\n    affiliation: string = \"\",\n    userRole?: CA_ROLE | string,\n    attrs?: IKeyValueAttribute,\n    maxEnrollments?: number,\n    ...args: MaybeContextualArg<any>\n  ): Promise<string> {\n    const { log } = (await this.logCtx(args, \"register\", true)).for(\n      this.register\n    );\n\n    let registration: string;\n    try {\n      const { userName, password } = model;\n      const props = {\n        enrollmentID: userName as string,\n        enrollmentSecret: password,\n        affiliation: affiliation,\n        userRole: userRole,\n        attrs: attrs,\n        maxEnrollments: maxEnrollments,\n      } as IRegisterRequest;\n      registration = await this.client.register(props, this.user);\n      log.info(\n        `Registration for ${userName} created with user type ${userRole ?? \"Undefined Role\"} ${isSuperUser ? \"as super user\" : \"\"}`\n      );\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return registration;\n  }\n\n  protected static identityFromEnrollment(\n    enrollment: IEnrollResponse,\n    mspId: string,\n    ctx: Context\n  ): Identity {\n    const log = ctx.logger.for(this.identityFromEnrollment);\n    const { certificate, key, rootCertificate } = enrollment;\n    log.verbose(\n      `Generating Identity from certificate ${certificate} in msp ${mspId}`\n    );\n    const clientId = CryptoUtils.fabricIdFromCertificate(certificate);\n    const id = CryptoUtils.encode(clientId);\n    log.debug(`Identity ${clientId} and encodedId ${id}`);\n    return new Identity({\n      id: id,\n      credentials: {\n        id: id,\n        certificate: certificate,\n        privateKey: key.toBytes(),\n        rootCertificate: rootCertificate,\n      },\n      mspId: mspId,\n    });\n  }\n\n  /**\n   * @description Enroll an identity with the CA using a registration secret.\n   * @summary Exchanges the enrollment ID and secret for certificates, returning a constructed Identity model.\n   * @param {string} enrollmentId - Enrollment ID to enroll.\n   * @param {string} registration - Enrollment secret returned at registration time.\n   * @return {Promise<Identity>} The enrolled identity object with credentials.\n   */\n  async enroll(\n    enrollmentId: string,\n    registration: string,\n    ...args: MaybeContextualArg<any>\n  ): Promise<Identity> {\n    const { log, ctx } = (await this.logCtx(args, \"enroll\", true)).for(\n      this.enroll\n    );\n    let identity: Identity;\n    try {\n      log.debug(`Enrolling ${enrollmentId}`);\n      const enrollment: IEnrollResponse = await this.client.enroll({\n        enrollmentID: enrollmentId,\n        enrollmentSecret: registration,\n      });\n      identity = FabricIdentityService.identityFromEnrollment(\n        enrollment,\n        this.config.caName,\n        ctx\n      );\n      log.info(\n        `Successfully enrolled ${enrollmentId} under ${this.config.caName} as ${identity.id}`\n      );\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return identity;\n  }\n\n  /**\n   * @description Register and enroll a new identity in one step.\n   * @summary Registers a new enrollment ID with the CA and immediately exchanges the secret to enroll, returning the created Identity.\n   * @param {Credentials} model - Credentials for the new identity containing userName and password.\n   * @param {boolean} [isSuperUser=false] - Whether to register the identity as a super user.\n   * @param {string} [affiliation=\"\"] - Affiliation string (e.g., org1.department1).\n   * @param {CA_ROLE | string} [userRole] - Role to assign to the identity.\n   * @param {IKeyValueAttribute} [attrs] - Optional attributes to attach to the identity.\n   * @param {number} [maxEnrollments] - Maximum number of enrollments allowed for the identity.\n   * @return {Promise<Identity>} The enrolled identity.\n   */\n  async registerAndEnroll(\n    model: Credentials,\n    isSuperUser: boolean = false,\n    affiliation: string = \"\",\n    userRole?: CA_ROLE | string,\n    attrs?: IKeyValueAttribute,\n    maxEnrollments?: number,\n    ...args: MaybeContextualArg<any>\n  ): Promise<Identity> {\n    const { ctx } = (await this.logCtx(args, \"register-enroll\", true)).for(\n      this.registerAndEnroll\n    );\n    const registration = await this.register(\n      model,\n      isSuperUser,\n      affiliation,\n      userRole,\n      attrs,\n      maxEnrollments,\n      ctx\n    );\n    const { userName } = model;\n    return this.enroll(userName as string, registration, ctx);\n  }\n\n  /**\n   * @description Re-enroll an existing identity using its current enrollment.\n   * @summary Renews the enrollment certificate by calling the CA reenroll.\n   * @param {User} currentUser - Already enrolled user, must have a signing identity.\n   * @return {Promise<Identity>} The renewed identity object with new credentials.\n   */\n  async updateIdentity(\n    enrollmentId: string,\n    identity: { certificate: string; privateKey: string },\n    identityRequest: IIdentityRequest,\n    ...args: MaybeContextualArg<any>\n  ): Promise<Identity> {\n    const { log, ctx } = (await this.logCtx(args, \"reenroll\", true)).for(\n      this.updateIdentity\n    );\n\n    try {\n      log.info(`Renewing identity for ${enrollmentId}`);\n\n      // Update attributes in the CA registry (admin operation). This changes the \"source of truth\".\n      const identityService = this.client.newIdentityService();\n\n      const caUserIdentity = (await identityService.getOne(\n        enrollmentId,\n        this.user\n      )) as { result: { attrs?: IKeyValueAttribute[] } };\n\n      await identityService.update(enrollmentId, identityRequest, this.user); // as IServiceResponse & { result: IIdentityRequest };\n\n      // Reenroll as the user. Request must be signed using the existing certificate.\n      const reenrollUser = User.createUser(\n        enrollmentId,\n        \"\", // enrollmentSecret not required for reenroll\n        this.user.getMspid(),\n        identity.certificate,\n        identity.privateKey\n      );\n      reenrollUser.setCryptoSuite(this.user.getCryptoSuite());\n\n      const enrollmentAttrs: IAttributeRequest[] = (\n        caUserIdentity.result.attrs || []\n      ).map(({ name }) => ({\n        name,\n        optional: false,\n      }));\n\n      const enrollment = await this.client.reenroll(\n        reenrollUser,\n        enrollmentAttrs\n      );\n\n      const renewedIdentity = FabricIdentityService.identityFromEnrollment(\n        enrollment,\n        this.config.caName,\n        ctx\n      );\n\n      // Revoke the previous certificate only, so the old cert becomes invalid.\n      log.debug(`Revoking previous certificates for ${enrollmentId}`);\n      const { aki, serial } = getAkiAndSerialFromCert(identity.certificate);\n      await this.revoke(enrollmentId, { aki, serial }, args);\n\n      log.debug(`Renew identity successful for ${enrollmentId}`);\n      return renewedIdentity;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  /**\n   * Revokes the enrollment of an identity with the specified enrollment ID.\n   *\n   * @param enrollmentId - The enrollment ID of the identity to be revoked.\n   *\n   * @returns A Promise that resolves to the result of the revocation operation.\n   *\n   * @throws {NotFoundError} If the enrollment with the specified ID does not exist.\n   * @throws {InternalError} If there is an error during the revocation process.\n   */\n  async revoke(\n    enrollmentId: string,\n    revokeOptions: Omit<IRevokeRequest, \"enrollmentID\">,\n    ...args: MaybeContextualArg<any>\n  ): Promise<IServiceResponse> {\n    const { log } = (await this.logCtx(args, \"revoke\", true)).for(this.revoke);\n    log.verbose(`Revoking identity with enrollment ID ${enrollmentId}`);\n    const identity = await this.read(enrollmentId);\n    if (!identity)\n      throw new NotFoundError(\n        `Could not find enrollment with id ${enrollmentId}`\n      );\n    let result: IServiceResponse;\n    try {\n      const reason =\n        Boolean(revokeOptions.serial) || Boolean(revokeOptions.aki)\n          ? \"Revoke User Certificate\"\n          : \"User Deletion\";\n\n      const revokeRequest: IRevokeRequest = {\n        reason,\n        ...revokeOptions,\n        enrollmentID: identity.id,\n      };\n\n      result = await this.client.revoke(revokeRequest, this.user);\n    } catch (e: unknown) {\n      throw new InternalError(\n        `Could not revoke enrollment with id ${enrollmentId}: ${e}`\n      );\n    }\n    if (!result.success)\n      throw new InternalError(\n        `Could not revoke enrollment with id ${enrollmentId}: ${result.errors.join(\"\\n\")}`\n      );\n    return result;\n  }\n}\n","/**\n * @description Certificate Authority role types used during enrollment and registration.\n * @summary Enumerates the standard Hyperledger Fabric CA roles that can be assigned to identities when registering with the CA service.\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.client\n */\nexport enum CA_ROLE {\n  /** Administrator role with elevated privileges for managing identities and affiliations */\n  ADMIN = \"admin\",\n  /** Standard user role for application clients interacting with the network */\n  USER = \"user\",\n  /** Client role typically used for SDK-based interactions and service accounts */\n  CLIENT = \"client\",\n}\n","import { FabricClientFlags } from \"./types\";\n\nexport const DefaultFabricClientFlags: FabricClientFlags = Object.assign({\n  evaluateTimeout: 5,\n  endorseTimeout: 15,\n  submitTimeout: 5,\n  commitTimeout: 60,\n  legacy: false,\n  allowManualEndorsingOrgs: false,\n  allowGatewayOverride: false,\n  rebuildWithTransient: true,\n  encryptTransient: false,\n  syntheticEvents: true,\n}) as any;\n","import { isBrowser, MiniLogger } from \"@decaf-ts/logging\";\nimport { User } from \"fabric-common\";\nimport { Identity, Signer, signers } from \"@hyperledger/fabric-gateway\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport { normalizeImport } from \"@decaf-ts/core\";\n\nconst log = new MiniLogger(\"fabric-fs\");\n\n/**\n * @description Loads content from a file or returns the content if already loaded\n * @summary Determines if the input is already content or a path to a file, and loads the file if needed\n * @param {string | Uint8Array} contentOrPath - The content or path to load\n * @param {Function} fileReader - Function to read the file if contentOrPath is a path\n * @return {Promise<string | Uint8Array | Buffer>} The content\n * @function contentOfLoadFile\n * @memberOf module:for-fabric.client\n */\nexport async function contentOfLoadFile(\n  contentOrPath: string | Uint8Array,\n  fileReader: (path: string) => Promise<string | Uint8Array | Buffer>\n) {\n  if (contentOrPath instanceof Uint8Array) return contentOrPath;\n  if (\n    contentOrPath.match(\n      /-----BEGIN (CERTIFICATE|KEY|PRIVATE KEY)-----.+?-----END \\1-----$/gms\n    )\n  )\n    return contentOrPath;\n  return await fileReader(contentOrPath);\n}\n\n/**\n * @description Reads a file from the file system\n * @summary Loads a file using the Node.js file system module\n * @param {string | Buffer} contentOrPath - The content or path to load\n * @return {Promise<Buffer>} The file content as a Buffer\n * @function readFile\n * @memberOf module:for-fabric.client\n */\nexport async function readFile(contentOrPath: string | Buffer) {\n  if (typeof contentOrPath !== \"string\") return contentOrPath;\n\n  const fileReader = async (path: string) => {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    return await promises.readFile(path);\n  };\n\n  return await fileReader(contentOrPath);\n}\n\n/**\n * @description Creates a Certificate Authority user\n * @summary Initializes a user with the given credentials for interacting with a Fabric CA\n * @param {string} userName - The user name\n * @param {string} privateKey - The private key as a string\n * @param {string} certificate - The certificate as a string\n * @param {string} mspId - The Membership Service Provider ID\n * @return {Promise<User>} Promise resolving to the created user\n * @function getCAUser\n * @memberOf module:for-fabric.client\n */\nexport async function getCAUser(\n  userName: string,\n  privateKey: string,\n  certificate: string,\n  mspId: string\n): Promise<User> {\n  log.debug(\n    `Creating a CA ${mspId} user ${userName} with certificate ${certificate}`\n  );\n  const user = new User(userName);\n  const cryptoSuite = User.newCryptoSuite();\n  user.setCryptoSuite(cryptoSuite);\n  const importedKey = cryptoSuite.createKeyFromRaw(privateKey);\n  await user.setEnrollment(importedKey, certificate, mspId);\n  return user;\n}\n\n/**\n * @description Gets an identity from a certificate directory\n * @summary Loads a certificate from a directory and creates an Identity object\n * @param {string} mspId - The Membership Service Provider ID\n * @param {string} certDirectoryPath - Path to the directory containing the certificate\n * @return {Promise<Identity>} Promise resolving to the identity\n * @function getIdentity\n * @memberOf module:for-fabric.client\n */\nexport async function getIdentity(\n  mspId: string,\n  certDirectoryPath: string\n): Promise<Identity> {\n  const identityFileReader = async (path: string) => {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    const certPath = await getFirstDirFileName(path);\n    const credentials = await promises.readFile(certPath);\n    return credentials;\n  };\n\n  const credentials: Uint8Array = (await contentOfLoadFile(\n    certDirectoryPath,\n    identityFileReader\n  )) as Uint8Array;\n\n  return { mspId, credentials };\n}\n\n/**\n * @description Gets the full path of the first file in a directory\n * @summary Reads a directory and returns the path to the first file found\n * @param {string} dirPath - Path to the directory\n * @return {Promise<string>} Promise resolving to the full path of the first file\n * @function getFirstDirFileName\n * @memberOf module:for-fabric.client\n */\nexport async function getFirstDirFileName(dirPath: string): Promise<string> {\n  const { promises } = await normalizeImport(import(\"fs\"));\n  const { join } = await normalizeImport(import(\"path\"));\n  const files = await promises.readdir(dirPath);\n  return join(dirPath, files[0]);\n}\n\n/**\n * @description Gets the content of the first file in a directory\n * @summary Reads a directory, finds the first file, and returns its content as a string\n * @param {string} dirPath - Path to the directory\n * @return {Promise<string>} Promise resolving to the content of the first file\n * @function getFirstDirFileNameContent\n * @memberOf module:for-fabric.client\n */\nexport async function getFirstDirFileNameContent(\n  dirPath: string\n): Promise<string> {\n  const { promises } = await normalizeImport(import(\"fs\"));\n  const { join } = await normalizeImport(import(\"path\"));\n  const files = await promises.readdir(dirPath);\n  return (await promises.readFile(join(dirPath, files[0]))).toString();\n}\n\n/**\n * @description Gets a signer from a key directory\n * @summary Loads a private key from a directory and creates a Signer for Fabric transactions\n * @param {string} keyDirectoryPath - Path to the directory containing the private key\n * @return {Promise<Signer>} Promise resolving to the signer\n * @function getSigner\n * @memberOf module:for-fabric.client\n */\nexport async function getSigner(keyDirectoryPath: string): Promise<Signer> {\n  const signerFileReader = async (path: string) => {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    const keyPath = await getFirstDirFileName(path);\n    return await promises.readFile(keyPath);\n  };\n\n  const privateKeyPem = (await contentOfLoadFile(\n    keyDirectoryPath,\n    signerFileReader\n  )) as Buffer;\n  // Node based implementation\n  // privateKey = createPrivateKey(privateKeyPem);\n  // --\n\n  // web based implementation\n  const privateKey = await extractPrivateKey(privateKeyPem);\n  const keys = Object.getOwnPropertySymbols(privateKey);\n  const k = (privateKey as any)[keys[0]];\n  // --\n\n  return signers.newPrivateKeySigner(k as any);\n}\n\n/**\n * @description Extracts a private key from a PEM buffer\n * @summary Converts a PEM-encoded private key to a CryptoKey object\n * @param {Buffer} pem - The PEM-encoded private key\n * @return {Promise<CryptoKey>} Promise resolving to the CryptoKey\n * @function extractPrivateKey\n * @memberOf module:for-fabric.client\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant ExtractPrivateKey\n *   participant SubtleCrypto\n *\n *   Caller->>ExtractPrivateKey: extractPrivateKey(pem)\n *   ExtractPrivateKey->>ExtractPrivateKey: Get SubtleCrypto implementation\n *   ExtractPrivateKey->>ExtractPrivateKey: Parse PEM format\n *   ExtractPrivateKey->>ExtractPrivateKey: Convert to binary DER\n *   ExtractPrivateKey->>SubtleCrypto: importKey(pkcs8, binaryDer, options)\n *   SubtleCrypto-->>ExtractPrivateKey: CryptoKey\n *   ExtractPrivateKey-->>Caller: CryptoKey\n */\nexport async function extractPrivateKey(pem: Buffer) {\n  const libName = \"crypto\";\n  let subtle;\n  if (isBrowser()) {\n    subtle = (globalThis as any).crypto.subtle;\n  } else {\n    const lib = (await normalizeImport(import(libName))) as any;\n    subtle = lib.subtle || lib.webcrypto.subtle;\n  }\n\n  if (!subtle) throw new Error(\"Could not load SubtleCrypto module\");\n\n  function str2ab(str: string) {\n    const buf = new ArrayBuffer(str.length);\n    const bufView = new Uint8Array(buf);\n    for (let i = 0, strLen = str.length; i < strLen; i++) {\n      bufView[i] = str.charCodeAt(i);\n    }\n    return buf;\n  }\n\n  const str = pem\n    .toString(\"utf8\")\n    .replace(\"-----BEGIN PRIVATE KEY-----\", \"\")\n    .replaceAll(\"\\n\", \"\")\n    .replace(\"-----END PRIVATE KEY-----\", \"\");\n  const decoded = Buffer.from(str, \"base64\").toString(\"binary\");\n  const binaryDer = str2ab(decoded);\n\n  try {\n    const key = await subtle.importKey(\n      \"pkcs8\",\n      binaryDer,\n      {\n        name: \"ECDSA\",\n        namedCurve: \"P-256\",\n      },\n      true,\n      [\"sign\"]\n    );\n\n    return key;\n  } catch (e: any) {\n    throw new InternalError(e);\n  }\n}\n","import {\n  AdapterFlags,\n  Condition,\n  Context,\n  GroupOperator,\n  MaybeContextualArg,\n  Operator,\n  OrderDirection,\n  PersistenceKeys,\n  PreparedStatement,\n  PreparedStatementKeys,\n  QueryClause,\n  QueryError,\n  Repository,\n  SelectSelector,\n  Sequence,\n  Statement,\n  StatementExecutor,\n  ViewKind,\n} from \"@decaf-ts/core\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { FabricClientAdapter } from \"./FabricClientAdapter\";\nimport {\n  CouchDBKeys,\n  CouchDBOperator,\n  CouchDBGroupOperator,\n  CouchDBQueryLimit,\n  MangoQuery,\n  MangoOperator,\n  MangoSelector,\n  translateOperators,\n  generateDesignDocName,\n  generateViewName,\n  findViewMetadata,\n  CouchDBViewMetadata,\n  ViewResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport { FabricClientFlags } from \"./types\";\nimport { toCamelCase } from \"@decaf-ts/logging\";\nimport { DBKeys, InternalError } from \"@decaf-ts/db-decorators\";\nimport { Metadata } from \"@decaf-ts/decoration\";\n\ntype FabricViewDescriptor = {\n  ddoc: string;\n  view: string;\n  options: Record<string, any>;\n};\n\ntype FabricAggregateInfo =\n  | {\n      kind: ViewKind;\n      meta: CouchDBViewMetadata;\n      descriptor: FabricViewDescriptor;\n      countDistinct?: boolean;\n    }\n  | {\n      kind: \"avg\";\n      attribute: string;\n      sumDescriptor: FabricViewDescriptor;\n      countDescriptor: FabricViewDescriptor;\n    };\n\nconst escapeRegExp = (value: string): string =>\n  value.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n\nfunction nextLexicographicString(value: string): string {\n  if (!value) return \"\\u0000\";\n  const chars = Array.from(value);\n  for (let i = chars.length - 1; i >= 0; i -= 1) {\n    const code = chars[i].codePointAt(0);\n    if (code === undefined) continue;\n    if (code < 0x10ffff) {\n      chars[i] = String.fromCodePoint(code + 1);\n      return chars.slice(0, i + 1).join(\"\");\n    }\n  }\n  return `${value}\\u0000`;\n}\n\nfunction prefixRange(prefix: string) {\n  return {\n    start: prefix,\n    end: nextLexicographicString(prefix),\n  };\n}\n\nexport class FabricClientStatement<M extends Model, R> extends Statement<\n  M,\n  FabricClientAdapter,\n  R,\n  MangoQuery\n> {\n  constructor(adapter: FabricClientAdapter, overrides?: Partial<AdapterFlags>) {\n    super(adapter, overrides);\n  }\n\n  protected override squash(\n    ctx: Context<FabricClientFlags>\n  ): PreparedStatement<any> | undefined {\n    const squashed: PreparedStatement<M> | undefined = super.squash(\n      ctx as never\n    );\n    if (!squashed) return squashed;\n\n    const { method, params, args } = squashed;\n    const { direction, limit } = params;\n    switch (method) {\n      case PreparedStatementKeys.FIND:\n        break;\n      case PreparedStatementKeys.PAGE:\n        args.push(direction, limit);\n        break;\n      case PreparedStatementKeys.FIND_BY:\n        break;\n      case PreparedStatementKeys.LIST_BY:\n        args.push(direction);\n        break;\n      case PreparedStatementKeys.PAGE_BY:\n        args.push(direction, limit);\n        break;\n      case PreparedStatementKeys.FIND_ONE_BY:\n        break;\n      default:\n        throw new InternalError(`Unsupported method ${method}`);\n    }\n\n    return squashed;\n  }\n\n  protected override async executePrepared(\n    ...argz: MaybeContextualArg<Context<FabricClientFlags>>\n  ): Promise<R> {\n    const repo = Repository.forModel(this.fromSelector, this.adapter.alias);\n    const { method, args } = this.prepared as PreparedStatement<any>;\n    return repo.statement(method, ...args, ...argz);\n  }\n\n  override async prepare(\n    ctx?: Context<FabricClientFlags>\n  ): Promise<StatementExecutor<M, R>> {\n    ctx =\n      ctx ||\n      (await this.adapter.context(\n        PersistenceKeys.QUERY,\n        this.overrides || {},\n        this.fromSelector\n      ));\n\n    if (\n      this.isSimpleQuery() &&\n      (ctx as Context<FabricClientFlags>).get(\"forcePrepareSimpleQueries\")\n    ) {\n      const squashed = this.squash(ctx as Context<FabricClientFlags>);\n      if (squashed) {\n        this.prepared = squashed;\n        return this;\n      }\n    }\n    const args: (string | number)[] = [];\n    const params: any = {} as any;\n\n    const prepared: PreparedStatement<any> = {\n      class: this.fromSelector,\n      args,\n      params,\n    } as any;\n\n    const method: string[] = [QueryClause.FIND_BY];\n\n    if (this.whereCondition) {\n      const parsed = this.prepareCondition(this.whereCondition, ctx as never);\n      method.push(parsed.method);\n      if (parsed.args && parsed.args.length)\n        args.push(...(parsed.args as (string | number)[]));\n    }\n    if (this.selectSelector)\n      method.push(\n        QueryClause.SELECT,\n        this.selectSelector.join(` ${QueryClause.AND.toLowerCase()} `)\n      );\n    if (this.orderBySelectors?.length) {\n      method.push(QueryClause.ORDER_BY, this.orderBySelectors[0][0] as string);\n      args.push(this.orderBySelectors[0][1] as any);\n    }\n    prepared.method = toCamelCase(method.join(\" \"));\n    prepared.params = params;\n    this.prepared = prepared;\n    return this;\n  }\n\n  /**\n   * @description Processes a record from CouchDB/Fabric\n   * @summary Extracts the ID from a CouchDB document and reverts it to a model instance\n   */\n  protected override processRecord(\n    record: any,\n    ctx: Context<FabricClientFlags>\n  ): M {\n    const pkAttr = Model.pk(this.fromSelector);\n    const type = Metadata.get(\n      this.fromSelector,\n      Metadata.key(DBKeys.ID, pkAttr as string)\n    )?.type;\n\n    if (record[CouchDBKeys.ID]) {\n      const [, ...keyArgs] = record[CouchDBKeys.ID].split(CouchDBKeys.SEPARATOR);\n      const id = keyArgs.join(\"_\");\n      record[pkAttr] = Sequence.parseValue(type as any, id);\n    }\n\n    return super.processRecord(record, ctx);\n  }\n\n  /**\n   * @description Executes a raw Mango query\n   * @summary Sends a raw Mango query to Fabric and processes the results\n   */\n  override async raw<R>(rawInput: MangoQuery, ...args: any[]): Promise<R> {\n    const { ctx } = this.logCtx(args, this.raw);\n    const aggregator = (rawInput as any)?.aggregateInfo;\n    if ((rawInput as any)?.aggregate && aggregator) {\n      return this.executeAggregate<R>(aggregator, ctx);\n    }\n    const results: any[] = await this.adapter.raw(\n      rawInput,\n      true,\n      this.fromSelector,\n      ctx\n    );\n\n    if (!this.selectSelector) {\n      const processed = results.map((r) => this.processRecord(r, ctx));\n      if (!ctx.getOrUndefined(\"afterQueryHandlers\")) {\n        return processed as unknown as R;\n      }\n      return (await this.applyAfterHandlersToResult(processed, ctx)) as R;\n    }\n    return results as R;\n  }\n\n  /**\n   * @description Builds a CouchDB Mango query from the statement\n   * @summary Converts the statement's conditions, selectors, and options into a CouchDB Mango query\n   */\n  protected override build(): MangoQuery {\n    const log = this.log.for(this.build);\n    const aggregateQuery = this.buildAggregateQuery();\n    if (aggregateQuery) return aggregateQuery;\n    const selectors: MangoSelector = {};\n    selectors[CouchDBKeys.TABLE] = {};\n    selectors[CouchDBKeys.TABLE] = Model.tableName(this.fromSelector);\n    const query: MangoQuery = { selector: selectors };\n    if (this.selectSelector) query.fields = this.selectSelector as string[];\n\n    if (this.whereCondition) {\n      const condition: MangoSelector = this.parseCondition(\n        Condition.and(\n          this.whereCondition,\n          Condition.attribute<M>(CouchDBKeys.TABLE as keyof M).eq(\n            query.selector[CouchDBKeys.TABLE]\n          )\n        )\n      ).selector;\n      const selectorKeys = Object.keys(condition) as MangoOperator[];\n      if (\n        selectorKeys.length === 1 &&\n        Object.values(CouchDBGroupOperator).indexOf(selectorKeys[0]) !== -1\n      )\n        switch (selectorKeys[0]) {\n          case CouchDBGroupOperator.AND:\n            condition[CouchDBGroupOperator.AND] = [\n              ...Object.values(\n                condition[CouchDBGroupOperator.AND] as MangoSelector\n              ).reduce((accum: MangoSelector[], val: any) => {\n                const keys = Object.keys(val);\n                if (keys.length !== 1)\n                  throw new Error(\n                    \"Too many keys in query selector. should be one\"\n                  );\n                const k = keys[0];\n                if (k === CouchDBGroupOperator.AND)\n                  accum.push(...(val[k] as any[]));\n                else accum.push(val);\n                return accum;\n              }, []),\n            ];\n            query.selector = condition;\n            break;\n          case CouchDBGroupOperator.OR: {\n            const s: Record<any, any> = {};\n            s[CouchDBGroupOperator.AND] = [\n              condition,\n              ...Object.entries(query.selector).map(([key, val]) => {\n                const result: Record<any, any> = {};\n                result[key] = val;\n                return result;\n              }),\n            ];\n            query.selector = s;\n            break;\n          }\n          default:\n            throw new Error(\"This should be impossible\");\n        }\n      else {\n        Object.entries(condition).forEach(([key, val]) => {\n          if (query.selector[key])\n            log.warn(\n              `A ${key} query param is about to be overridden: ${query.selector[key]} by ${val}`\n            );\n          query.selector[key] = val;\n        });\n      }\n    }\n\n    if (this.orderBySelectors?.length) {\n      query.sort = query.sort || [];\n      query.selector = query.selector || ({} as MangoSelector);\n      for (const [selectorKey, direction] of this.orderBySelectors) {\n        const selector = selectorKey as string;\n        const rec: Record<string, OrderDirection> = {};\n        rec[selector] = direction as OrderDirection;\n        (query.sort as Record<string, OrderDirection>[]).push(rec);\n        if (!query.selector[selector]) {\n          query.selector[selector] = {} as MangoSelector;\n          (query.selector[selector] as MangoSelector)[CouchDBOperator.BIGGER] =\n            null;\n        }\n      }\n    }\n\n    if (this.limitSelector) {\n      query.limit = this.limitSelector;\n    } else {\n      log.warn(\n        `No limit selector defined. Using default couchdb limit of ${CouchDBQueryLimit}`\n      );\n      query.limit = CouchDBQueryLimit;\n    }\n\n    if (this.offsetSelector) query.skip = this.offsetSelector;\n\n    return query;\n  }\n\n  /**\n   * @description Parses a condition into a CouchDB Mango query selector\n   * @summary Converts a Condition object into a CouchDB Mango query selector structure\n   */\n  protected override parseCondition(condition: Condition<M>): MangoQuery {\n    function merge(\n      op: MangoOperator,\n      obj1: MangoSelector,\n      obj2: MangoSelector\n    ): MangoQuery {\n      const result: MangoQuery = { selector: {} as MangoSelector };\n      result.selector[op] = [obj1, obj2];\n      return result;\n    }\n\n    const { attr1, operator, comparison } = condition as unknown as {\n      attr1: string | Condition<M>;\n      operator: Operator | GroupOperator;\n      comparison: any;\n    };\n\n    if (operator === Operator.STARTS_WITH) {\n      if (typeof attr1 !== \"string\")\n        throw new QueryError(\"STARTS_WITH requires an attribute name\");\n      if (typeof comparison !== \"string\")\n        throw new QueryError(\"STARTS_WITH requires a string comparison\");\n      const range = prefixRange(comparison);\n      const selector: MangoSelector = {} as MangoSelector;\n      selector[attr1] = {} as MangoSelector;\n      (selector[attr1] as MangoSelector)[CouchDBOperator.BIGGER_EQ] = range.start;\n      (selector[attr1] as MangoSelector)[CouchDBOperator.SMALLER] = range.end;\n      return { selector };\n    }\n\n    if (operator === Operator.ENDS_WITH) {\n      if (typeof attr1 !== \"string\")\n        throw new QueryError(\"ENDS_WITH requires an attribute name\");\n      if (typeof comparison !== \"string\")\n        throw new QueryError(\"ENDS_WITH requires a string comparison\");\n      const selector: MangoSelector = {} as MangoSelector;\n      selector[attr1] = {\n        [CouchDBOperator.REGEXP]: `${escapeRegExp(comparison)}$`,\n      } as MangoSelector;\n      return { selector };\n    }\n\n    if (operator === Operator.BETWEEN) {\n      const attr = attr1 as string;\n      if (!Array.isArray(comparison) || comparison.length !== 2)\n        throw new QueryError(\"BETWEEN operator requires [min, max] comparison\");\n      const [min, max] = comparison;\n      const opBetween: MangoSelector = {} as MangoSelector;\n      opBetween[attr] = {} as MangoSelector;\n      (opBetween[attr] as MangoSelector)[\n        translateOperators(Operator.BIGGER_EQ)\n      ] = min;\n      (opBetween[attr] as MangoSelector)[\n        translateOperators(Operator.SMALLER_EQ)\n      ] = max;\n      return { selector: opBetween };\n    }\n\n    let op: MangoSelector = {} as MangoSelector;\n    if (\n      [GroupOperator.AND, GroupOperator.OR, Operator.NOT].indexOf(\n        operator as GroupOperator\n      ) === -1\n    ) {\n      op[attr1 as string] = {} as MangoSelector;\n      (op[attr1 as string] as MangoSelector)[translateOperators(operator)] =\n        comparison;\n    } else if (operator === Operator.NOT) {\n      op = this.parseCondition(attr1 as Condition<M>).selector as MangoSelector;\n      op[translateOperators(Operator.NOT)] = {} as MangoSelector;\n      (op[translateOperators(Operator.NOT)] as MangoSelector)[\n        (attr1 as unknown as { attr1: string }).attr1\n      ] = comparison;\n    } else {\n      const op1: any = this.parseCondition(attr1 as Condition<M>).selector;\n      const op2: any = this.parseCondition(comparison as Condition<M>).selector;\n      op = merge(translateOperators(operator), op1, op2).selector;\n    }\n\n    return { selector: op };\n  }\n\n  /**\n   * @description Builds an aggregate query if aggregation is requested\n   * @summary Checks for aggregate operations and returns a special MangoQuery for them\n   */\n  private buildAggregateQuery(): MangoQuery | undefined {\n    if (!this.fromSelector) return undefined;\n    if (this.avgSelector) {\n      const attribute = String(this.avgSelector);\n      const sumInfo = this.createAggregateDescriptor(\"sum\", attribute);\n      const countInfo = this.createAggregateDescriptor(\"count\", attribute);\n      if (!sumInfo || !countInfo)\n        throw new QueryError(\n          `Avg operation requires sum and count views for attribute ${attribute}`\n        );\n      return this.createAggregateQuery({\n        kind: \"avg\",\n        attribute,\n        sumDescriptor: sumInfo.descriptor,\n        countDescriptor: countInfo.descriptor,\n      });\n    }\n\n    if (typeof this.countDistinctSelector !== \"undefined\") {\n      const attribute =\n        this.countDistinctSelector == null\n          ? undefined\n          : String(this.countDistinctSelector);\n      const info = this.createAggregateDescriptor(\"distinct\", attribute);\n      if (info) {\n        info.countDistinct = true;\n        return this.createAggregateQuery(info);\n      }\n    }\n\n    const aggregatorUsed =\n      typeof this.countSelector !== \"undefined\" ||\n      typeof this.countDistinctSelector !== \"undefined\" ||\n      !!this.minSelector ||\n      !!this.maxSelector ||\n      !!this.sumSelector ||\n      !!this.distinctSelector;\n\n    const aggregatorChecks: Array<[ViewKind, SelectSelector<M> | undefined]> = [\n      [\n        \"count\",\n        (this.countSelector ?? undefined) as SelectSelector<M> | undefined,\n      ],\n      [\"max\", this.maxSelector],\n      [\"min\", this.minSelector],\n      [\"sum\", this.sumSelector],\n      [\"distinct\", this.distinctSelector],\n    ];\n\n    for (const [kind, selector] of aggregatorChecks) {\n      const attribute = selector ? String(selector) : undefined;\n      const info = this.createAggregateDescriptor(kind, attribute);\n      if (info) return this.createAggregateQuery(info);\n    }\n\n    if (aggregatorUsed) {\n      throw new QueryError(\n        `No CouchDB view metadata found for table ${Model.tableName(\n          this.fromSelector\n        )} aggregator`\n      );\n    }\n    return undefined;\n  }\n\n  /**\n   * @description Creates an aggregate descriptor for a view-based aggregation\n   */\n  private createAggregateDescriptor(\n    kind: ViewKind,\n    attribute?: string\n  ): Extract<FabricAggregateInfo, { kind: ViewKind }> | undefined {\n    if (!this.fromSelector) return undefined;\n    const metas = findViewMetadata(this.fromSelector, kind, attribute);\n    if (!metas.length) return undefined;\n    const meta = metas[0];\n    const tableName = Model.tableName(this.fromSelector);\n    const viewName = generateViewName(tableName, meta.attribute, kind, meta);\n    const ddoc = meta.ddoc || generateDesignDocName(tableName, viewName);\n    const options: Record<string, any> = {\n      reduce: meta.reduce !== undefined ? true : !meta.returnDocs,\n    };\n    if (kind === \"distinct\" || kind === \"groupBy\") options.group = true;\n    return {\n      kind,\n      meta,\n      descriptor: {\n        ddoc,\n        view: viewName,\n        options,\n      },\n    };\n  }\n\n  /**\n   * @description Creates the special aggregate MangoQuery marker\n   */\n  private createAggregateQuery(\n    info: FabricAggregateInfo\n  ): MangoQuery & { aggregate: true; aggregateInfo: FabricAggregateInfo } {\n    return {\n      selector: {},\n      aggregate: true,\n      aggregateInfo: info,\n    } as MangoQuery & { aggregate: true; aggregateInfo: FabricAggregateInfo };\n  }\n\n  /**\n   * @description Gets the adapter cast to FabricClientAdapter for view access\n   */\n  private getFabricAdapter(): FabricClientAdapter {\n    return this.adapter as FabricClientAdapter;\n  }\n\n  /**\n   * @description Executes an aggregate query via adapter's view method\n   */\n  private async executeAggregate<R>(\n    info: FabricAggregateInfo,\n    ctx: Context<FabricClientFlags>\n  ): Promise<R> {\n    if (!this.isViewAggregate(info)) {\n      return this.handleAverage<R>(info, ctx);\n    }\n    const fabricAdapter = this.getFabricAdapter();\n    const viewInfo = info as Extract<FabricAggregateInfo, { kind: ViewKind }>;\n    const response = await fabricAdapter.view<ViewResponse>(\n      viewInfo.descriptor.ddoc,\n      viewInfo.descriptor.view,\n      viewInfo.descriptor.options,\n      ctx\n    );\n    return this.processViewResponse<R>(info, response);\n  }\n\n  /**\n   * @description Handles average calculation from sum and count views\n   */\n  private async handleAverage<R>(\n    info: FabricAggregateInfo,\n    ctx: Context<FabricClientFlags>\n  ): Promise<R> {\n    if (info.kind !== \"avg\")\n      throw new QueryError(\"Average descriptor is not valid\");\n    const fabricAdapter = this.getFabricAdapter();\n    const [sumDesc, countDesc] = [info.sumDescriptor, info.countDescriptor];\n    const [sumResponse, countResponse] = await Promise.all([\n      fabricAdapter.view<ViewResponse>(\n        sumDesc.ddoc,\n        sumDesc.view,\n        sumDesc.options,\n        ctx\n      ),\n      fabricAdapter.view<ViewResponse>(\n        countDesc.ddoc,\n        countDesc.view,\n        countDesc.options,\n        ctx\n      ),\n    ]);\n    const sum = sumResponse.rows?.[0]?.value ?? 0;\n    const count = countResponse.rows?.[0]?.value ?? 0;\n    if (!count) return 0 as unknown as R;\n    return (sum / count) as unknown as R;\n  }\n\n  /**\n   * @description Processes the view response based on aggregate kind\n   */\n  private processViewResponse<R>(\n    info: FabricAggregateInfo,\n    response: ViewResponse\n  ): R {\n    if (info.kind === \"avg\")\n      throw new QueryError(\n        \"Average results should be handled before processing rows\"\n      );\n    const rows = response.rows || [];\n    const viewInfo = info as Extract<FabricAggregateInfo, { kind: ViewKind }>;\n    const meta = viewInfo.meta;\n    if (viewInfo.countDistinct) {\n      return (rows.length || 0) as unknown as R;\n    }\n    if (viewInfo.kind === \"distinct\" || viewInfo.kind === \"groupBy\") {\n      return rows.map((row) => row.key ?? row.value) as unknown as R;\n    }\n    if (meta.returnDocs) {\n      return rows.map((row) => row.value ?? row.doc ?? row) as unknown as R;\n    }\n    if (!rows.length) {\n      return (viewInfo.kind === \"count\" ? 0 : null) as unknown as R;\n    }\n    return (rows[0].value ?? rows[0].key ?? null) as unknown as R;\n  }\n\n  /**\n   * @description Type guard to check if info is a view-based aggregate\n   */\n  private isViewAggregate(\n    info: FabricAggregateInfo\n  ): info is Extract<FabricAggregateInfo, { kind: ViewKind }> {\n    return info.kind !== \"avg\";\n  }\n}\n","import \"../shared/overrides\";\nimport {\n  CouchDBKeys,\n  type MangoQuery,\n  type ViewResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport { Client } from \"@grpc/grpc-js\";\nimport * as grpc from \"@grpc/grpc-js\";\nimport {\n  Model,\n  type ModelConstructor,\n  type Serializer,\n} from \"@decaf-ts/decorator-validation\";\nimport { debug, final, Logging } from \"@decaf-ts/logging\";\nimport {\n  type PeerConfig,\n  type SegregatedModel,\n  type MspDetails,\n} from \"../shared/types\";\nimport {\n  connect,\n  type ConnectOptions,\n  Gateway,\n  Network,\n  ProposalOptions,\n  Contract as Contrakt,\n  type Signer,\n  GatewayError,\n  EndorseError,\n} from \"@hyperledger/fabric-gateway\";\nimport { Gateway as LegacyGateway, Wallets } from \"fabric-network\";\nimport type { Endorser } from \"fabric-common\";\nimport {\n  getIdentity,\n  getSigner,\n  getFirstDirFileNameContent,\n  readFile as readFsFile,\n} from \"./fabric-fs\";\nimport {\n  BaseError,\n  InternalError,\n  OperationKeys,\n  SerializationError,\n  BulkCrudOperationKeys,\n  NotFoundError,\n  ConflictError,\n  BadRequestError,\n  type PrimaryKeyType,\n  ValidationError,\n} from \"@decaf-ts/db-decorators\";\nimport {\n  Context,\n  Adapter,\n  type AdapterFlags,\n  AuthorizationError,\n  ConnectionError,\n  ForbiddenError,\n  MigrationError,\n  ObserverError,\n  PagingError,\n  PersistenceKeys,\n  QueryError,\n  Repository,\n  UnsupportedError,\n  Statement,\n  type PreparedStatement,\n  Paginator,\n  MaybeContextualArg,\n  ContextualArgs,\n  type PreparedModel,\n  AllOperationKeys,\n} from \"@decaf-ts/core\";\nimport { FabricFlavour } from \"../shared/constants\";\nimport { ClientSerializer } from \"../shared/ClientSerializer\";\nimport { FabricClientDispatch } from \"./FabricClientDispatch\";\n// import { HSMSignerFactoryCustom } from \"./fabric-hsm\";\nimport { type Constructor } from \"@decaf-ts/decoration\";\nimport { FabricClientStatement } from \"./FabricClientStatement\";\nimport { FabricClientPaginator } from \"./FabricClientPaginator\";\nimport { FabricClientRepository } from \"./FabricClientRepository\";\nimport {\n  EndorsementError,\n  EndorsementPolicyError,\n  MvccReadConflictError,\n  PhantomReadConflictError,\n  TransactionTimeoutError,\n} from \"../shared/errors\";\nimport { FabricClientFlags } from \"./types\";\nimport { DefaultFabricClientFlags } from \"./constants\";\nimport fs from \"fs\";\nimport { CryptoUtils } from \"./crypto\";\nimport { extractIds } from \"./ids/id-extraction\";\nimport { Identity } from \"../shared/index\";\n\ntype LegacyPeerTarget = {\n  mspId: string;\n  peerEndpoint: string;\n  peerHostAlias?: string;\n  tlsCert?: string | Buffer;\n};\n\ntype LegacyPeerWithName = LegacyPeerTarget & { name: string };\n\n/**\n * @description Adapter for interacting with Hyperledger Fabric networks\n * @summary The FabricAdapter extends CouchDBAdapter to provide a seamless interface for interacting with Hyperledger Fabric networks.\n * It handles connection management, transaction submission, and CRUD operations against Fabric chaincode.\n * @template PeerConfig - Configuration type for connecting to a Fabric peer\n * @template FabricFlags - Flags specific to Fabric operations\n * @template Context<FabricFlags> - Context type containing Fabric-specific flags\n * @param config - Configuration for connecting to a Fabric peer\n * @param alias - Optional alias for the adapter instance\n * @class FabricClientAdapter\n * @example\n * ```typescript\n * // Create a new FabricAdapter instance\n * const config: PeerConfig = {\n *   mspId: 'Org1MSP',\n *   peerEndpoint: 'localhost:7051',\n *   channelName: 'mychannel',\n *   chaincodeName: 'mycc',\n *   contractName: 'mycontract',\n *   tlsCertPath: '/path/to/tls/cert',\n *   certDirectoryPath: '/path/to/cert/dir',\n *   keyDirectoryPath: '/path/to/key/dir'\n * };\n *\n * const adapter = new FabricAdapter(config, 'org1-adapter');\n *\n * // Use the adapter to interact with the Fabric network\n * const result = await adapter.read('users', 'user1', mySerializer);\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant FabricAdapter\n *   participant Gateway\n *   participant Network\n *   participant Contract\n *   participant Chaincode\n *\n *   Client->>FabricAdapter: create(tableName, id, model, transient, serializer)\n *   FabricAdapter->>FabricAdapter: submitTransaction(OperationKeys.CREATE, [serializedModel], transient)\n *   FabricAdapter->>Gateway: connect()\n *   Gateway->>Network: getNetwork(channelName)\n *   Network->>Contract: getContract(chaincodeName, contractName)\n *   FabricAdapter->>Contract: submit(api, proposalOptions)\n *   Contract->>Chaincode: invoke\n *   Chaincode-->>Contract: response\n *   Contract-->>FabricAdapter: result\n *   FabricAdapter->>FabricAdapter: decode(result)\n *   FabricAdapter->>FabricAdapter: serializer.deserialize(decodedResult)\n *   FabricAdapter-->>Client: deserializedResult\n */\nexport class FabricClientAdapter extends Adapter<\n  PeerConfig,\n  Client,\n  MangoQuery,\n  Context<FabricClientFlags>\n> {\n  /**\n   * @description Static text decoder for converting Uint8Array to string\n   */\n  private static decoder = new TextDecoder(\"utf8\");\n\n  private static serializer = new ClientSerializer();\n\n  protected static log = Logging.for(FabricClientAdapter);\n\n  protected readonly serializer: Serializer<any> =\n    FabricClientAdapter.serializer;\n\n  /**\n   * @description Creates a new FabricAdapter instance\n   * @summary Initializes a new adapter for interacting with a Hyperledger Fabric network\n   * @param {PeerConfig} config - Configuration for connecting to a Fabric peer\n   * @param {string} [alias] - Optional alias for the adapter instance\n   */\n  constructor(config: PeerConfig, alias?: string) {\n    super(\n      Object.assign({}, DefaultFabricClientFlags, config),\n      FabricFlavour,\n      alias\n    );\n  }\n\n  override Statement<M extends Model>(\n    overrides?: Partial<AdapterFlags>\n  ): Statement<M, FabricClientAdapter, any, MangoQuery> {\n    return new FabricClientStatement(this, overrides);\n  }\n\n  Paginator<M extends Model>(\n    query: PreparedStatement<any> | MangoQuery,\n    size: number,\n    clazz: Constructor<M>\n  ): Paginator<M, any, MangoQuery> {\n    return new FabricClientPaginator(this, query, size, clazz);\n  }\n\n  protected override async flags<M extends Model>(\n    operation: OperationKeys | string,\n    model: Constructor<M> | Constructor<M>[] | undefined,\n    flags: Partial<FabricClientFlags>,\n    ...args: any[]\n  ): Promise<FabricClientFlags> {\n    const mergedFlags = Object.assign({}, this.config, flags);\n    const f = Object.assign(\n      await super.flags(operation, model, mergedFlags, ...args)\n    );\n    return f;\n  }\n\n  override async context<M extends Model>(\n    operation: ((...args: any[]) => any) | AllOperationKeys,\n    overrides: Partial<FabricClientFlags>,\n    model: Constructor<M> | Constructor<M>[],\n    ...args: MaybeContextualArg<Context<any>>\n  ): Promise<Context<FabricClientFlags>> {\n    const log = this.log.for(this.context);\n    log.silly(\n      `creating new context for ${operation} operation on ${model ? (Array.isArray(model) ? model.map((m) => Model.tableName(m)) : Model.tableName(model)) : \"no\"} table ${overrides && Object.keys(overrides) ? Object.keys(overrides).length : \"no\"} with flag overrides`\n    );\n    let ctx = args.pop();\n    if (typeof ctx !== \"undefined\" && !(ctx instanceof Context)) {\n      args.push(ctx);\n      ctx = undefined;\n    }\n\n    overrides = ctx\n      ? Object.assign({}, ctx.toOverrides(), overrides)\n      : overrides;\n    const flags = await this.flags(\n      typeof operation === \"string\" ? operation : operation.name,\n      model,\n      overrides as Partial<FabricClientFlags>,\n      ...[...args, ctx].filter(Boolean)\n    );\n\n    if (ctx) {\n      if (!(ctx instanceof this.Context)) {\n        const newCtx = new this.Context().accumulate({\n          ...ctx[\"cache\"],\n          ...flags,\n          parentContext: ctx,\n        }) as any;\n        ctx.accumulate({\n          childContexts: [\n            ...(ctx.getOrUndefined(\"childContexts\") || []),\n            newCtx,\n          ],\n        });\n        return newCtx;\n      }\n      const currentOp = ctx.getOrUndefined(\"operation\");\n      const currentModel = ctx.getOrUndefined(\"affectedTables\");\n      if (\n        !currentOp ||\n        currentOp !== operation ||\n        (model && model !== currentModel)\n      ) {\n        const newCtx = new this.Context().accumulate({\n          ...ctx[\"cache\"],\n          ...flags,\n          parentContext: ctx,\n        }) as any;\n\n        ctx.accumulate({\n          childContexts: [\n            ...(ctx.getOrUndefined(\"childContexts\") || []),\n            newCtx,\n          ],\n        });\n        return newCtx;\n      }\n      return ctx.accumulate(flags) as any;\n    }\n\n    return new this.Context().accumulate({\n      ...flags,\n    }) as any;\n  }\n\n  /**\n   * @description Decodes a Uint8Array to a string\n   * @summary Converts binary data received from Fabric to a string using UTF-8 encoding\n   * @param {Uint8Array} data - The binary data to decode\n   * @return {string} The decoded string\n   */\n  decode(data: Uint8Array): string {\n    return FabricClientAdapter.decoder.decode(data);\n  }\n\n  override repository<\n    R extends Repository<\n      any,\n      Adapter<PeerConfig, Client, MangoQuery, Context<FabricClientFlags>>\n    >,\n  >(): Constructor<R> {\n    return FabricClientRepository as unknown as Constructor<R>;\n  }\n\n  protected createPrefix<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    model: Record<string, any>,\n    ...args: MaybeContextualArg<Context<FabricClientFlags>>\n  ): [Constructor<M>, PrimaryKeyType, Record<string, any>, ...any[], Context] {\n    const { ctxArgs } = this.logCtx(args, this.createPrefix);\n    const tableName = Model.tableName(clazz);\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    Object.assign(record, model);\n    return [clazz, id, record, ...ctxArgs];\n  }\n\n  /**\n   * @description Prepares multiple records for creation\n   * @summary Adds necessary CouchDB fields to multiple records before creation\n   * @param {string} tableName - The name of the table\n   * @param {string[]|number[]} ids - The IDs of the records\n   * @param models - The models to prepare\n   * @return A tuple containing the tableName, ids, and prepared records\n   * @throws {InternalError} If ids and models arrays have different lengths\n   */\n  protected createAllPrefix<M extends Model>(\n    clazz: Constructor<M>,\n    ids: string[] | number[],\n    models: Record<string, any>[],\n    ...args: MaybeContextualArg<Context<FabricClientFlags>>\n  ) {\n    const tableName = Model.tableName(clazz);\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const { ctxArgs } = this.logCtx(args, this.createAllPrefix);\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      Object.assign(record, models[count]);\n      return record;\n    });\n    return [clazz, ids, records, ...ctxArgs];\n  }\n\n  protected updateAllPrefix<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    models: Record<string, any>[],\n    ...args: MaybeContextualArg<Context<FabricClientFlags>>\n  ) {\n    const tableName = Model.tableName(clazz);\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const { ctxArgs } = this.logCtx(args, this.updateAllPrefix);\n    const records = ids.map(() => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      return record;\n    });\n    return [clazz, ids, records, ...ctxArgs];\n  }\n\n  /**\n   * @description Creates multiple records in a single transaction\n   * @summary Submits a transaction to create multiple records in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of record identifiers\n   * @param {Array<Record<string, any>>} models - Array of record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the created records\n   */\n  override async createAll<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    models: Record<string, any>[],\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>[]> {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    //HERE!\n    const ctxArgs = [...(args as unknown as any[])];\n    const transient = ctxArgs.shift() as Record<string, any>;\n    const { log, ctx } = this.logCtx(\n      ctxArgs as ContextualArgs<Context<FabricClientFlags>>,\n      this.createAll\n    );\n    const tableName = Model.tableName(clazz);\n\n    log.info(`adding ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const hasTransient = transient && Object.keys(transient).length > 0;\n    const needsFullPayload =\n      hasTransient || this.shouldForceGatewayHydration(ctx);\n    const transientPayload = hasTransient ? { [tableName]: transient } : {};\n\n    const result = await this.submitTransaction(\n      ctx,\n      BulkCrudOperationKeys.CREATE_ALL,\n      [\n        JSON.stringify(\n          models.map((m) => this.serializer.serialize(m, clazz.name))\n        ),\n      ],\n      transientPayload as any,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n\n    let res: Record<string, any>[];\n    try {\n      res = JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n\n    if (\n      this.shouldRefreshAfterWrite(\n        clazz,\n        ctx,\n        needsFullPayload,\n        res[0][Model.pk(clazz) as string] || ids[0]\n      )\n    ) {\n      return this.readAll(\n        clazz,\n        extractIds(\n          clazz,\n          models.map((m, i) =>\n            Model.merge(Object.assign({}, m as any, transient[i] || {}), res[i])\n          ),\n          ids\n        ),\n        ctx\n      );\n    }\n\n    return res;\n  }\n\n  /**\n   * @description Reads multiple records in a single transaction\n   * @summary Submits a transaction to read multiple records from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of record identifiers to read\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the retrieved records\n   */\n  override async readAll<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>[]> {\n    const { log, ctx } = this.logCtx(args, this.readAll);\n    const tableName = Model.tableName(clazz);\n    log.info(`reading ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const result = await this.evaluateTransaction(\n      ctx,\n      BulkCrudOperationKeys.READ_ALL,\n      [JSON.stringify(ids)],\n      undefined,\n      undefined,\n      clazz.name\n    );\n    try {\n      return JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n  }\n\n  /**\n   * @description Updates multiple records in a single transaction\n   * @summary Submits a transaction to update multiple records in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of record identifiers\n   * @param {Array<Record<string, any>>} models - Array of updated record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the updated records\n   */\n  override async updateAll<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    models: Record<string, any>[],\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>[]> {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const ctxArgs = [...(args as unknown as any[])];\n    const transient = ctxArgs.shift() as Record<string, any>;\n    const { log, ctx } = this.logCtx(\n      ctxArgs as ContextualArgs<Context<FabricClientFlags>>,\n      this.updateAll\n    );\n    const tableName = Model.tableName(clazz);\n    log.info(`updating ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const hasTransient = transient && Object.keys(transient).length > 0;\n    const needsFullPayload =\n      hasTransient || this.shouldForceGatewayHydration(ctx);\n    const transientPayload = hasTransient ? { [tableName]: transient } : {};\n\n    const result = await this.submitTransaction(\n      ctx,\n      BulkCrudOperationKeys.UPDATE_ALL,\n      [\n        JSON.stringify(\n          models.map((m) => this.serializer.serialize(m, clazz.name))\n        ),\n      ],\n      transientPayload as any,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n\n    let res: any;\n    try {\n      res = JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n\n    if (this.shouldRefreshAfterWrite(clazz, ctx, needsFullPayload, ids[0])) {\n      return this.readAll(\n        clazz,\n        extractIds(\n          clazz,\n          models.map((m, i) =>\n            Model.merge(Object.assign({}, m as any, transient[i] || {}), res[i])\n          ),\n          ids\n        ),\n        ctx\n      );\n    }\n    return res;\n  }\n\n  /**\n   * @description Deletes multiple records in a single transaction\n   * @summary Submits a transaction to delete multiple records from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of record identifiers to delete\n   * @param {Serializer<any>} serializer - Serializer for the model data\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the deleted records\n   */\n  override async deleteAll<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>[]> {\n    const { log, ctx, ctxArgs } = this.logCtx(args, this.deleteAll);\n    const tableName = Model.tableName(clazz);\n\n    const needsFullPayload =\n      Model.isTransient(clazz) || this.shouldForceGatewayHydration(ctx);\n    let result: any;\n    const shouldHydrate = this.shouldRefreshAfterWrite(\n      clazz,\n      ctx,\n      needsFullPayload,\n      ids[0]\n    );\n    if (shouldHydrate) {\n      result = await this.readAll(clazz, ids, ...ctxArgs);\n    }\n\n    log.info(`deleting ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const res = await this.submitTransaction(\n      ctx,\n      BulkCrudOperationKeys.DELETE_ALL,\n      [JSON.stringify(ids)],\n      undefined,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n    try {\n      return shouldHydrate\n        ? result\n        : JSON.parse(this.decode(res)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n  }\n\n  /**\n   * @description Prepares a model for persistence\n   * @summary Converts a model instance into a format suitable for database storage,\n   * handling column mapping and separating transient properties\n   * @template M - The model type\n   * @param {M} model - The model instance to prepare\n   * @param pk - The primary key property name\n   * @return The prepared data\n   */\n  override prepare<M extends Model>(\n    model: M,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): SegregatedModel<M> & PreparedModel {\n    const { log, ctx } = this.logCtx(args, this.prepare);\n    const split = Model.segregate(model);\n    if ((model as any)[PersistenceKeys.METADATA]) {\n      log.silly(\n        `Passing along persistence metadata for ${(model as any)[PersistenceKeys.METADATA]}`\n      );\n      Object.defineProperty(split.model, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        configurable: true,\n        value: (model as any)[PersistenceKeys.METADATA],\n      });\n    }\n\n    const mirrorMeta = Model.mirroredAt(model);\n    if (mirrorMeta) {\n      const mirrorMsp = mirrorMeta.mspId;\n      if (!mirrorMsp) throw new InternalError(`No mirror MSP could be found`);\n      let msps = this.getEndorsingOrganizations(ctx) || [];\n      msps = Array.isArray(msps) ? msps : [msps];\n      const merged = [...new Set([...msps, mirrorMsp])];\n      ctx.accumulate({\n        endorsingOrgs: merged,\n        endorsingOrganizations: merged,\n        legacy: true,\n      });\n    }\n\n    return {\n      record: split.model,\n      model: split.model,\n      id: model[Model.pk(model.constructor as Constructor<M>)] as string,\n      transient: split.transient,\n      privates: split.privates,\n      shared: split.shared,\n    };\n  }\n\n  override revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    transient?: Record<string, any>,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): M {\n    const { log, ctx } = this.logCtx(args, this.revert);\n    if (\n      transient &&\n      this.shouldRebuildWithTransient(\n        ctx,\n        ctx.getOrUndefined(\"operation\") as string | undefined\n      )\n    ) {\n      log.verbose(\n        `re-adding transient properties: ${Object.keys(transient).join(\", \")}`\n      );\n      Object.entries(transient as Record<string, any>)\n        .filter(([, v]) => typeof v !== \"undefined\")\n        .forEach(([key, val]) => {\n          if (key in obj && (obj as any)[key] !== undefined)\n            log.warn(\n              `overwriting existing ${key}. if this is not a default value, this may pose a problem`\n            );\n          (obj as M)[key as keyof M] = val;\n        });\n    }\n\n    const result = new (clazz as Constructor<M>)(obj);\n\n    return result;\n  }\n\n  private shouldRebuildWithTransient(\n    ctx: Context<FabricClientFlags>,\n    operation?: string\n  ): boolean {\n    if (!ctx) return false;\n    if (ctx.getOrUndefined(\"rebuildWithTransient\")) return true;\n    const childRebuild =\n      typeof (ctx as any).getFromChildren === \"function\"\n        ? (ctx as any).getFromChildren(\"rebuildWithTransient\")\n        : undefined;\n    if (childRebuild) return true;\n    const resolvedOp = this.resolveOperation(ctx, operation);\n    if (!resolvedOp) return false;\n    const op = resolvedOp.toString().toLowerCase();\n    return (\n      op.includes(\"read\") ||\n      op.includes(\"find\") ||\n      op.includes(\"query\") ||\n      op.includes(\"statement\") ||\n      op.includes(\"page\")\n    );\n  }\n\n  private resolveOperation(\n    ctx: Context<FabricClientFlags>,\n    operation?: string\n  ): string | undefined {\n    if (operation) return operation;\n    if (typeof (ctx as any).getFromChildren === \"function\") {\n      return (ctx as any).getFromChildren(\"operation\");\n    }\n    return undefined;\n  }\n\n  private shouldRefreshAfterWrite<M extends Model>(\n    clazz: Constructor<M>,\n    ctx: Context<FabricClientFlags>,\n    hasTransient: boolean,\n    id?: PrimaryKeyType\n  ): boolean {\n    if (!hasTransient) return false;\n    const pk = Model.pk(clazz);\n    const composed = Model.composed(clazz, pk);\n    const generated = Model.generated(clazz, pk);\n    const hasId = id !== undefined && id !== null;\n    if (!hasId && composed) return true;\n    if (!hasId && generated) {\n      ctx.logger.warn(\n        `Cannot refresh record with private generated primary key`\n      );\n      return false;\n    }\n    return hasId;\n  }\n\n  private getEndorsingOrganizations(\n    ctx: Context<FabricClientFlags>\n  ): string[] | undefined {\n    const direct =\n      ctx.getOrUndefined(\"endorsingOrgs\") ||\n      (ctx.getOrUndefined(\"endorsingOrgs\") as string[] | undefined);\n    if (direct && direct.length) return direct;\n    return (\n      (ctx.getFromChildren(\"endorsingOrgs\") as string[] | undefined) ||\n      (ctx.getFromChildren(\"endorsingOrgs\") as string[] | undefined)\n    );\n  }\n\n  private shouldForceGatewayHydration(\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ctx: Context<FabricClientFlags>\n  ): boolean {\n    return !!this.config.allowGatewayOverride;\n  }\n\n  /**\n   * @description Creates a single record\n   * @summary Submits a transaction to create a record in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @param {Record<string, any>} model - The record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Record<string, any>>} Promise resolving to the created record\n   */\n  @debug()\n  @final()\n  override async create<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    model: Record<string, any>,\n    transient: Record<string, any> = {},\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const ctxArgs = [...(args as unknown as any[])];\n    const { log, ctx } = this.logCtx(\n      ctxArgs as ContextualArgs<Context<FabricClientFlags>>,\n      this.create\n    );\n    const tableName = Model.tableName(clazz);\n    log.verbose(`adding entry to ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const hasTransient = transient && Object.keys(transient).length > 0;\n    const needsFullPayload =\n      hasTransient || this.shouldForceGatewayHydration(ctx);\n    const transientPayload = hasTransient ? { [tableName]: transient } : {};\n    const result = await this.submitTransaction(\n      ctx,\n      OperationKeys.CREATE,\n      [this.serializer.serialize(model, clazz.name)],\n      transientPayload as any,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n    const deserialized = this.serializer.deserialize(this.decode(result));\n    if (this.shouldRefreshAfterWrite(clazz, ctx, needsFullPayload, id)) {\n      return this.read(\n        clazz,\n        extractIds(\n          clazz,\n          Model.merge(\n            Object.assign({}, model, transient || {}),\n            deserialized,\n            clazz\n          ),\n          id\n        ),\n        ctx\n      );\n    }\n    return deserialized;\n  }\n\n  @debug()\n  @final()\n  async healthcheck<M extends Model>(\n    clazz: Constructor<M>,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const { log, ctx } = this.logCtx(args, this.healthcheck);\n    const tableName = Model.tableName(clazz);\n\n    log.verbose(`reading entry from ${tableName} table`);\n    const result = await this.evaluateTransaction(\n      ctx,\n      \"healthcheck\",\n      [],\n      undefined,\n      undefined,\n      clazz.name\n    );\n    return JSON.parse(this.decode(result));\n  }\n\n  /**\n   * @description Reads a single record\n   * @summary Evaluates a transaction to read a record from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @return {Promise<Record<string, any>>} Promise resolving to the retrieved record\n   */\n  @debug()\n  @final()\n  async read<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const { log, ctx } = this.logCtx(args, this.read);\n    const tableName = Model.tableName(clazz);\n\n    log.verbose(`reading entry from ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const result = await this.evaluateTransaction(\n      ctx,\n      OperationKeys.READ,\n      [id.toString()],\n      undefined,\n      undefined,\n      clazz.name\n    );\n    return this.serializer.deserialize(this.decode(result));\n  }\n\n  updatePrefix<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    model: Record<string, any>,\n    ...args: MaybeContextualArg<Context<FabricClientFlags>>\n  ) {\n    const tableName = Model.tableName(clazz);\n    const { ctxArgs } = this.logCtx(args, this.updatePrefix);\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    // record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    Object.assign(record, model);\n    return [clazz, id, record, ...ctxArgs];\n  }\n\n  /**\n   * @description Updates a single record\n   * @summary Submits a transaction to update a record in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @param {Record<string, any>} model - The updated record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Record<string, any>>} Promise resolving to the updated record\n   */\n  @debug()\n  @final()\n  async update<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    model: Record<string, any>,\n    transient: Record<string, any> = {},\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const ctxArgs = [...(args as unknown as any[])];\n    const { log, ctx } = this.logCtx(\n      ctxArgs as ContextualArgs<Context<FabricClientFlags>>,\n      this.update\n    );\n    log.info(`CLIENT UPDATE class : ${typeof clazz}`);\n    const tableName = Model.tableName(clazz);\n    log.verbose(`updating entry to ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const hasTransient = transient && Object.keys(transient).length > 0;\n    const needsFullPayload =\n      hasTransient || this.shouldForceGatewayHydration(ctx);\n    const transientPayload = hasTransient ? { [tableName]: transient } : {};\n    const result = await this.submitTransaction(\n      ctx,\n      OperationKeys.UPDATE,\n      [this.serializer.serialize(model, clazz.name || clazz)], // TODO should be receving class but is receiving string\n      transientPayload as any,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n    const deserialized = this.serializer.deserialize(this.decode(result));\n    if (this.shouldRefreshAfterWrite(clazz, ctx, needsFullPayload, id)) {\n      return this.read(\n        clazz,\n        extractIds(\n          clazz,\n          Model.merge(\n            Object.assign({}, model, transient || {}),\n            deserialized,\n            clazz\n          ),\n          id\n        ),\n        ctx\n      );\n    }\n    return deserialized;\n  }\n\n  /**\n   * @description Deletes a single record\n   * @summary Submits a transaction to delete a record from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier to delete\n   * @return {Promise<Record<string, any>>} Promise resolving to the deleted record\n   */\n  @debug()\n  @final()\n  override async delete<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const { log, ctx } = this.logCtx(args, this.delete);\n    const tableName = Model.tableName(clazz);\n    const needsFullPayload =\n      Model.isTransient(clazz) || this.shouldForceGatewayHydration(ctx);\n    let result: any;\n    const shouldHydrate = this.shouldRefreshAfterWrite(\n      clazz,\n      ctx,\n      needsFullPayload,\n      id\n    );\n    if (shouldHydrate) {\n      result = await this.read(clazz, id, ctx);\n    }\n\n    log.verbose(`deleting entry from ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const res = await this.submitTransaction(\n      ctx,\n      OperationKeys.DELETE,\n      [id.toString()],\n      undefined,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n    return shouldHydrate\n      ? result\n      : this.serializer.deserialize(this.decode(res));\n  }\n\n  /**\n   * @description Executes a raw query against the Fabric ledger\n   * @summary Evaluates a transaction to perform a query using Mango Query syntax\n   * @template V - The return type\n   * @param {MangoQuery} rawInput - The Mango Query to execute\n   * @param {boolean} process - Whether to process the result\n   * @return {Promise<V>} Promise resolving to the query result\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant FabricAdapter\n   *   participant Contract\n   *   participant Chaincode\n   *\n   *   Client->>FabricAdapter: raw(rawInput, process)\n   *   FabricAdapter->>FabricAdapter: JSON.stringify(rawInput)\n   *   FabricAdapter->>FabricAdapter: evaluateTransaction(\"query\", [input])\n   *   FabricAdapter->>Contract: evaluate(\"query\", proposalOptions)\n   *   Contract->>Chaincode: invoke\n   *   Chaincode-->>Contract: response\n   *   Contract-->>FabricAdapter: result\n   *   FabricAdapter->>FabricAdapter: JSON.parse(decode(result))\n   *   FabricAdapter->>FabricAdapter: Process result based on type\n   *   FabricAdapter-->>Client: processed result\n   */\n  @debug()\n  async raw<V, D extends boolean>(\n    rawInput: MangoQuery,\n    docsOnly: D = true as D,\n    clazz: ModelConstructor<any>,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<V> {\n    const { log, ctx } = this.logCtx(args, this.raw);\n    const tableName = clazz.name;\n    log.info(`Performing raw statement on table ${Model.tableName(clazz)}`);\n    let transactionResult: any;\n    try {\n      transactionResult = await this.evaluateTransaction(\n        ctx,\n        \"raw\",\n        [JSON.stringify(rawInput), docsOnly],\n        undefined,\n        undefined,\n        tableName\n      );\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n    let result: any;\n    try {\n      result = JSON.parse(this.decode(transactionResult));\n    } catch (e: any) {\n      throw new SerializationError(`Failed to process result: ${e}`);\n    }\n\n    const parseRecord = (record: Record<any, any>) => {\n      if (Model.isModel(record)) return Model.build(record);\n      return record;\n    };\n\n    if (Array.isArray(result)) {\n      if (!result.length) return result as V;\n      const el = result[0];\n      if (Model.isModel(el))\n        // if the first one is a model, all are models\n        return result.map((el) => Model.build(el)) as V;\n      return result as V;\n    }\n\n    return parseRecord(result as any) as V;\n  }\n\n  /**\n   * @description Executes a CouchDB view query against the Fabric chaincode\n   * @summary Evaluates a transaction to query a design document view\n   * @template R - The view response type\n   * @param {string} ddoc - Design document name\n   * @param {string} viewName - View name\n   * @param {Record<string, any>} options - View query options\n   * @param {...ContextualArgs<Context<FabricClientFlags>>} args - Optional contextual arguments\n   * @return {Promise<ViewResponse<R>>} The view response\n   */\n  @debug()\n  async view<R>(\n    ddoc: string,\n    viewName: string,\n    options: Record<string, any>,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<ViewResponse<R>> {\n    const { log, ctx } = this.logCtx(args, this.view);\n    log.info(`Querying view ${ddoc}/${viewName}`);\n    let transactionResult: any;\n    try {\n      transactionResult = await this.evaluateTransaction(\n        ctx,\n        \"view\",\n        [ddoc, viewName, JSON.stringify(options)],\n        undefined,\n        undefined,\n        undefined\n      );\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n    let result: ViewResponse<R>;\n    try {\n      result = JSON.parse(this.decode(transactionResult));\n    } catch (e: any) {\n      throw new SerializationError(`Failed to process view result: ${e}`);\n    }\n    return result;\n  }\n\n  /**\n   * @description Gets or creates a gRPC client for the Fabric peer\n   * @summary Returns a cached client or creates a new one if none exists\n   * @return {Promise<Client>} Promise resolving to the gRPC client\n   */\n  override getClient(): Client {\n    if (!this._client)\n      this._client = FabricClientAdapter.getClient(this.config);\n    return this._client;\n  }\n\n  /**\n   * @description Gets a Gateway instance for the Fabric network\n   * @summary Creates a new Gateway instance using the current client\n   * @return {Promise<Gateway>} Promise resolving to the Gateway instance\n   */\n  protected async Gateway(ctx: Context<FabricClientFlags>): Promise<Gateway> {\n    return FabricClientAdapter.getGateway(ctx, this.config, this.client);\n  }\n\n  private getContractName(className?: string) {\n    if (!className) return undefined;\n    return `${className}Contract`;\n  }\n\n  /**\n   * @description Gets a Contract instance for the Fabric chaincode\n   * @summary Creates a new Contract instance using the current Gateway\n   * @return {Promise<Contrakt>} Promise resolving to the Contract instance\n   */\n  protected async Contract(\n    ctx: Context<FabricClientFlags>,\n    contractName?: string\n  ): Promise<Contrakt> {\n    return FabricClientAdapter.getContract(\n      await this.Gateway(ctx),\n      this.config,\n      contractName\n    );\n  }\n\n  /**\n   * @description Executes a transaction on the Fabric network\n   * @summary Submits or evaluates a transaction on the Fabric chaincode\n   * @param {string} api - The chaincode function to call\n   * @param {boolean} submit - Whether to submit (true) or evaluate (false) the transaction\n   * @param {any[]} [args] - Arguments to pass to the chaincode function\n   * @param {Record<string, string>} [transientData] - Transient data for the transaction\n   * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction\n   * @return {Promise<Uint8Array>} Promise resolving to the transaction result\n   * @mermaid\n   * sequenceDiagram\n   *   participant FabricAdapter\n   *   participant Gateway\n   *   participant Contract\n   *   participant Chaincode\n   *\n   *   FabricAdapter->>Gateway: connect()\n   *   FabricAdapter->>Contract: getContract()\n   *   alt submit transaction\n   *     FabricAdapter->>Contract: submit(api, proposalOptions)\n   *   else evaluate transaction\n   *     FabricAdapter->>Contract: evaluate(api, proposalOptions)\n   *   end\n   *   Contract->>Chaincode: invoke\n   *   Chaincode-->>Contract: response\n   *   Contract-->>FabricAdapter: result\n   *   FabricAdapter->>Gateway: close()\n   */\n  protected async transaction(\n    ctx: Context<FabricClientFlags>,\n    api: string,\n    submit = true,\n    args?: any[],\n    transientData: Record<string, string> = {},\n    endorsingOrganizations?: string[],\n    className?: string\n  ): Promise<Uint8Array> {\n    const log = this.log.for(this.transaction);\n    const gateway = await this.Gateway(ctx);\n    try {\n      const contract = await this.Contract(\n        ctx,\n        this.getContractName(className)\n      );\n      log.verbose(\n        `${submit ? \"Submit\" : \"Evaluate\"}ting transaction ${this.getContractName(className) || this.config.contractName}.${api}`\n      );\n      log.debug(`args: ${args?.map((a) => a.toString()).join(\"\\n\") || \"none\"}`);\n      const method = submit ? contract.submit : contract.evaluate;\n\n      endorsingOrganizations = endorsingOrganizations?.length\n        ? endorsingOrganizations\n        : undefined;\n      const proposalOptions: ProposalOptions = {\n        arguments: args || [],\n        transientData: Object.entries(transientData).reduce(\n          (acc, [key, val]) => {\n            acc[key] = JSON.stringify(val);\n            return acc;\n          },\n          {} as typeof transientData\n        ),\n        endorsingOrganizations: ctx.getOrUndefined(\"allowManualEndorsingOrgs\")\n          ? endorsingOrganizations || undefined\n          : undefined, // mspId list\n      };\n\n      return await method.call(contract, api, proposalOptions);\n    } catch (e: any) {\n      throw this.parseError(e);\n    } finally {\n      this.log.debug(`Closing ${this.config.mspId} gateway connection`);\n      gateway.close();\n    }\n  }\n\n  private shouldUseLegacyGateway(ctx: Context<FabricClientFlags>): boolean {\n    return !!ctx.getOrUndefined(\"legacy\") && !!this.config.allowGatewayOverride;\n  }\n\n  private prepareLegacyArgs(args?: any[]): string[] {\n    return (args || []).map((arg) =>\n      typeof arg === \"string\" ? arg : JSON.stringify(arg)\n    );\n  }\n\n  private buildLegacyTransient(\n    transientData?: Record<string, string>\n  ): Record<string, Buffer> | undefined {\n    if (!transientData) return undefined;\n    const entries = Object.entries(transientData);\n    if (!entries.length) return undefined;\n    const map: Record<string, Buffer> = {};\n    for (const [key, value] of entries) {\n      map[key] = Buffer.from(JSON.stringify(value));\n    }\n    return map;\n  }\n\n  private resolveLegacyMspCount(): number {\n    const configured = this.config.legacyMspCount ?? 1;\n    const parsed = Number(configured);\n    if (!Number.isFinite(parsed) || parsed < 1) return 1;\n    return Math.floor(parsed);\n  }\n\n  private pickLegacyCandidates(\n    candidates: MspDetails[],\n    limit: number\n  ): MspDetails[] {\n    if (!candidates.length || limit <= 0) return [];\n    const available = [...candidates];\n    const target = Math.min(limit, available.length);\n    const picked: MspDetails[] = [];\n    while (picked.length < target && available.length) {\n      const idx = Math.floor(Math.random() * available.length);\n      const [selection] = available.splice(idx, 1);\n      if (selection) {\n        picked.push(selection);\n      }\n    }\n    return picked;\n  }\n\n  private buildLegacyPeerConfigs(\n    ctx: Context<FabricClientFlags>\n  ): LegacyPeerTarget[] {\n    const peers: LegacyPeerTarget[] = [\n      {\n        mspId: this.config.mspId,\n        peerEndpoint: this.config.peerEndpoint,\n        peerHostAlias: this.config.peerHostAlias,\n        tlsCert: this.config.tlsCert,\n      },\n    ];\n\n    let endorsingOrgs = this.getEndorsingOrganizations(ctx) || [];\n    endorsingOrgs = Array.isArray(endorsingOrgs)\n      ? endorsingOrgs\n      : [endorsingOrgs];\n    const endorsers =\n      endorsingOrgs.filter((org): org is string => Boolean(org)) || [];\n    const extras = endorsers.filter((org) => org !== this.config.mspId);\n    if (!extras.length) return peers;\n\n    const map = this.config.mspMap;\n    const legacyCount = this.resolveLegacyMspCount();\n    for (const msp of extras) {\n      const candidates = map?.[msp];\n      if (!candidates?.length) {\n        throw new UnsupportedError(\n          `No peer mapping available for MSP ${msp}. Provide it via config.mspMap`\n        );\n      }\n      const selections = this.pickLegacyCandidates(candidates, legacyCount);\n      if (!selections.length) {\n        throw new UnsupportedError(\n          `No valid peer mapping available for MSP ${msp}. Provide it via config.mspMap`\n        );\n      }\n      for (const choice of selections) {\n        if (!choice.endpoint) {\n          throw new UnsupportedError(\n            `Invalid peer mapping for MSP ${msp}: missing endpoint`\n          );\n        }\n        peers.push({\n          mspId: msp,\n          peerEndpoint: choice.endpoint,\n          peerHostAlias: choice.alias,\n          tlsCert: choice.tlsCert || this.config.tlsCert,\n        });\n      }\n    }\n\n    return peers;\n  }\n\n  private async submitLegacyWithExplicitEndorsers(\n    ctx: Context<FabricClientFlags>,\n    fcn: string,\n    args: string[],\n    transientMap: Record<string, Buffer> | undefined,\n    peerConfigs: LegacyPeerTarget[],\n    className?: string\n  ): Promise<Uint8Array> {\n    const log = this.log.for(this.submitLegacyWithExplicitEndorsers);\n    const peers = this.normalizeLegacyPeers(peerConfigs);\n    const identityMaterial = await this.resolveLegacyIdentityMaterial();\n    const wallet = await Wallets.newInMemoryWallet();\n    const identityLabel = `${this.config.mspId}-legacy`;\n    await wallet.put(identityLabel, {\n      credentials: {\n        certificate: identityMaterial.certificate,\n        privateKey: identityMaterial.privateKey,\n      },\n      mspId: this.config.mspId,\n      type: \"X.509\",\n    } as Identity);\n\n    const connectionProfile = await this.buildLegacyConnectionProfile(peers);\n    const gateway = new LegacyGateway();\n\n    try {\n      await gateway.connect(connectionProfile, {\n        identity: identityLabel,\n        wallet,\n        discovery: {\n          enabled: true,\n          asLocalhost: this.shouldTreatPeersAsLocalhost(peers),\n        },\n        tlsInfo: {\n          certificate: identityMaterial.certificate,\n          key: identityMaterial.privateKey,\n        },\n      });\n\n      const network = await gateway.getNetwork(this.config.channel);\n      const contract = network.getContract(\n        this.config.chaincodeName,\n        this.getContractName(className)\n      );\n      const transaction = contract.createTransaction(fcn);\n\n      if (transientMap) {\n        transaction.setTransient(transientMap);\n      }\n\n      const endorsers = peers\n        .map((peer) => network.getChannel().getEndorser(peer.name))\n        .filter((endorser): endorser is Endorser => Boolean(endorser));\n      if (endorsers.length) {\n        transaction.setEndorsingPeers(endorsers);\n      }\n\n      log.verbose(\n        `Legacy submitting ${this.getContractName(className) || this.config.contractName}.${fcn} via peers ${peers.map((p) => p.peerEndpoint).join(\", \")}`\n      );\n\n      const result = await transaction.submit(...args);\n      return Uint8Array.from(result);\n    } catch (e: any) {\n      throw this.parseError(e);\n    } finally {\n      gateway.disconnect();\n    }\n  }\n\n  private normalizeLegacyPeers(\n    peers: LegacyPeerTarget[]\n  ): LegacyPeerWithName[] {\n    const deduped = new Map<string, LegacyPeerWithName>();\n    const addPeer = (peer: LegacyPeerTarget) => {\n      const key = `${peer.peerEndpoint}|${peer.peerHostAlias || \"\"}`;\n      if (deduped.has(key)) return;\n      const name = `peer-${peer.mspId}-${deduped.size}`;\n      deduped.set(key, {\n        ...peer,\n        name,\n      });\n    };\n\n    peers.forEach(addPeer);\n    addPeer({\n      mspId: this.config.mspId,\n      peerEndpoint: this.config.peerEndpoint,\n      peerHostAlias: this.config.peerHostAlias,\n    });\n\n    return Array.from(deduped.values());\n  }\n\n  private async resolveLegacyIdentityMaterial(): Promise<{\n    certificate: string;\n    privateKey: string;\n  }> {\n    const certificate = await this.readPemInput(\n      this.config.certCertOrDirectoryPath\n    );\n    const privateKey = await this.readPemInput(\n      this.config.keyCertOrDirectoryPath\n    );\n    return { certificate, privateKey };\n  }\n\n  private async buildLegacyConnectionProfile(peers: LegacyPeerWithName[]) {\n    const peerEntries: Record<string, any> = {};\n    const channelPeers: Record<string, any> = {};\n    const orgs: Record<string, any> = {};\n    for (const peer of peers) {\n      const tlsPem = await this.readPemInput(\n        peer.tlsCert || this.config.tlsCert\n      );\n      const hostname =\n        peer.peerHostAlias || this.extractHost(peer.peerEndpoint);\n      peerEntries[peer.name] = {\n        url: this.ensureGrpcUrl(peer.peerEndpoint),\n        tlsCACerts: { pem: tlsPem },\n        grpcOptions: {\n          \"ssl-target-name-override\": hostname,\n          hostnameOverride: hostname,\n        },\n      };\n      channelPeers[peer.name] = {\n        endorsingPeer: true,\n        chaincodeQuery: true,\n        ledgerQuery: true,\n        eventSource: true,\n      };\n      orgs[peer.mspId] = orgs[peer.mspId] || {\n        mspid: peer.mspId,\n        peers: [],\n      };\n      orgs[peer.mspId].peers.push(peer.name);\n    }\n\n    return {\n      name: \"legacy-manual\",\n      version: \"1.0.0\",\n      client: {\n        organization: this.config.mspId,\n      },\n      organizations: orgs,\n      peers: peerEntries,\n      orderers: {},\n      channels: {\n        [this.config.channel]: {\n          peers: channelPeers,\n        },\n      },\n    };\n  }\n\n  private shouldTreatPeersAsLocalhost(peers: LegacyPeerWithName[]): boolean {\n    return peers.every((peer) => this.isLocalEndpoint(peer.peerEndpoint));\n  }\n\n  private isLocalEndpoint(endpoint: string): boolean {\n    const host = this.extractHost(endpoint).toLowerCase();\n    return host === \"localhost\" || host === \"127.0.0.1\";\n  }\n\n  private extractHost(endpoint: string): string {\n    const sanitized = endpoint.replace(/^grpcs?:\\/\\//, \"\");\n    return sanitized.split(\":\")[0];\n  }\n\n  private ensureGrpcUrl(endpoint: string): string {\n    if (/^grpcs?:\\/\\//i.test(endpoint)) return endpoint;\n    return `grpcs://${endpoint}`;\n  }\n\n  private async readPemInput(source?: string | Buffer): Promise<string> {\n    if (!source) throw new InternalError(\"Missing certificate or key material\");\n    if (Buffer.isBuffer(source)) return source.toString(\"utf8\");\n    const trimmed = source.trim();\n    if (/-----BEGIN [A-Z ]+-----/.test(trimmed)) return trimmed;\n    const stats = await fs.promises.stat(source).catch(() => undefined);\n    if (stats?.isDirectory()) {\n      return await getFirstDirFileNameContent(source);\n    }\n    return (await readFsFile(source)).toString();\n  }\n\n  /**\n   * @description Parses an error into a BaseError\n   * @summary Converts any error into a standardized BaseError\n   * @param {Error | string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error\n   */\n  override parseError<E extends BaseError>(err: Error | string): E {\n    return FabricClientAdapter.parseError<E>(err);\n  }\n\n  /**\n   * @description Submits a transaction to the Fabric network\n   * @summary Executes a transaction that modifies the ledger state\n   * @param {string} api - The chaincode function to call\n   * @param {any[]} [args] - Arguments to pass to the chaincode function\n   * @param {Record<string, string>} [transientData] - Transient data for the transaction\n   * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction\n   * @return {Promise<Uint8Array>} Promise resolving to the transaction result\n   */\n  async submitTransaction(\n    ctx: Context<FabricClientFlags>,\n    api: string,\n    args?: any[],\n    transientData?: Record<string, string>,\n    endorsingOrganizations?: Array<string>,\n    className?: string\n  ): Promise<Uint8Array> {\n    if (this.shouldUseLegacyGateway(ctx)) {\n      const legacyArgs = this.prepareLegacyArgs(args);\n      const transientMap = this.buildLegacyTransient(transientData);\n      const peerConfigs = this.buildLegacyPeerConfigs(ctx);\n      return this.submitLegacyWithExplicitEndorsers(\n        ctx,\n        api,\n        legacyArgs,\n        transientMap,\n        peerConfigs,\n        className\n      );\n    }\n    return this.transaction(\n      ctx,\n      api,\n      true,\n      args,\n      transientData,\n      endorsingOrganizations,\n      className\n    );\n  }\n\n  /**\n   * @description Evaluates a transaction on the Fabric network\n   * @summary Executes a transaction that does not modify the ledger state\n   * @param {string} api - The chaincode function to call\n   * @param {any[]} [args] - Arguments to pass to the chaincode function\n   * @param {Record<string, string>} [transientData] - Transient data for the transaction\n   * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction\n   * @return {Promise<Uint8Array>} Promise resolving to the transaction result\n   */\n  async evaluateTransaction(\n    ctx: Context<FabricClientFlags>,\n    api: string,\n    args?: any[],\n    transientData?: Record<string, string>,\n    endorsingOrganizations?: Array<string>,\n    className?: string\n  ): Promise<Uint8Array> {\n    return this.transaction(\n      ctx,\n      api,\n      false,\n      args,\n      transientData,\n      endorsingOrganizations,\n      className\n    );\n  }\n\n  /**\n   * @description Shuts down the connection to the Fabric network\n   * @summary Closes the active dispatch (which in turn closes any gateway\n   * event subscription) via the base class, then closes the gRPC client.\n   * Works correctly regardless of whether `syntheticEvents` is enabled.\n   * @return {Promise<void>} Promise that resolves when all connections are closed\n   */\n  override async shutdown(...args: MaybeContextualArg<Context<FabricClientFlags>>): Promise<void> {\n    // Base class handles dispatch.close() internally.\n    await super.shutdown(...args);\n    if (this.client) {\n      this.log.verbose(`Closing ${this.config.mspId} gateway client`);\n      this.client.close();\n    }\n  }\n\n  /**\n   * @description Gets a Contract instance from a Gateway\n   * @summary Retrieves a chaincode contract from the specified network\n   * @param {Gateway} gateway - The Gateway instance\n   * @param {PeerConfig} config - The peer configuration\n   * @return {Contrakt} The Contract instance\n   */\n  static getContract(\n    gateway: Gateway,\n    config: PeerConfig,\n    contractName?: string\n  ): Contrakt {\n    const log = this.log.for(this.getContract);\n    const network = this.getNetwork(gateway, config.channel);\n    let contract: Contrakt;\n    try {\n      log.debug(\n        `Retrieving chaincode ${config.chaincodeName} contract ${contractName || config.contractName} from network ${config.channel}`\n      );\n      contractName = contractName ? contractName : config.contractName;\n      contract = network.getContract(config.chaincodeName, contractName);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return contract;\n  }\n\n  /**\n   * @description Gets a Network instance from a Gateway\n   * @summary Connects to a specific channel on the Fabric network\n   * @param {Gateway} gateway - The Gateway instance\n   * @param {string} channelName - The name of the channel to connect to\n   * @return {Network} The Network instance\n   */\n  static getNetwork(gateway: Gateway, channelName: string): Network {\n    const log = Logging.for(this.getNetwork);\n    let network: Network;\n    try {\n      log.debug(`Connecting to channel ${channelName}`);\n      network = gateway.getNetwork(channelName);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    return network;\n  }\n\n  /**\n   * @description Gets a Gateway instance for connecting to the Fabric network\n   * @summary Creates a Gateway using the provided configuration and client\n   * @param {PeerConfig} config - The peer configuration\n   * @param {Client} [client] - Optional gRPC client, will be created if not provided\n   * @return {Promise<Gateway>} Promise resolving to the Gateway instance\n   */\n  static async getGateway(\n    ctx: Context<FabricClientFlags>,\n    config: PeerConfig,\n    client?: Client\n  ) {\n    return (await this.getConnection(\n      client || (await this.getClient(config)),\n      config,\n      ctx\n    )) as Gateway;\n  }\n\n  /**\n   * @description Creates a gRPC client for connecting to a Fabric peer\n   * @summary Initializes a client with TLS credentials for secure communication\n   * @param {PeerConfig} config - The peer configuration\n   * @return {Client} Promise resolving to the gRPC client\n   */\n  static getClient(config: PeerConfig): Client {\n    const log = this.log.for(this.getClient);\n    log.debug(`generating TLS credentials for msp ${config.mspId}`);\n    let pathOrCert: string | Buffer = config.tlsCert as string | Buffer;\n\n    if (typeof pathOrCert === \"string\") {\n      if (\n        pathOrCert.match(\n          /-----BEGIN (CERTIFICATE|KEY|PRIVATE KEY)-----.+?-----END \\1-----$/gms\n        )\n      ) {\n        pathOrCert = Buffer.from(pathOrCert, \"utf8\");\n      } else {\n        try {\n          pathOrCert = Buffer.from(fs.readFileSync(pathOrCert, \"utf8\"));\n        } catch (e: unknown) {\n          throw new InternalError(\n            `Failed to read the tls certificate from ${pathOrCert}: ${e}`\n          );\n        }\n      }\n    }\n\n    const tlsCredentials = grpc.credentials.createSsl(pathOrCert);\n    log.debug(`generating Gateway Client for url ${config.peerEndpoint}`);\n    return new Client(config.peerEndpoint, tlsCredentials, {\n      \"grpc.max_receive_message_length\": (config.sizeLimit || 15) * 1024 * 1024,\n      \"grpc.max_send_message_length\": (config.sizeLimit || 15) * 1024 * 1024,\n    });\n  }\n\n  /**\n   * @description Establishes a connection to the Fabric network\n   * @summary Creates a Gateway connection with identity and signer\n   * @param {Client} client - The gRPC client\n   * @param {PeerConfig} config - The peer configuration\n   * @return {Promise<Gateway>} Promise resolving to the connected Gateway\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant FabricAdapter\n   *   participant Identity\n   *   participant Signer\n   *   participant Gateway\n   *\n   *   Caller->>FabricAdapter: getConnection(client, config)\n   *   FabricAdapter->>Identity: getIdentity(mspId, certDirectoryPath)\n   *   Identity-->>FabricAdapter: identity\n   *   FabricAdapter->>Signer: getSigner(keyDirectoryPath)\n   *   Signer-->>FabricAdapter: signer\n   *   FabricAdapter->>FabricAdapter: Create ConnectOptions\n   *   FabricAdapter->>Gateway: connect(options)\n   *   Gateway-->>FabricAdapter: gateway\n   *   FabricAdapter-->>Caller: gateway\n   */\n  static async getConnection(\n    client: Client,\n    config: PeerConfig,\n    ctx: Context<FabricClientFlags>\n  ) {\n    const log = Logging.for(this.getConnection);\n    log.debug(\n      `Retrieving Peer Identity for ${config.mspId} under ${config.certCertOrDirectoryPath}`\n    );\n    const identity = await getIdentity(\n      config.mspId,\n      config.certCertOrDirectoryPath as any\n    );\n    try {\n      log.debug(\n        `preparing transaction signer for ${CryptoUtils.fabricIdFromCertificate(identity.credentials.toString())}`\n      );\n    } catch (e: unknown) {\n      log.error(`Failed to extract Fabric ID from certificate`, e as Error);\n    }\n\n    let signer: Signer;\n    const close = () => {};\n    if (!config.hsm) {\n      signer = await getSigner(config.keyCertOrDirectoryPath as any);\n    } else {\n      // const hsm = new HSMSignerFactoryCustom(config.hsm.library);\n      // const identifier = hsm.getSKIFromCertificatePath(\n      //   config.certCertOrDirectoryPath as any\n      // );\n      // const pkcs11Signer = hsm.newSigner({\n      //   label: config.hsm.tokenLabel as string,\n      //   pin: String(config.hsm.pin) as string,\n      //   identifier: identifier,\n      //   // userType: 1 /*CKU_USER */,\n      // });\n      // signer = pkcs11Signer.signer;\n      // close = pkcs11Signer.close;\n      throw new UnsupportedError(\"HSM NOT IMPLEMENTED\");\n    }\n\n    const options = {\n      client,\n      identity: identity,\n      signer: signer,\n      // Default timeouts for different gRPC calls\n      evaluateOptions: () => {\n        return { deadline: Date.now() + 1000 * ctx.get(\"evaluateTimeout\") }; // defaults to 5 seconds\n      },\n      endorseOptions: () => {\n        return { deadline: Date.now() + 1000 * ctx.get(\"endorseTimeout\") }; // defaults to 15 seconds\n      },\n      submitOptions: () => {\n        return { deadline: Date.now() + 1000 * ctx.get(\"submitTimeout\") }; // defaults to 5 seconds\n      },\n      commitStatusOptions: () => {\n        return { deadline: Date.now() + 1000 * ctx.get(\"commitTimeout\") }; // defaults to 1 minute\n      },\n    } as ConnectOptions;\n\n    log.debug(`Connecting to ${config.mspId}`);\n    const gateway = connect(options);\n\n    // TODO: replace?\n    if (config.hsm) {\n      gateway.close = new Proxy(gateway.close, {\n        apply(target: () => void, thisArg: any, argArray: any[]): any {\n          Reflect.apply(target, thisArg, argArray);\n          close();\n        },\n      });\n    }\n\n    return gateway;\n  }\n\n  /**\n   * @description Creates a new Dispatch instance for the Fabric client.\n   * @summary This function is responsible for creating a new FabricClientDispatch instance that can be used to interact with the Fabric network.\n   * @returns {Dispatch} A new Dispatch instance configured for the Fabric client.\n   * @remarks The Dispatch instance is used to encapsulate the logic for interacting with the Fabric network, such as submitting transactions or querying data.\n   * @example\n   * const fabricDispatch = fabricClientAdapter.Dispatch();\n   * fabricDispatch.submitTransaction('createProduct', { name: 'Product A', price: 100 });\n   */\n  override Dispatch(): FabricClientDispatch {\n    return new FabricClientAdapter[\"_baseDispatch\"](this.client);\n  }\n\n  /**\n   * @description Parses an error into a BaseError\n   * @summary Converts any error into a standardized BaseError using the parent class implementation\n   * @param {Error | string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error\n   */\n  protected static parseError<E extends BaseError>(\n    err: Error | string | GatewayError\n  ): E {\n    // if (\n    //   MISSING_PRIVATE_DATA_REGEX.test(\n    //     typeof err === \"string\" ? err : err.message\n    //   )\n    // )\n    //   return new UnauthorizedPrivateDataAccess(err) as E;\n\n    let msg = typeof err === \"string\" ? err : err.message;\n    if (err instanceof GatewayError && err.details.length && err.code === 10) {\n      msg = `${err.details[0].message}`;\n    }\n\n    if (\n      err instanceof EndorseError &&\n      err.details.length &&\n      err.code === 10 &&\n      err.details[0].message?.includes(UnsupportedError.name)\n    ) {\n      msg = `${err.details[0].message}`;\n    }\n\n    if (msg.includes(\"MVCC_READ_CONFLICT\"))\n      return new MvccReadConflictError(err) as E;\n\n    if (msg.includes(\"DEADLINE_EXCEEDED\"))\n      return new TransactionTimeoutError(err) as E;\n\n    if (msg.includes(\"ENDORSEMENT_POLICY_FAILURE\"))\n      return new EndorsementPolicyError(err) as E;\n\n    if (msg.includes(\"PHANTOM_READ_CONFLICT\"))\n      return new PhantomReadConflictError(err) as E;\n\n    if (err instanceof Error && (err as any).code) {\n      switch ((err as any).code) {\n        case 9:\n          return new EndorsementError(err) as E;\n      }\n    }\n\n    if (msg.includes(ValidationError.name))\n      return new ValidationError(err) as E;\n    if (msg.includes(NotFoundError.name)) return new NotFoundError(err) as E;\n    if (msg.includes(ConflictError.name)) return new ConflictError(err) as E;\n    if (msg.includes(BadRequestError.name))\n      return new BadRequestError(err) as E;\n    if (msg.includes(QueryError.name)) return new QueryError(err) as E;\n    if (msg.includes(PagingError.name)) return new PagingError(err) as E;\n    if (msg.includes(UnsupportedError.name))\n      return new UnsupportedError(err) as E;\n    if (msg.includes(MigrationError.name)) return new MigrationError(err) as E;\n    if (msg.includes(ObserverError.name)) return new ObserverError(err) as E;\n    if (msg.includes(AuthorizationError.name))\n      return new AuthorizationError(err) as E;\n    if (msg.includes(ForbiddenError.name)) return new ForbiddenError(err) as E;\n    if (msg.includes(ConnectionError.name))\n      return new ConnectionError(err) as E;\n    if (msg.includes(SerializationError.name))\n      return new SerializationError(err) as E;\n    return new InternalError(err) as E;\n  }\n}\n\nFabricClientAdapter.decoration();\nAdapter.setCurrent(FabricFlavour);\n","import {\n  Adapter,\n  ContextualArgs,\n  Dispatch,\n  EventIds,\n  UnsupportedError,\n  Context,\n  MaybeContextualArg,\n  PersistenceKeys,\n} from \"@decaf-ts/core\";\nimport { PeerConfig } from \"../shared/types\";\nimport { Client } from \"@grpc/grpc-js\";\nimport { FabricClientAdapter } from \"./FabricClientAdapter\";\nimport {\n  BulkCrudOperationKeys,\n  InternalError,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport {\n  ChaincodeEvent,\n  CloseableAsyncIterable,\n} from \"@hyperledger/fabric-gateway\";\nimport { parseEventName } from \"../shared/events\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { Constructor } from \"@decaf-ts/decoration\";\nimport { FabricClientFlags } from \"./types\";\n\n/**\n * @description Event dispatcher for Hyperledger Fabric chaincode events\n * @summary Listens for and processes events emitted by Fabric chaincode, dispatching them to registered observers\n * @template PeerConfig - Configuration type for connecting to a Fabric peer\n * @param client - gRPC client for connecting to the Fabric network\n * @class FabricClientDispatch\n * @example\n * ```typescript\n * // Create a new FabricDispatch instance\n * const client = await FabricAdapter.getClient(peerConfig);\n * const dispatch = new FabricDispatch(client);\n *\n * // Configure the dispatch with peer configuration\n * dispatch.configure(peerConfig);\n *\n * // Register an observer for a specific table and event\n * dispatch.observe('users', 'create', (id) => {\n *   console.log(`User created: ${id}`);\n * });\n *\n * // Start listening for events\n * await dispatch.start();\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant FabricDispatch\n *   participant Gateway\n *   participant Network\n *   participant Chaincode\n *\n *   Client->>FabricDispatch: new FabricDispatch(client)\n *   Client->>FabricDispatch: configure(peerConfig)\n *   Client->>FabricDispatch: observe(table, event, callback)\n *   Client->>FabricDispatch: start()\n *   FabricDispatch->>FabricDispatch: initialize()\n *   FabricDispatch->>Gateway: getGateway(config, client)\n *   Gateway->>Network: getNetwork(channel)\n *   Network->>Network: getChaincodeEvents(chaincodeName)\n *   FabricDispatch->>FabricDispatch: handleEvents()\n *   loop For each event\n *     Chaincode-->>FabricDispatch: ChaincodeEvent\n *     FabricDispatch->>FabricDispatch: parseEventName(eventName)\n *     FabricDispatch->>FabricDispatch: parsePayload(payload)\n *     FabricDispatch->>FabricDispatch: updateObservers(table, event, id)\n *     FabricDispatch-->>Client: callback(id)\n *   end\n */\nexport class FabricClientDispatch extends Dispatch<FabricClientAdapter> {\n  /**\n   * @description Event listening stack for chaincode events\n   */\n  private listeningStack?: CloseableAsyncIterable<ChaincodeEvent>;\n\n  /**\n   * @description Text decoder for converting event payloads from bytes to strings\n   */\n  private decoder = new TextDecoder(\"utf8\");\n\n  /**\n   * @description Creates a new FabricDispatch instance\n   * @summary Initializes a dispatcher for Fabric chaincode events\n   * @param {Client} client - gRPC client for connecting to the Fabric network\n   */\n  constructor(protected client: Client) {\n    super();\n  }\n\n  /**\n   * @description Closes the event listening connection\n   * @summary Stops listening for chaincode events and releases resources\n   * @return {Promise<void>} Promise that resolves when the connection is closed\n   */\n  override async close(\n    ...ctxArgs: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<void> {\n    const { log, ctxArgs: loggedArgs } = (\n      await this.logCtx(ctxArgs, PersistenceKeys.SHUTDOWN, true)\n    ).for(this.close);\n    try {\n      await super.close(...loggedArgs);\n    } catch (e: unknown) {\n      log.error(`Failed to close Fabric proxies event listener`, e as Error);\n    }\n    if (this.listeningStack) {\n      try {\n        await this.listeningStack.close();\n      } catch (e: unknown) {\n        log.error(`Failed to close Fabric event listener`, e as Error);\n      } finally {\n        this.listeningStack = undefined;\n      }\n    }\n  }\n\n  /**\n   * @description Parses event payload from binary format\n   * @summary Converts a Uint8Array containing JSON to an object with an id property\n   * @param {Uint8Array} jsonBytes - The binary payload from the chaincode event\n   * @return {{ id: string }} The parsed payload containing the record ID\n   */\n  private parsePayload(jsonBytes: Uint8Array): { id: string; result?: any } {\n    const json = this.decoder.decode(jsonBytes);\n    return JSON.parse(json);\n  }\n\n  /**\n   * @description Starts observing an adapter\n   * @summary Connects this dispatch to an adapter to monitor its operations\n   * @param {Adapter<any, any, any, any>} observer - The adapter to observe\n   * @return {void}\n   */\n  override observe(observer: Adapter<any, any, any, any>): () => void {\n    if (!(observer instanceof FabricClientAdapter))\n      throw new UnsupportedError(\n        \"Only FabricClientAdapter can be observed by dispatch\"\n      );\n    super.observe(observer as FabricClientAdapter);\n    return () => this.unObserve(observer);\n  }\n\n  /**\n   * @description Updates observers about a database event\n   * @summary Notifies observers about a change in the database\n   * @param {string} table - The name of the table where the change occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {any} payload - The event payload\n   * @return {Promise<void>} A promise that resolves when all observers have been notified\n   */\n  override async updateObservers(\n    model: Constructor<any> | string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<void> {\n    const { log, ctxArgs } = Adapter.logCtx<Context<FabricClientFlags>>(\n      this.updateObservers,\n      event,\n      false,\n      ...args\n    );\n    if (!this.adapter) {\n      log.verbose(\n        `No adapter observed for dispatch; skipping observer update for ${typeof model === \"string\" ? model : Model.tableName(model)}:${event}`\n      );\n      return;\n    }\n    try {\n      await this.adapter.refresh(model, event, id, ...ctxArgs);\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to refresh dispatch: ${e}`);\n    }\n  }\n\n  /**\n   * @description Processes incoming chaincode events\n   * @summary Listens for events from the chaincode and dispatches them to registered observers\n   * @return {Promise<void>} Promise that resolves when event handling stops\n   * @mermaid\n   * sequenceDiagram\n   *   participant FabricDispatch\n   *   participant EventStack\n   *   participant EventParser\n   *   participant Observers\n   *\n   *   FabricDispatch->>FabricDispatch: handleEvents()\n   *   FabricDispatch->>EventStack: for await (const evt of listeningStack)\n   *   EventStack-->>FabricDispatch: ChaincodeEvent\n   *   FabricDispatch->>EventParser: parseEventName(evt.eventName)\n   *   EventParser-->>FabricDispatch: { table, event, owner }\n   *   FabricDispatch->>FabricDispatch: Check if event is for this MSP\n   *   FabricDispatch->>FabricDispatch: parsePayload(evt.payload)\n   *   FabricDispatch->>Observers: updateObservers(table, event, payload.id)\n   *   Observers-->>FabricDispatch: Callbacks executed\n   */\n  protected async handleEvents(\n    ctxArg?: Context<FabricClientFlags>\n  ): Promise<void> {\n    if (!this.listeningStack)\n      throw new InternalError(\n        `Event stack not initialized. Ensure that \"startListening\" is called before attempting this operation.`\n      );\n\n    if (!this.adapter || !this.adapter.config)\n      throw new InternalError(`No adapter found. should be impossible`);\n\n    const ctx =\n      ctxArg ||\n      (await this.adapter.context(\n        OperationKeys.READ,\n        {\n          correlationId: this.adapter.config.chaincodeName,\n        },\n        (this.models && this.models[0]) || (Model as unknown as Constructor)\n      ));\n    const log = this.log.for(this.handleEvents);\n\n    log.info(\n      `Listening for incoming events on chaincode \"${this.adapter.config.chaincodeName}\" on channel \"${this.adapter.config.channel}\"...`\n    );\n\n    try {\n      for await (const evt of this.listeningStack) {\n        const { table, event, owner } = parseEventName(evt.eventName);\n        if (\n          this.adapter.config?.mspEventOnly &&\n          owner &&\n          owner !== this.adapter.config?.mspId\n        )\n          continue;\n        const payload: { id: string; result?: any } = this.parsePayload(\n          evt.payload\n        );\n        try {\n          const targetModel = table\n            ? Model.get(table)\n            : Model.get(this.models[0].name);\n          const modelRef = targetModel ?? (table || this.models[0]?.name);\n          const observerArgs = payload.result ? [payload.result, ctx] : [ctx];\n          await this.updateObservers(\n            modelRef as Constructor | string,\n            event,\n            payload.id as string,\n            ...(observerArgs as ContextualArgs<any>)\n          );\n        } catch (e: unknown) {\n          log.error(\n            `Failed update observables for table ${table} event ${event} id: ${payload.id}: ${e}`\n          );\n        }\n      }\n    } catch (e: any) {\n      log.error(\n        `Failed to read event for chaincode \"${this.adapter.config.chaincodeName}\" on channel \"${this.adapter.config.channel}\": ${e}`\n      );\n      await this.close(ctx);\n    }\n  }\n\n  /**\n   * @description Initializes the event listener\n   * @summary Sets up event dispatching for the observed adapter. When\n   * `syntheticEvents` is true (the default) no gateway connection is opened;\n   * instead every CRUD operation is wrapped with a Proxy that fires\n   * `updateObservers` for **all** models. When `syntheticEvents` is false the\n   * existing gateway-based chaincode-event subscription is established and the\n   * local Proxy fallback is limited to fully-segregated (transient) models only.\n   * @return {Promise<void>} Promise that resolves when initialization is complete\n   */\n  protected override async initialize(): Promise<void> {\n    if (!this.adapter)\n      throw new InternalError(`No adapter or config observed for dispatch`);\n\n    const syntheticEvents = this.adapter.config.syntheticEvents !== false;\n\n    if (!syntheticEvents) {\n      // Gateway-based chaincode-event subscription (non-synthetic path)\n      const context = await this.adapter.context(\n        \"dispatch\",\n        {\n          correlationId: this.adapter.config.chaincodeName,\n        },\n        Model as any\n      );\n      const { ctx } = this.logCtx([context], this.initialize);\n      const gateway = await FabricClientAdapter.getGateway(\n        ctx,\n        this.adapter.config as PeerConfig,\n        this.client\n      );\n      const network = gateway.getNetwork(this.adapter.config.channel);\n      if (!this.adapter)\n        throw new InternalError(`No adapter observed for dispatch`);\n      this.listeningStack = await network.getChaincodeEvents(\n        this.adapter.config.chaincodeName\n      );\n      this.handleEvents(ctx);\n    }\n\n    // Proxy CRUD methods.\n    // • syntheticEvents = true  → notify for ALL models (replaces gateway events entirely)\n    // • syntheticEvents = false → notify only for fully-segregated (transient) models\n    //   (the gateway subscription handles public models)\n    (\n      [\n        OperationKeys.CREATE,\n        OperationKeys.UPDATE,\n        OperationKeys.DELETE,\n        BulkCrudOperationKeys.CREATE_ALL,\n        BulkCrudOperationKeys.UPDATE_ALL,\n        BulkCrudOperationKeys.DELETE_ALL,\n      ] as (keyof Adapter<any, any, any, any>)[]\n    ).forEach((toWrap) => {\n      if (!this.adapter)\n        throw new InternalError(\n          `No adapter provided for the fallback of fully segregated models`\n        );\n      if (!this.adapter[toWrap])\n        throw new InternalError(\n          `Method ${toWrap} not found in ${this.adapter.alias} adapter to bind Observables Dispatch`\n        );\n\n      let descriptor = Object.getOwnPropertyDescriptor(this.adapter, toWrap);\n      let proto: any = this.adapter;\n      while (!descriptor && proto !== Object.prototype) {\n        proto = Object.getPrototypeOf(proto);\n        descriptor = Object.getOwnPropertyDescriptor(proto, toWrap);\n      }\n\n      if (!descriptor || !descriptor.writable) {\n        this.log.error(\n          `Could not find method ${toWrap} to bind Observables Dispatch`\n        );\n        return;\n      }\n      function bulkToSingle(method: string) {\n        switch (method) {\n          case BulkCrudOperationKeys.CREATE_ALL:\n            return OperationKeys.CREATE;\n          case BulkCrudOperationKeys.UPDATE_ALL:\n            return OperationKeys.UPDATE;\n          case BulkCrudOperationKeys.DELETE_ALL:\n            return OperationKeys.DELETE;\n          default:\n            return method;\n        }\n      }\n\n      // @ts-expect-error because there are read only properties\n      this.adapter[toWrap] = new Proxy(this.adapter[toWrap], {\n        apply: async (\n          target: any,\n          thisArg: FabricClientAdapter,\n          argArray: any[]\n        ) => {\n          // Run the original method unchanged so transient data is preserved\n          const result = await target.apply(thisArg, argArray);\n\n          const clazz: Constructor<any> = argArray[0];\n          // When syntheticEvents is false, public models emit a chaincode event\n          // on the contract side; skip the local fallback to avoid\n          // double-notification. When syntheticEvents is true we handle all models.\n          if (!syntheticEvents && !Model.isTransient(clazz)) return result;\n\n          // Context is always the last element of argArray\n          const { log, ctxArgs, ctx } = thisArg[\"logCtx\"](\n            argArray.slice(argArray.length - 1),\n            target\n          );\n          const ids = argArray[1];\n          const resultArgs: any[] = [clazz, bulkToSingle(toWrap), ids];\n\n          if (ctx.getOrUndefined(\"observeFullResult\")) {\n            resultArgs.push(result);\n          }\n          this.updateObservers(\n            ...(resultArgs as Parameters<typeof this.updateObservers>),\n            ...ctxArgs\n          ).catch((e: unknown) =>\n            log.error(\n              `Failed to dispatch observer refresh for ${toWrap} on ${clazz.name || clazz} for ${ids}: ${e}`\n            )\n          );\n          return result;\n        },\n      });\n    });\n  }\n}\n\nif (FabricClientAdapter)\n  FabricClientAdapter[\"_baseDispatch\"] = FabricClientDispatch;\n","import { Metadata } from \"@decaf-ts/decoration\";\n\nexport const VERSION = \"##VERSION##\";\nexport const PACKAGE_NAME = \"##PACKAGE##\";\n\nMetadata.registerLibrary(PACKAGE_NAME, VERSION);\n"],"names":["ensureDirectoryExistence","filePath","fs","require","path","dirname","existsSync","mkdirSync","generateModelIndexes","m","generateIndexes","generateModelDesignDocs","accum","views","generateViews","storage","forEach","doc","_id","readModelFile","file","exports","join","process","cwd","parentPath","name","values","Object","filter","e","Model","async","readModelFolders","folders","result","folder","files","readdirSync","withFileTypes","recursive","f","isFile","endsWith","push","writeIndexes","indexes","p","collection","index","resolve","writeFileSync","JSON","stringify","undefined","writeDesignDocs","designDocs","length","docId","replace","payload","_rev","collectionFor","collectionName","policy","requiredPeerCount","maxPeerCount","blockToLive","memberOnlyRead","memberOnlyWrite","privateCollectionFor","mspId","c","endorsementPolicy","signaturePolicy","sharedCollectionFor","mspIds","map","extractCollections","overrides","mirror","privateCols","sharedCols","collectionsFor","resolveCollection","arg","InternalError","privateDefaults","assign","sharedDefaults","mirrorMeta","mirroredAt","privates","flat","resolved","resolver","some","includes","shared","writeCollections","cols","fileName","writeCollectionDesignDocs","docs","FabricClientPaginator","Paginator","constructor","adapter","query","size","clazz","super","prepare","rawStatement","UnsupportedError","page","args","isSerializedPage","obj","Array","isArray","data","FabricClientRepository","Repository","force","this","_overrides","ignoreValidation","ignoreHandlers","allowRawStatements","forcePrepareSimpleQueries","forcePrepareComplexQueries","allowGenerationOverride","rebuildWithTransient","override","flags","for","ObserverHandler","paginateBy","key","order","ref","offset","limit","log","ctxArgs","logCtx","PreparedStatementKeys","PAGE_BY","verbose","tableName","class","statement","bookmark","listBy","LIST_BY","findBy","value","FIND_BY","findOneBy","FIND_ONE_BY","find","OrderDirection","ASC","FIND","direction","PAGE","ctx","PersistenceKeys","STATEMENT","callArgs","slice","parse","decode","evaluateTransaction","hydrated","r","CouchDBKeys","TABLE","d","applyAfterRead","getOrUndefined","enforceDBDecorators","OperationKeys","READ","AFTER","Promise","all","entry","countOf","COUNT_OF","stmtArgs","maxOf","MAX_OF","minOf","MIN_OF","avgOf","AVG_OF","sumOf","SUM_OF","distinctOf","DISTINCT_OF","groupOf","GROUP_OF","healthcheck","create","model","debug","ensureLegacyMirrorFlag","prepared","record","id","transient","revert","update","createAllPrefix","models","CREATE","get","ignoreValidate","ON","ignoredProps","errors","hasErrors","errorMessages","reduceErrorsToPrint","ValidationError","createAll","ids","payloads","transients","created","i","readAll","keys","records","updateAll","updated","u","accumulate","legacy","ERC20Token","BaseModel","__decorate","pk","type","String","prototype","column","required","table","ERC20Wallet","Allowance","ClientSerializer","JSONSerializer","preSerialize","modelName","toSerialize","metadata","Metadata","SerializationError","ModelKeys","ANCHOR","deserialize","str","deserialization","className","Error","build","serialize","FabricERC20ClientRepository","serializer","decoder","TextDecoder","updateObservers","event","observerHandler","count","parsedId","Sequence","parseValue","sequenceFor","tokenName","symbol","decimals","Number","totalSupply","total","balanceOf","owner","balance","transfer","to","transferred","submitTransaction","toString","transferFrom","from","contextArgs","Context","approve","spender","approved","allowance","initialize","token","initiliazed","checkInitialized","mint","amount","burn","burnFrom","account","clientAccountBalance","serializedAccountBalance","clientAccountID","extractIds","composed","pkProps","extractId","composeAttributeValue","IdentityCredentials","description","FabricModelKeys","IdentityType","FabricFlavour","Identity","X509","oneToOne","Cascade","CASCADE","delete","CoreUtils","logger","MiniLogger","contentOfLoadFile","contentOrPath","fileReader","Uint8Array","match","readFile","promises","normalizeImport","import","getCAUser","userName","privateKey","certificate","options","stringFormat","user","User","config","hsm","software","lib","library","slot","label","tokenLabel","pin","cryptoSuite","getCryptoSuite","setCryptoSuite","enrollmentKey","getHSMEnrollmentKey","getSoftwareEnrollmentKey","setEnrollment","newCryptoSuite","createKeyFromRaw","ski","keyIdHex","trim","Buffer","getCertificateSKI","getKey","isPrivate","x509","X509Certificate","jwk","publicKey","export","format","prefix","x","y","crypto","createHash","concat","digest","getIdentity","certDirectoryPath","identityFileReader","certPath","getFirstDirFileName","credentials","dirPath","readdir","getFirstDirFileNameContent","getFileContent","getSigner","keyDirectoryPath","signerFileReader","keyPath","privateKeyPem","extractPrivateKey","getOwnPropertySymbols","k","signers","newPrivateKeySigner","pem","libName","subtle","globalThis","window","Crypto","webcrypto","str2ab","buf","ArrayBuffer","bufView","strLen","charCodeAt","replaceAll","decoded","binaryDer","importKey","namedCurve","getAkiAndSerialFromCert","cert","x509Certificate","X509Cert","akiExt","extensions","aki","toUpperCase","startsWith","serial","serialNumber","cryptoProvider","set","BASE_ALPHABET","CRYPTO","BaseEncoder","alphabet","baseMap","j","charAt","xc","base","leader","factor","Math","iFactor","encode","source","isView","buffer","byteOffset","byteLength","zeroes","pbegin","pend","b58","carry","it1","it2","repeat","decodeUnsafe","psz","b256","it3","it4","vch","CryptoUtils","b58encoder","BASE58","fabricIdFromCertificate","subject","issuer","stringToArrayBuffer","extractKey","usages","RegExp","extractPublicKey","sign","buff","hash","b","padStart","verify","signature","encrypt","getSubtleCrypto","isBrowser","decrypt","getMaster","textEncoder","TextEncoder","genGenesis","randomUUID","importedKey","KEY_ALGORYTHM","iv","getDerivationKey","salt","saltBuffer","saltHashed","params","HASH","iterations","ITERATIONS","derivation","deriveBits","KEYLENGTH","ivlen","keylen","derivedKey","importedEncryptionKey","ALGORYTHM","encryptPin","text","keyObject","textBuffer","encryptedText","decryptPin","textDecoder","decryptedText","OverflowError","msg","BalanceError","AllowanceError","RegistrationError","AuthorizationError","MissingContextError","UnauthorizedPrivateDataAccess","BaseError","NotInitializedError","MissingPKCSS11Lib","EndorsementError","message","MvccReadConflictError","PhantomReadConflictError","EndorsementPolicyError","TransactionLimitsError","code","TransactionTimeoutError","TransactionBufferSizeError","HFCAIdentityType","HFCAIdentityAttributes","FabricEnrollmentService","LoggedClass","caConfig","caName","caCert","caKey","url","CA","ca","tls","trustedRoots","root","FabricCAServices","Client","client","Certificate","certificateService","newCertificateService","Affiliations","affiliationService","newAffiliationService","Identities","identityService","newIdentityService","getCertificates","request","doMap","response","certs","PEM","getIdentities","identitiesService","getAll","identities","parseError","regexp","exec","ConflictError","getAffiliations","a","read","enrollmentId","getOne","NotFoundError","success","register","isSuperUser","affiliation","userRole","attrs","maxEnrollments","registration","password","props","enrollmentID","enrollmentSecret","info","identityFromEnrollment","enrollment","rootCertificate","Logging","clientId","now","Date","toBytes","createdOn","updatedOn","enroll","identity","registerAndEnroll","revoke","reason","RegistrationRequestBuilder","errs","role","setAffiliation","addAttr","attr","setAttrs","setEnrollmentID","setEnrollmentSecret","setMaxEnrollments","setRole","minlength","min","ERC20Events","FabricBaseModel","createdAt","updatedAt","version","uses","FabricIdentifiedBaseModel","createdBy","updatedBy","isShared","segregate","isTransient","decoratedProperties","getAttributes","transientProps","DBKeys","TRANSIENT","privateProperties","PRIVATE","sharedProperties","SHARED","public","transientKeys","privateKeys","sharedKeys","isPublic","bind","mirrored","FABRIC","MIRROR","ownerOf","meta","OWNED_BY","sharedKey","constr","privateMeta","sharedMeta","collections","extractMspId","getMSPID","Owner","target","propertyKey","descriptor","originalMethod","acountId","clientIdentity","getID","select","tokens","execute","apply","ownedByOnCreate","context","stub","creator","getCreator","mspid","setOwnedByKeyValue","defineProperty","enumerable","writable","configurable","ownedBy","attribute","generated","readonly","onCreate","propMetadata","Decoration","define","decorator","transactionIdOnCreate","getTxID","transactionId","onUpdate","TRANSACTION_ID","evalMirrorMetadata","createMirrorHandler","fabricCtx","sourceModel","put","repo","mirrorCollection","updateMirrorHandler","applyUpdateValidation","mergeForUpdate","deleteMirrorHandler","pkProp","segregated","mirrorWriteGuard","msp","condition","readMirrorHandler","matches","readFrom","mspIdOrCondition","isConditionOnly","Boolean","cond","onRead","priority","onDelete","ModelCollection","orgName","toPascalCase","NamespaceCollection","namespace","ImplicitPrivateCollection","SEGREGATED_COLLECTION_EXTRACTION_PRIORITY","applySegregationFlags","isFullySegregated","hasPublicProperties","markFullySegregated","applyMirrorFlags","attributes","transientMeta","extractSegregatedCollections","dataArray","collectionResolver","seqName","sequenceName","setSequenceSegregation","segregatedDataOnCreate","keyArray","_k","keyStrings","writeTo","segregatedDataOnRead","segregatedDataOnUpdate","oldModel","segregatedDataOnDelete","innerSegregated","segregatedDec","Set","add","constrMeta","constrCollections","updatedTransientMeta","decs","properties","groupName","extractGroupName","dataGroupName","earlyExtractionMeta","earlyExtractionGroupSort","group","prop","on","DBOperations","ALL","privateData","sharedData","sortKeysOnlyRecursive","sort","reduce","acc","DeterministicSerializer","error","self","o","call","relations","generateFabricEventName","parseEventName","parts","split","sub","safeParseInt","string","digitRegex","test","parsedint","parseInt","isNaN","SimpleDeterministicSerializer","putAnchor","preSerialization","FabricIdentityService","ClientBasedService","rootClient","_user","certificates","affiliations","getUser","cfg","INITIALIZATION","getName","updateIdentity","identityRequest","caUserIdentity","reenrollUser","createUser","getMspid","enrollmentAttrs","optional","reenroll","renewedIdentity","revokeOptions","revokeRequest","CA_ROLE","DefaultFabricClientFlags","evaluateTimeout","endorseTimeout","submitTimeout","commitTimeout","allowManualEndorsingOrgs","allowGatewayOverride","encryptTransient","syntheticEvents","escapeRegExp","nextLexicographicString","chars","codePointAt","fromCodePoint","prefixRange","start","end","FabricClientStatement","Statement","squash","squashed","method","executePrepared","argz","forModel","fromSelector","alias","QUERY","isSimpleQuery","QueryClause","whereCondition","parsed","prepareCondition","selectSelector","SELECT","AND","toLowerCase","orderBySelectors","ORDER_BY","toCamelCase","processRecord","pkAttr","ID","keyArgs","SEPARATOR","raw","rawInput","aggregator","aggregateInfo","aggregate","executeAggregate","results","processed","applyAfterHandlersToResult","aggregateQuery","buildAggregateQuery","selectors","selector","fields","parseCondition","Condition","and","eq","selectorKeys","CouchDBGroupOperator","indexOf","val","OR","s","entries","warn","selectorKey","rec","CouchDBOperator","BIGGER","limitSelector","CouchDBQueryLimit","offsetSelector","skip","merge","op","obj1","obj2","attr1","operator","comparison","Operator","STARTS_WITH","QueryError","range","BIGGER_EQ","SMALLER","ENDS_WITH","REGEXP","BETWEEN","max","opBetween","translateOperators","SMALLER_EQ","GroupOperator","NOT","op1","op2","avgSelector","sumInfo","createAggregateDescriptor","countInfo","createAggregateQuery","kind","sumDescriptor","countDescriptor","countDistinctSelector","countDistinct","aggregatorUsed","countSelector","minSelector","maxSelector","sumSelector","distinctSelector","aggregatorChecks","metas","findViewMetadata","viewName","generateViewName","ddoc","generateDesignDocName","returnDocs","view","getFabricAdapter","isViewAggregate","handleAverage","fabricAdapter","viewInfo","processViewResponse","sumDesc","countDesc","sumResponse","countResponse","sum","rows","row","FabricClientAdapter","Adapter","operation","mergedFlags","silly","pop","toOverrides","newCtx","parentContext","childContexts","currentOp","currentModel","repository","createPrefix","updateAllPrefix","shift","hasTransient","needsFullPayload","shouldForceGatewayHydration","transientPayload","BulkCrudOperationKeys","CREATE_ALL","getEndorsingOrganizations","res","shouldRefreshAfterWrite","READ_ALL","UPDATE_ALL","deleteAll","shouldHydrate","DELETE_ALL","METADATA","mirrorMsp","msps","merged","endorsingOrgs","endorsingOrganizations","shouldRebuildWithTransient","v","childRebuild","getFromChildren","resolvedOp","resolveOperation","hasId","direct","deserialized","updatePrefix","UPDATE","DELETE","docsOnly","transactionResult","parseRecord","isModel","el","getClient","_client","Gateway","getGateway","getContractName","Contract","contractName","getContract","transaction","api","submit","transientData","gateway","contract","evaluate","proposalOptions","arguments","close","shouldUseLegacyGateway","prepareLegacyArgs","buildLegacyTransient","resolveLegacyMspCount","configured","legacyMspCount","isFinite","floor","pickLegacyCandidates","candidates","available","picked","idx","random","selection","splice","buildLegacyPeerConfigs","peers","peerEndpoint","peerHostAlias","tlsCert","endorsers","org","extras","mspMap","legacyCount","selections","choice","endpoint","submitLegacyWithExplicitEndorsers","fcn","transientMap","peerConfigs","normalizeLegacyPeers","identityMaterial","resolveLegacyIdentityMaterial","wallet","Wallets","newInMemoryWallet","identityLabel","connectionProfile","buildLegacyConnectionProfile","LegacyGateway","connect","discovery","enabled","asLocalhost","shouldTreatPeersAsLocalhost","tlsInfo","network","getNetwork","channel","chaincodeName","createTransaction","setTransient","peer","getChannel","getEndorser","endorser","setEndorsingPeers","disconnect","deduped","Map","addPeer","has","readPemInput","certCertOrDirectoryPath","keyCertOrDirectoryPath","peerEntries","channelPeers","orgs","tlsPem","hostname","extractHost","ensureGrpcUrl","tlsCACerts","grpcOptions","hostnameOverride","endorsingPeer","chaincodeQuery","ledgerQuery","eventSource","organization","organizations","orderers","channels","every","isLocalEndpoint","host","sanitized","isBuffer","trimmed","stats","stat","catch","isDirectory","readFsFile","err","legacyArgs","shutdown","channelName","getConnection","pathOrCert","readFileSync","tlsCredentials","grpc","createSsl","sizeLimit","signer","evaluateOptions","deadline","endorseOptions","submitOptions","commitStatusOptions","Proxy","thisArg","argArray","Reflect","Dispatch","GatewayError","details","EndorseError","BadRequestError","PagingError","MigrationError","ObserverError","ForbiddenError","ConnectionError","final","D","_a","decoration","setCurrent","FabricClientDispatch","loggedArgs","SHUTDOWN","listeningStack","parsePayload","jsonBytes","json","observe","observer","unObserve","refresh","handleEvents","ctxArg","correlationId","evt","eventName","mspEventOnly","targetModel","modelRef","observerArgs","getChaincodeEvents","toWrap","getOwnPropertyDescriptor","proto","getPrototypeOf","bulkToSingle","resultArgs","VERSION","PACKAGE_NAME","registerLibrary"],"mappings":"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"}
|
|
3790
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-fabric.cjs","sources":["../src/client/indexes/generation.ts","../src/client/collections/generation.ts","../src/client/FabricClientPaginator.ts","../src/client/FabricClientRepository.ts","../src/contracts/erc20/models.ts","../src/shared/ClientSerializer.ts","../src/client/erc20/FabricERC20ClientRepository.ts","../src/client/ids/id-extraction.ts","../src/shared/model/IdentityCredentials.ts","../src/shared/constants.ts","../src/shared/model/Identity.ts","../src/client/utils.ts","../src/client/crypto.ts","../src/shared/errors.ts","../src/client/services/FabricEnrollmentService.ts","../src/client/services/RegistrationRequestBuilder.ts","../src/shared/erc20/erc20-constants.ts","../src/shared/model/FabricBaseModel.ts","../src/shared/model/FabricIdentifiedBaseModel.ts","../src/shared/overrides/overrides.ts","../src/shared/decorators.ts","../src/shared/DeterministicSerializer.ts","../src/shared/events.ts","../src/shared/math.ts","../src/shared/SimpleDeterministicSerializer.ts","../src/client/services/FabricIdentityService.ts","../src/client/services/constants.ts","../src/client/constants.ts","../src/client/fabric-fs.ts","../src/client/FabricClientStatement.ts","../src/client/FabricClientAdapter.ts","../src/client/FabricClientDispatch.ts","../src/version.ts"],"sourcesContent":["import { Constructor } from \"@decaf-ts/decoration\";\nimport {\n  CreateIndexRequest,\n  CouchDBDesignDoc,\n  generateIndexes,\n  generateViews,\n} from \"@decaf-ts/for-couchdb\";\nimport { Model, ModelConstructor } from \"@decaf-ts/decorator-validation\";\n\nexport type Index = CreateIndexRequest;\n\nfunction ensureDirectoryExistence(filePath: string) {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n  const dirname: string = path.dirname(filePath);\n  if (fs.existsSync(dirname)) {\n    return true;\n  }\n  ensureDirectoryExistence(dirname);\n  fs.mkdirSync(dirname);\n}\n\nexport function generateModelIndexes<M extends Model>(\n  m: Constructor<M>\n): Index[] {\n  return generateIndexes([m]);\n}\n\nexport function generateModelDesignDocs<M extends Model>(\n  m: Constructor<M>,\n  accum?: Record<string, CouchDBDesignDoc>\n): CouchDBDesignDoc[] {\n  const views = generateViews([m]);\n  const storage: Record<string, CouchDBDesignDoc> = accum || {};\n  views.forEach((doc) => {\n    storage[doc._id] = doc;\n  });\n  return views;\n}\n\nexport function readModelFile(file: any) {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const exports = require(path.join(process.cwd(), file.parentPath, file.name));\n\n  const values = Object.values(exports).filter((e) => {\n    try {\n      const m = new (e as Constructor)();\n      return m instanceof Model;\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      return false;\n    }\n  }) as ModelConstructor<any>[];\n  return values;\n}\n\nexport async function readModelFolders(\n  ...folders: string[]\n): Promise<ModelConstructor<any>[]> {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n\n  const result: ModelConstructor<any>[] = [];\n\n  for (const folder of folders) {\n    const files = fs\n      .readdirSync(folder, {\n        withFileTypes: true,\n        recursive: true,\n      })\n      .filter((f: any) => f.isFile() && f.name.endsWith(\"js\"));\n    for (const file of files) {\n      result.push(...readModelFile(file));\n    }\n  }\n  return result;\n}\n\nexport function writeIndexes(\n  indexes: Index[],\n  p: string = process.cwd(),\n  collection?: string\n) {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n\n  indexes.forEach((index) => {\n    const file = path.resolve(\n      path.join(\n        p,\n        `./META-INF/statedb/couchdb/${collection ? `collections/${collection}/` : \"\"}indexes/${index.name}.json`\n      )\n    );\n    ensureDirectoryExistence(file);\n    fs.writeFileSync(file, JSON.stringify(index, undefined, 2));\n  });\n}\n\nexport function writeDesignDocs(\n  designDocs: CouchDBDesignDoc[],\n  p: string = process.cwd(),\n  collection?: string\n) {\n  if (!designDocs.length) return;\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n\n  designDocs.forEach((doc) => {\n    const docId = doc._id.replace(/^_design\\//, \"\");\n    const file = path.resolve(\n      path.join(\n        p,\n        `./META-INF/statedb/couchdb/${collection ? `collections/${collection}/` : \"\"}design_docs/${docId}.json`\n      )\n    );\n    ensureDirectoryExistence(file);\n    const payload = { ...doc };\n    delete payload._rev;\n    fs.writeFileSync(file, JSON.stringify(payload, undefined, 2));\n  });\n}\n","import { Constructor } from \"@decaf-ts/decoration\";\nimport { CouchDBDesignDoc } from \"@decaf-ts/for-couchdb\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport { CollectionResolver } from \"../../shared/index\";\nimport { writeDesignDocs } from \"../indexes/generation\";\n\n//\n// export type FabricCollection = {\n//   name: \"collectionMarbles\";\n//   policy: \"OR('Org1MSP.member', 'Org2MSP.member')\";\n//   requiredPeerCount: 0;\n//   maxPeerCount: 3;\n//   blockToLive: 0;\n//   memberOnlyRead: true;\n//   memberOnlyWrite: true;\n//   endorsementPolicy: {\n//     identities: [\n//       { role: { name: \"member\"; mspId: \"Org1MSP\" } },\n//       { role: { name: \"member\"; mspId: \"Org2MSP\" } },\n//     ];\n//     rule: \"OR('Org1MSP.member', 'Org2MSP.member')\";\n//   };\n// };\n\nexport type FabricPolicyIdentity = {\n  role: {\n    name: string;\n    mspId: string;\n  };\n};\n\nexport type FabricCollection = {\n  name: string;\n  policy: string;\n  requiredPeerCount: number;\n  maxPeerCount: number;\n  blockToLive: number;\n  memberOnlyRead: boolean;\n  memberOnlyWrite: boolean;\n  endorsementPolicy: {\n    identities: FabricPolicyIdentity[];\n    rule: string;\n  };\n};\n\nexport type PrivateCollection = {\n  name: string;\n  policy: string;\n  requiredPeerCount: number;\n  maxPeerCount: number;\n  blockToLive: number;\n  memberOnlyRead: boolean;\n  memberOnlyWrite: boolean;\n  endorsementPolicy?: {\n    signaturePolicy: string;\n  };\n};\n\nexport function collectionFor(\n  collectionName: string,\n  policy: string,\n  requiredPeerCount: number,\n  maxPeerCount: number,\n  blockToLive: number,\n  memberOnlyRead: boolean,\n  memberOnlyWrite: boolean\n): PrivateCollection {\n  return {\n    name: collectionName,\n    policy: policy,\n    requiredPeerCount,\n    maxPeerCount,\n    blockToLive,\n    memberOnlyRead,\n    memberOnlyWrite,\n  };\n}\n\nexport function privateCollectionFor(\n  mspId: string,\n  collectionName: string = `${mspId}Private`,\n  requiredPeerCount: number = 0,\n  maxPeerCount: number = 0,\n  blockToLive: number = 0,\n  memberOnlyRead: boolean = true,\n  memberOnlyWrite: boolean = true\n): PrivateCollection {\n  const c = collectionFor(\n    collectionName,\n    `OR('${mspId}.member')`,\n    requiredPeerCount,\n    maxPeerCount,\n    blockToLive,\n    memberOnlyRead,\n    memberOnlyWrite\n  );\n\n  c.endorsementPolicy = {\n    signaturePolicy: `OR('${mspId}.peer')`,\n  };\n  return c;\n}\n\nexport function sharedCollectionFor(\n  mspIds: string[],\n  collectionName: string,\n  requiredPeerCount: number = 1,\n  maxPeerCount: number = 2,\n  blockToLive: number = 0,\n  memberOnlyRead: boolean = true,\n  memberOnlyWrite: boolean = true\n): PrivateCollection {\n  const c = collectionFor(\n    collectionName,\n    `OR(${mspIds.map((m) => `'${m}.member'`).join(\",\")})`,\n    requiredPeerCount,\n    maxPeerCount,\n    blockToLive,\n    memberOnlyRead,\n    memberOnlyWrite\n  );\n  c.endorsementPolicy = {\n    signaturePolicy: `AND(${mspIds.map((m) => `'${m}.peer'`).join(\",\")})`,\n  };\n  return c;\n}\n\nexport async function extractCollections<M extends Model>(\n  m: Constructor<M>,\n  mspIds: string[],\n  overrides: {\n    privateCols?: Partial<PrivateCollection>;\n    sharedCols?: Partial<PrivateCollection>;\n  } = {},\n  mirror: boolean = false\n) {\n  let { privateCols, sharedCols } = Model.collectionsFor(m);\n\n  function resolveCollection(arg: string | CollectionResolver): string {\n    try {\n      if (typeof arg === \"string\") return arg;\n      return arg(m, mspIds[0]) as string;\n    } catch (e: unknown) {\n      throw new InternalError(e as Error);\n    }\n  }\n\n  privateCols = privateCols.map(resolveCollection);\n  sharedCols = sharedCols.map(resolveCollection);\n\n  const privateDefaults = Object.assign(\n    {},\n    {\n      requiredPeerCount: 0,\n      maxPeerCount: 0,\n      blockToLive: 0,\n      memberOnlyRead: true,\n      memberOnlyWrite: true,\n    },\n    overrides?.privateCols || {}\n  );\n  const sharedDefaults = Object.assign(\n    {},\n    {\n      requiredPeerCount: 1,\n      maxPeerCount: 2,\n      blockToLive: 0,\n      memberOnlyRead: true,\n      memberOnlyWrite: true,\n    },\n    overrides?.sharedCols || {}\n  );\n\n  const mirrorMeta = mirror ? Model.mirroredAt(m) : undefined;\n\n  const privates = mspIds\n    .map((mspId) =>\n      (privateCols as string[]).map((p) => {\n        const { requiredPeerCount, maxPeerCount, blockToLive, memberOnlyRead } =\n          privateDefaults;\n        return privateCollectionFor(\n          mspId,\n          p,\n          requiredPeerCount,\n          maxPeerCount,\n          blockToLive,\n          memberOnlyRead,\n          false\n        );\n      })\n    )\n    .flat();\n\n  if (mirrorMeta && mirrorMeta.mspId) {\n    const resolved =\n      typeof mirrorMeta.resolver === \"string\"\n        ? mirrorMeta.resolver\n        : mirrorMeta.resolver(m, mirrorMeta.mspId);\n    if (\n      resolved &&\n      !privates.some(\n        (p) => p.name === resolved && p.policy.includes(mirrorMeta.mspId)\n      )\n    ) {\n      const { requiredPeerCount, maxPeerCount, blockToLive, memberOnlyRead } =\n        privateDefaults;\n      privates.push(\n        privateCollectionFor(\n          mirrorMeta.mspId,\n          resolved,\n          requiredPeerCount,\n          maxPeerCount,\n          blockToLive,\n          memberOnlyRead,\n          false\n        )\n      );\n    }\n  }\n\n  const shared = (sharedCols as string[]).map((p) => {\n    const {\n      requiredPeerCount,\n      maxPeerCount,\n      blockToLive,\n      memberOnlyRead,\n      memberOnlyWrite,\n    } = sharedDefaults;\n    return sharedCollectionFor(\n      mspIds,\n      p,\n      requiredPeerCount,\n      maxPeerCount,\n      blockToLive,\n      memberOnlyRead,\n      memberOnlyWrite\n    );\n  });\n\n  return {\n    privates,\n    shared,\n  };\n}\n\nexport function writeCollections(\n  cols: PrivateCollection[],\n  p: string = process.cwd(),\n  fileName = \"collections_config\"\n) {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const fs = require(\"fs\");\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const path = require(\"path\");\n\n  function ensureDirectoryExistence(filePath: string) {\n    const dirname: string = path.dirname(filePath) as string;\n    if (fs.existsSync(dirname)) {\n      return true;\n    }\n    ensureDirectoryExistence(dirname);\n    fs.mkdirSync(dirname);\n  }\n\n  const file = path.resolve(path.join(p, `./META-INF/${fileName}.json`));\n  ensureDirectoryExistence(file);\n  fs.writeFileSync(file, JSON.stringify(cols, undefined, 2));\n}\n\nexport function writeCollectionDesignDocs(\n  docs: CouchDBDesignDoc[],\n  p: string = process.cwd(),\n  collection?: string\n) {\n  if (!docs?.length) return;\n  writeDesignDocs(docs, p, collection);\n}\n","import {\n  MaybeContextualArg,\n  Paginator,\n  PreparedStatement,\n  SerializedPage,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { Constructor } from \"@decaf-ts/decoration\";\nimport { FabricClientAdapter } from \"./FabricClientAdapter\";\nimport { MangoQuery } from \"@decaf-ts/for-couchdb\";\n\nexport class FabricClientPaginator<M extends Model> extends Paginator<\n  M,\n  M[],\n  MangoQuery\n> {\n  bookmark?: string;\n\n  constructor(\n    adapter: FabricClientAdapter,\n    query: MangoQuery | PreparedStatement<any>,\n    size: number,\n    clazz: Constructor<M>\n  ) {\n    super(adapter, query, size, clazz);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected prepare(rawStatement: MangoQuery): MangoQuery {\n    throw new UnsupportedError(\n      `Raw query access must be implemented by a subclass. only prepared statements are natively available`\n    );\n  }\n\n  override page(\n    page: number = 1,\n    ...args: MaybeContextualArg<any>\n  ): Promise<M[]> {\n    return super.page(page, ...args); // this will fail for non-prepared statements\n  }\n\n  static override isSerializedPage(obj: SerializedPage<any> | any) {\n    return obj && typeof obj === \"object\" && Array.isArray(obj.data);\n  }\n}\n","import type { MaybeContextualArg } from \"@decaf-ts/core\";\nimport {\n  ContextOf,\n  DirectionLimitOffset,\n  FlagsOf,\n  ObserverHandler,\n  OrderDirection,\n  Paginator,\n  PersistenceKeys,\n  PreparedStatementKeys,\n  Repository,\n  SerializedPage,\n} from \"@decaf-ts/core\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { Constructor } from \"@decaf-ts/decoration\";\nimport { type FabricClientAdapter } from \"./FabricClientAdapter\";\nimport {\n  BulkCrudOperationKeys,\n  enforceDBDecorators,\n  OperationKeys,\n  PrimaryKeyType,\n  reduceErrorsToPrint,\n  ValidationError,\n} from \"@decaf-ts/db-decorators\";\nimport { CouchDBKeys } from \"@decaf-ts/for-couchdb\";\nimport { FabricClientPaginator } from \"./FabricClientPaginator\";\n\n/**\n * @description Repository implementation for Fabric client operations\n * @summary Extends the generic Repository to prepare context and arguments for CRUD operations executed via a Fabric client Adapter, wiring RepositoryFlags and Fabric-specific overrides.\n * @template M extends Model - The model type handled by this repository\n * @param {Adapter<any, MangoQuery, FabricFlags, Context<FabricFlags>>} [adapter] - Optional adapter instance used to execute operations\n * @param {Constructor<M>} [clazz] - Optional model constructor used by the repository\n * @return {void}\n * @class FabricClientRepository\n * @example\n * import { Repository } from \"@decaf-ts/core\";\n * import { FabricClientRepository } from \"@decaf-ts/for-fabric\";\n *\n * class User extends Model { id!: string; name!: string; }\n * const repo = new FabricClientRepository<User>();\n * const created = await repo.create(new User({ id: \"1\", name: \"Alice\" }));\n * const loaded = await repo.read(\"1\");\n *\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Repo as FabricClientRepository\n *   participant Adapter\n *   App->>Repo: create(model)\n *   Repo->>Repo: createPrefix(model, ...args)\n *   Repo->>Adapter: create(table, id, model, flags)\n *   Adapter-->>Repo: result\n *   Repo-->>App: model\n */\nexport class FabricClientRepository<\n  M extends Model,\n  A extends FabricClientAdapter = FabricClientAdapter,\n> extends Repository<M, A> {\n  protected override _overrides = Object.assign({}, super[\"_overrides\"], {\n    ignoreValidation: true,\n    ignoreHandlers: true,\n    allowRawStatements: false,\n    forcePrepareSimpleQueries: true,\n    forcePrepareComplexQueries: true,\n    allowGenerationOverride: false,\n    rebuildWithTransient: false,\n  });\n\n  constructor(adapter?: A, clazz?: Constructor<M>, force: boolean = false) {\n    super(adapter, clazz, force);\n  }\n\n  override override(flags: Partial<FlagsOf<ContextOf<A>>>): this {\n    return super\n      .override(Object.assign({}, flags, this._overrides))\n      .for(flags as any);\n  }\n\n  protected override ObserverHandler(): ObserverHandler {\n    return super.ObserverHandler();\n  }\n\n  override async paginateBy(\n    key: keyof M,\n    order: OrderDirection,\n    ref: Omit<DirectionLimitOffset, \"direction\"> = {\n      offset: 1,\n      limit: 10,\n    },\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<SerializedPage<M>> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.PAGE_BY, true)\n    ).for(this.paginateBy);\n    log.verbose(\n      `paginating ${Model.tableName(this.class)} with page size ${ref.limit}`\n    );\n    return this.statement(\n      this.paginateBy.name,\n      key,\n      order,\n      { limit: ref.limit, offset: ref.offset, bookmark: ref.bookmark },\n      ...ctxArgs\n    );\n  }\n\n  override async listBy(\n    key: keyof M,\n    order: OrderDirection,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.LIST_BY, true)\n    ).for(this.listBy);\n    log.verbose(\n      `listing ${Model.tableName(this.class)} by ${key as string} ${order}`\n    );\n    return (await this.statement(\n      this.listBy.name,\n      key,\n      order,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async findBy(\n    key: keyof M,\n    value: any,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.FIND_BY, true)\n    ).for(this.findBy);\n    log.verbose(\n      `finding all ${Model.tableName(this.class)} with ${key as string} ${value}`\n    );\n    return (await this.statement(\n      this.findBy.name,\n      key,\n      value,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async findOneBy(\n    key: keyof M,\n    value: any,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.FIND_ONE_BY, true)\n    ).for(this.findOneBy);\n    log.verbose(\n      `finding One ${Model.tableName(this.class)} with ${key as string} ${value}`\n    );\n    return (await this.statement(\n      this.findOneBy.name,\n      key,\n      value,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async find(\n    value: string,\n    order: OrderDirection = OrderDirection.ASC,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.FIND, true)\n    ).for(this.find);\n    log.verbose(\n      `finding ${Model.tableName(this.class)} by default query attributes`\n    );\n    return (await this.statement(\n      this.find.name,\n      value,\n      order,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async page(\n    value: string,\n    direction: OrderDirection = OrderDirection.ASC,\n    ref: Omit<DirectionLimitOffset, \"direction\"> = {\n      offset: 1,\n      limit: 10,\n    },\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<SerializedPage<M>> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.PAGE, true)\n    ).for(this.page);\n    log.verbose(\n      `paging ${Model.tableName(this.class)} by default query attributes`\n    );\n    return (await this.statement(\n      this.page.name,\n      value,\n      direction,\n      ref,\n      ...ctxArgs\n    )) as any;\n  }\n\n  override async statement(\n    name: string,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<any> {\n    const { log, ctx, ctxArgs } = (\n      await this.logCtx(args, PersistenceKeys.STATEMENT, true)\n    ).for(this.statement);\n    log.verbose(`Executing prepared statement ${name}`);\n    const callArgs = ctxArgs.slice(0, -1);\n    const result = JSON.parse(\n      this.adapter.decode(\n        await this.adapter.evaluateTransaction(\n          ctx,\n          PersistenceKeys.STATEMENT,\n          [name, JSON.stringify(callArgs)],\n          undefined,\n          undefined,\n          this.class.name\n        )\n      )\n    );\n\n    let hydrated: any;\n    if (Array.isArray(result)) {\n      hydrated = result.map((r: any) =>\n        (r as any)[CouchDBKeys.TABLE] &&\n        (r as any)[CouchDBKeys.TABLE] === Model.tableName(this.class)\n          ? (new this.class(r) as M)\n          : r\n      );\n    } else if (\n      (result as any)[CouchDBKeys.TABLE] &&\n      (result as any)[CouchDBKeys.TABLE] === Model.tableName(this.class)\n    ) {\n      hydrated = new this.class(result) as M;\n    } else if (FabricClientPaginator.isSerializedPage(result)) {\n      hydrated = Object.assign(result, {\n        data: result.data.map((d: any) => new this.class(d) as M),\n      });\n    } else {\n      hydrated = result;\n    }\n\n    return this.applyAfterRead(hydrated, ctx);\n  }\n\n  private async applyAfterRead(value: any, ctx: ContextOf<A>): Promise<any> {\n    if (!ctx.getOrUndefined(\"afterQueryHandlers\")) return value;\n    if (value instanceof Model) {\n      await enforceDBDecorators<M, Repository<M, A>, any>(\n        this,\n        ctx,\n        value as M,\n        OperationKeys.READ,\n        OperationKeys.AFTER\n      );\n      return value;\n    }\n    if (Array.isArray(value)) {\n      await Promise.all(value.map((entry) => this.applyAfterRead(entry, ctx)));\n      return value;\n    }\n    if (FabricClientPaginator.isSerializedPage(value)) {\n      await this.applyAfterRead(value.data, ctx);\n      return value;\n    }\n    return value;\n  }\n\n  override async countOf(\n    key?: keyof M,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.COUNT_OF, true)\n    ).for(this.countOf);\n    log.verbose(\n      `counting ${Model.tableName(this.class)}${key ? ` by ${key as string}` : \"\"}`\n    );\n    const stmtArgs = key ? [key, ...ctxArgs] : ctxArgs;\n    return this.statement(PreparedStatementKeys.COUNT_OF, ...stmtArgs);\n  }\n\n  override async maxOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[K]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.MAX_OF, true)\n    ).for(this.maxOf);\n    log.verbose(\n      `finding max of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.MAX_OF, key, ...ctxArgs);\n  }\n\n  override async minOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[K]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.MIN_OF, true)\n    ).for(this.minOf);\n    log.verbose(\n      `finding min of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.MIN_OF, key, ...ctxArgs);\n  }\n\n  override async avgOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.AVG_OF, true)\n    ).for(this.avgOf);\n    log.verbose(\n      `calculating avg of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.AVG_OF, key, ...ctxArgs);\n  }\n\n  override async sumOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.SUM_OF, true)\n    ).for(this.sumOf);\n    log.verbose(\n      `calculating sum of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.SUM_OF, key, ...ctxArgs);\n  }\n\n  override async distinctOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[K][]> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.DISTINCT_OF, true)\n    ).for(this.distinctOf);\n    log.verbose(\n      `finding distinct values of ${key as string} in ${Model.tableName(this.class)}`\n    );\n    return this.statement(PreparedStatementKeys.DISTINCT_OF, key, ...ctxArgs);\n  }\n\n  override async groupOf<K extends keyof M>(\n    key: K,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<Record<string, M[]>> {\n    const { log, ctxArgs } = (\n      await this.logCtx(args, PreparedStatementKeys.GROUP_OF, true)\n    ).for(this.groupOf);\n    log.verbose(`grouping ${Model.tableName(this.class)} by ${key as string}`);\n    return this.statement(PreparedStatementKeys.GROUP_OF, key, ...ctxArgs);\n  }\n\n  async healthcheck(...args: MaybeContextualArg<ContextOf<A>>) {\n    const { ctxArgs } = this.logCtx(args, this.healthcheck);\n\n    const result = await this.adapter.healthcheck(this.class, ...ctxArgs);\n\n    return result;\n  }\n\n  override async create(\n    model: M,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M> {\n    const { ctx, log, ctxArgs } = this.logCtx(args, this.create);\n    log.debug(\n      `Creating new ${this.class.name} in table ${Model.tableName(this.class)}`\n    );\n    this.ensureLegacyMirrorFlag(ctx, model);\n    const prepared = this.adapter.prepare(model, ctx);\n    const { record, id, transient } = prepared;\n    const result = await this.adapter.create(\n      this.class,\n      id,\n      record,\n      transient,\n      ...ctxArgs\n    );\n    return this.adapter.revert<M>(result, this.class, id, transient, ctx);\n  }\n\n  override async update(\n    model: M,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M> {\n    const { ctxArgs, log, ctx } = this.logCtx(args, this.update);\n    this.ensureLegacyMirrorFlag(ctx, model);\n    const prepared = this.adapter.prepare(model, ctx);\n    const { id, transient } = prepared;\n    let record = prepared.record;\n    log.debug(\n      `updating ${this.class.name} in table ${Model.tableName(this.class)} with id ${id}`\n    );\n    record = await this.adapter.update(\n      this.class,\n      id,\n      record,\n      transient,\n      ...ctxArgs\n    );\n    return this.adapter.revert<M>(record, this.class, id, transient, ctx);\n  }\n\n  protected override async createAllPrefix(\n    models: M[],\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<[M[], ...any[], ContextOf<A>]> {\n    const { ctx, ctxArgs } = (\n      await this.logCtx(args, OperationKeys.CREATE, true)\n    ).for(this.createAllPrefix);\n    const ignoreHandlers = ctx.get(\"ignoreHandlers\");\n    const ignoreValidate = ctx.get(\"ignoreValidation\");\n    if (!models.length) return [models, ...ctxArgs] as any;\n\n    models = await Promise.all(\n      models.map(async (m) => {\n        m = new this.class(m);\n        if (!ignoreHandlers)\n          await enforceDBDecorators<M, Repository<M, A>, any>(\n            this,\n            ctx,\n            m,\n            OperationKeys.CREATE,\n            OperationKeys.ON\n          );\n        return m;\n      })\n    );\n\n    if (!ignoreValidate) {\n      const ignoredProps = ctx.get(\"ignoredValidationProperties\") || [];\n\n      const errors = await Promise.all(\n        models.map((m) => Promise.resolve(m.hasErrors(...ignoredProps)))\n      );\n\n      const errorMessages = reduceErrorsToPrint(errors);\n\n      if (errorMessages) throw new ValidationError(errorMessages);\n    }\n    return [models, ...ctxArgs] as any;\n  }\n\n  override async createAll(\n    models: M[],\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    if (!models.length) return models;\n    const { ctx, log, ctxArgs } = this.logCtx(args, this.createAll);\n    log.debug(\n      `Creating ${models.length} new ${this.class.name} in table ${Model.tableName(this.class)}`\n    );\n\n    models.forEach((model) => this.ensureLegacyMirrorFlag(ctx, model));\n    const prepared = models.map((m) => this.adapter.prepare(m, ctx));\n    const ids = prepared.map((p) => p.id);\n    const payloads = prepared.map((p) => p.record);\n    const transients = prepared.map((p) => p.transient);\n    const created = await this.adapter.createAll(\n      this.class,\n      ids as PrimaryKeyType[],\n      payloads,\n      transients,\n      ...ctxArgs\n    );\n    return Promise.all(\n      created.map(async (r, i) => {\n        const id = ids[i];\n        return this.adapter.revert<M>(r, this.class, id, transients[i], ctx);\n      })\n    );\n  }\n\n  override async readAll(\n    keys: PrimaryKeyType[],\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ) {\n    const { ctx, log, ctxArgs } = this.logCtx(args, this.readAll);\n    log.debug(\n      `reading ${keys.length} ${this.class.name} in table ${Model.tableName(this.class)}`\n    );\n    const records = await this.adapter.readAll(this.class, keys, ...ctxArgs);\n    return records.map((r, i) =>\n      this.adapter.revert(r, this.class, keys[i], {}, ctx)\n    );\n  }\n\n  override async updateAll(\n    models: M[],\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<M[]> {\n    const { ctx, log, ctxArgs } = this.logCtx(args, this.updateAll);\n    log.debug(\n      `Updating ${models.length} new ${this.class.name} in table ${Model.tableName(this.class)}`\n    );\n\n    models.forEach((model) => this.ensureLegacyMirrorFlag(ctx, model));\n    const prepared = models.map((m) => this.adapter.prepare(m, ctx));\n    const ids = prepared.map((p) => p.id);\n    const updated = await this.adapter.updateAll(\n      this.class,\n      ids as PrimaryKeyType[],\n      prepared.map((r) => r.record),\n      prepared.map((r) => r.transient),\n      ...ctxArgs\n    );\n    return Promise.all(\n      updated.map(async (u, i) => {\n        const id = ids[i];\n        return this.adapter.revert<M>(\n          u,\n          this.class,\n          id,\n          prepared[i].transient,\n          ctx\n        );\n      })\n    );\n  }\n\n  private ensureLegacyMirrorFlag(ctx: ContextOf<A>, model: M): void {\n    if (Model.mirroredAt(model)) {\n      ctx.accumulate({ legacy: true });\n    }\n  }\n}\n","import { BaseModel, column, pk, table } from \"@decaf-ts/core\";\nimport { model, type ModelArg, required } from \"@decaf-ts/decorator-validation\";\n\n/**\n * @description ERC20 token metadata model\n * @summary Represents an ERC20 token definition within the Fabric ERC20 sample, including name, symbol, decimals, and the owning identity. Used to define the unique token managed by the contract.\n * @param {ModelArg<ERC20Token>} [m] - Optional partial data or another instance to initialize the model\n * @return {void}\n * @class ERC20Token\n * @example\n * const token = new ERC20Token({ name: \"MyToken\", symbol: \"MTK\", decimals: 18, owner: \"x509::...\" });\n * // Persist through a repository: await repo.create(token, ctx)\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Repo\n *   participant Adapter\n *   App->>Repo: create(new ERC20Token({...}), ctx)\n *   Repo->>Adapter: create(table, id=name, record, flags)\n *   Adapter-->>Repo: stored\n *   Repo-->>App: model\n */\n@table(\"erc20_tokens\")\n@model()\nexport class ERC20Token extends BaseModel {\n  @pk({ type: String })\n  /**\n   * @description Token unique name\n   * @summary Serves as the primary key for the ERC20 token definition; typically a human-readable identifier\n   */\n  name!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Owning identity of the token\n   * @summary X.509 subject or MSP identity string that denotes who owns/controls the token definition\n   */\n  owner!: string;\n  @column()\n  @required()\n  /**\n   * @description Token symbol\n   * @summary Short ticker-like symbol used to represent the token (e.g., MTK)\n   */\n  symbol!: string;\n  @column()\n  @required()\n  /**\n   * @description Decimal precision for token amounts\n   * @summary Number of digits after the decimal separator used when formatting token balances\n   */\n  decimals!: number;\n\n  constructor(m?: ModelArg<ERC20Wallet>) {\n    super(m);\n  }\n}\n\n/**\n * @description ERC20 wallet model\n * @summary Represents a holder account for an ERC20 token within the Fabric network, tracking balance and token association.\n * @param {ModelArg<ERC20Wallet>} [m] - Optional partial data or another instance to initialize the model\n * @return {void}\n * @class ERC20Wallet\n * @example\n * const wallet = new ERC20Wallet({ id: \"acct1\", token: \"MyToken\", balance: 1000 });\n * // Update balance via repository: await repo.update(wallet, ctx)\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Repo\n *   App->>Repo: read(\"acct1\", ctx)\n *   Repo-->>App: ERC20Wallet\n */\n@table(\"erc20_wallets\")\n@model()\nexport class ERC20Wallet extends BaseModel {\n  @pk({ type: String })\n  /**\n   * @description Wallet unique identifier\n   * @summary Primary key for the wallet; commonly references an account or identity\n   */\n  id!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Associated token name\n   * @summary References the ERC20Token this wallet holds; maintained as a relationship for cascading updates/deletes\n   */\n  token!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Token balance for this wallet\n   * @summary Current amount of the associated token held by this wallet\n   */\n  balance!: number;\n\n  @column()\n  /**\n   * @description Captive flag or identifier\n   * @summary Optional field used by some flows to mark non-transferable funds or managed custody\n   */\n  captive!: string;\n\n  constructor(m?: ModelArg<ERC20Wallet>) {\n    super(m);\n  }\n}\n\n/**\n * @description ERC20 allowance model\n * @summary Captures an approval relationship where an owner allows a spender to transfer up to a certain value from the owner's wallet.\n * @param {ModelArg<Allowance>} [m] - Optional partial data or another instance to initialize the model\n * @return {void}\n * @class Allowance\n * @example\n * const allowance = new Allowance({ owner: \"acct1\", spender: \"acct2\", value: 50 });\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   App->>App: new Allowance({ owner, spender, value })\n */\n@table(\"erc20_allowances\")\n@model()\nexport class Allowance extends BaseModel {\n  @pk({ type: String })\n  /**\n   * @description Allowance unique identifier\n   * @summary Primary key for the allowance; typically a unique identifier for the approval relationship\n   */\n  @column()\n  @required()\n  /**\n   * @description Owner wallet identifier\n   * @summary Wallet that authorizes the allowance\n   */\n  owner!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Spender wallet identifier\n   * @summary Wallet allowed to spend up to the approved value from the owner\n   */\n  spender!: string;\n\n  @column()\n  @required()\n  /**\n   * @description Approved value\n   * @summary Maximum token amount the spender may transfer on behalf of the owner\n   */\n  value!: number;\n\n  constructor(m?: ModelArg<Allowance>) {\n    super(m);\n  }\n}\n","import {\n  JSONSerializer,\n  Model,\n  ModelKeys,\n} from \"@decaf-ts/decorator-validation\";\nimport { SerializationError } from \"@decaf-ts/db-decorators\";\nimport { Constructor, Metadata } from \"@decaf-ts/decoration\";\n\n/**\n * @description Client-side JSON serializer for Decaf models targeting Hyperledger Fabric\n * @summary Extends the base JSONSerializer to embed model metadata (anchor) required to reconstruct instances on the client, and to safely serialize/deserialize Fabric-bound models.\n * @template M extends Model - The Decaf model type handled by this serializer\n * @param {void} [constructor] No public constructor arguments; provided for documentation completeness\n * @return {void}\n * @class ClientSerializer\n * @example\n * const serializer = new ClientSerializer<User>();\n * const json = serializer.serialize(new User({ id: \"1\", name: \"Alice\" }));\n * const user = serializer.deserialize(json);\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Serializer as ClientSerializer\n *   participant Model\n *   App->>Serializer: serialize(model)\n *   Serializer->>Serializer: preSerialize(model)\n *   Serializer-->>App: JSON string\n *   App->>Serializer: deserialize(json)\n *   Serializer->>Serializer: JSON.parse(json)\n *   Serializer->>Model: Model.build(parsed, anchor)\n *   Model-->>App: instance\n */\nexport class ClientSerializer<M extends Model> extends JSONSerializer<M> {\n  constructor() {\n    super();\n  }\n  /**\n   * @description Prepare a model for JSON serialization embedding class anchor\n   * @summary Clones the model and injects the class metadata anchor so it can be reconstructed during deserialization. Falls back to provided table name if metadata is not available.\n   * @template M - Model type handled by this serializer\n   * @param {M} model - The model instance to serialize\n   * @param {string} [modelName] - Optional table name to use when metadata cannot be derived\n   * @return {Record<string, any>} A plain object ready to be JSON.stringify'd\n   */\n  protected override preSerialize(model: M, modelName?: string) {\n    // TODO: nested preserialization (so increase performance when deserializing)\n    const toSerialize: Record<string, any> = Object.assign({}, model);\n    let metadata = Metadata.modelName(model.constructor as Constructor<M>);\n\n    if (!metadata || metadata === \"Object\")\n      if (modelName) metadata = modelName;\n      else\n        throw new SerializationError(\n          `Could not find metadata for ${model.constructor.name}`\n        );\n    toSerialize[ModelKeys.ANCHOR] = metadata;\n    return toSerialize;\n  }\n\n  /**\n   * @description Rebuilds a model from its JSON serialization\n   * @summary Parses the JSON string, retrieves the embedded model anchor, and uses Model.build to reconstruct the original instance\n   * @param {string} str - The JSON string previously produced by serialize\n   * @return {M} The reconstructed model instance\n   */\n  override deserialize(str: string): M {\n    const deserialization = JSON.parse(str);\n    const className = deserialization[ModelKeys.ANCHOR];\n    if (!className)\n      throw new Error(\"Could not find class reference in serialized model\");\n    const model: M = Model.build(deserialization, className) as unknown as M;\n    return model;\n  }\n\n  /**\n   * @description Serializes a model to a JSON string\n   * @summary Prepares the model via preSerialize, embedding metadata needed for reconstruction, and returns a JSON string representation\n   * @param {M} model - The model instance to serialize\n   * @param {string} [table] - Optional table name to include as anchor when metadata is unavailable\n   * @return {string} A JSON string containing the serialized model with anchor metadata\n   */\n  override serialize(model: M, modelName?: string): string {\n    return JSON.stringify(this.preSerialize(model, modelName));\n  }\n}\n","import { FabricClientRepository } from \"../FabricClientRepository\";\nimport { ERC20Token, ERC20Wallet } from \"../../contracts/erc20/models\";\nimport { Model, Serializer } from \"@decaf-ts/decorator-validation\";\nimport { FabricClientAdapter } from \"../FabricClientAdapter\";\nimport { ClientSerializer } from \"../../shared/ClientSerializer\";\nimport {\n  Context,\n  ContextOf,\n  ContextualArgs,\n  EventIds,\n  MaybeContextualArg,\n  Sequence,\n} from \"@decaf-ts/core\";\nimport {\n  BulkCrudOperationKeys,\n  InternalError,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { Constructor } from \"@decaf-ts/decoration\";\n/**\n * Repository for interacting with ERC20 contracts on a Hyperledger Fabric network.\n * Extends the base FabricClientRepository class and utilizes the ClientSerializer for data serialization.\n */\nexport class FabricERC20ClientRepository<\n  A extends FabricClientAdapter,\n> extends FabricClientRepository<ERC20Wallet, A> {\n  private static serializer = new ClientSerializer();\n\n  protected readonly serializer: Serializer<any> =\n    FabricERC20ClientRepository.serializer;\n\n  private static decoder = new TextDecoder(\"utf8\");\n\n  /**\n   * @description Notifies all observers of an event.\n   * @summary Updates all registered observers with information about a database event.\n   * @param {string} table - The table name where the event occurred.\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of event that occurred.\n   * @param {EventIds} id - The ID or IDs of the affected records.\n   * @param {...any[]} args - Additional arguments.\n   * @return {Promise<void>} A promise that resolves when all observers have been notified.\n   * @throws {InternalError} If the observer handler is not initialized.\n   */\n  override async updateObservers<M extends Model>(\n    table: Constructor<M> | string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: ContextualArgs<ContextOf<A>>\n  ): Promise<void> {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    const { log, ctxArgs } = this.logCtx(args, this.updateObservers);\n    log.verbose(\n      `Updating ${this.observerHandler.count()} observers for ${this}`\n    );\n\n    table = (\n      typeof table === \"string\" ? Model.get(table) : table\n    ) as Constructor<M>;\n    let parsedId: string | string[] | undefined;\n\n    if (id === undefined) {\n      parsedId = undefined;\n    } else if (Array.isArray(id)) {\n      parsedId = id.map(\n        (i) => Sequence.parseValue(Model.sequenceFor(table).type, i) as string\n      );\n    } else {\n      parsedId = Sequence.parseValue(\n        Model.sequenceFor(table).type,\n        id\n      ) as string;\n    }\n    await this.observerHandler.updateObservers(\n      table,\n      event,\n      parsedId!,\n      ...ctxArgs\n    );\n  }\n\n  /**\n   * Decodes a Uint8Array into a string using the TextDecoder.\n   *\n   * @param data - The Uint8Array to decode.\n   * @returns The decoded string.\n   */\n  decode(data: Uint8Array): string {\n    return FabricERC20ClientRepository.decoder.decode(data);\n  }\n\n  constructor(adapter?: A) {\n    super(adapter, ERC20Wallet);\n  }\n\n  /**\n   * Retrieves the name of the ERC20 token.\n   *\n   * @description\n   * This function interacts with the blockchain network to fetch the name of the ERC20 token.\n   * It calls the \"TokenName\" transaction on the smart contract and decodes the returned data.\n   *\n   * @returns {Promise<string>} A promise that resolves with the name of the ERC20 token.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async tokenName(...args: MaybeContextualArg<ContextOf<A>>): Promise<string> {\n    const { ctx } = (await this.logCtx(args, \"tokenName\", true)).for(\n      this.tokenName\n    );\n    const name = await this.adapter.evaluateTransaction(ctx, \"TokenName\");\n    return this.decode(name);\n  }\n\n  /**\n   * Retrieves the symbol of the ERC20 token.\n   *\n   * This function interacts with the blockchain network to fetch the symbol of the ERC20 token.\n   * It calls the \"Symbol\" transaction on the smart contract and decodes the returned data.\n   *\n   * @returns {Promise<string>} A promise that resolves with the symbol of the ERC20 token.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async symbol(...args: MaybeContextualArg<ContextOf<A>>): Promise<string> {\n    const { ctx } = (await this.logCtx(args, \"symbol\", true)).for(this.symbol);\n    const symbol = await this.adapter.evaluateTransaction(ctx, \"Symbol\");\n    return this.decode(symbol);\n  }\n\n  /**\n   * Retrieves the number of decimal places for the ERC20 token.\n   *\n   * This function interacts with the blockchain network to fetch the number of decimal places for the ERC20 token.\n   * It calls the \"Decimals\" transaction on the smart contract and decodes the returned data.\n   *\n   * @returns {Promise<number>} A promise that resolves with the number of decimal places for the ERC20 token.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async decimals(...args: MaybeContextualArg<ContextOf<A>>): Promise<number> {\n    const { ctx } = (await this.logCtx(args, \"decimals\", true)).for(\n      this.decimals\n    );\n    const decimals = await this.adapter.evaluateTransaction(ctx, \"Decimals\");\n    return Number(this.decode(decimals));\n  }\n\n  /**\n   * Retrieves the total supply of the ERC20 token.\n   *\n   * This function interacts with the blockchain network to fetch the total supply of the ERC20 token.\n   * It calls the \"TotalSupply\" transaction on the smart contract and decodes the returned data.\n   *\n   * @returns {Promise<number>} A promise that resolves with the total supply of the ERC20 token.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async totalSupply(\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { ctx } = (await this.logCtx(args, \"totalSupply\", true)).for(\n      this.totalSupply\n    );\n    const total = await this.adapter.evaluateTransaction(ctx, \"TotalSupply\");\n    return Number(this.decode(total));\n  }\n\n  /**\n   * Retrieves the balance of the ERC20 token for a specified owner.\n   *\n   * @description\n   * This function interacts with the blockchain network to fetch the balance of the ERC20 token for a given owner.\n   * It calls the \"BalanceOf\" transaction on the smart contract with the provided owner's address as a parameter.\n   * The returned data is then decoded and converted to a number.\n   *\n   * @param owner - The address of the ERC20 token owner.\n   *\n   * @returns {Promise<number>} A promise that resolves with the balance of the ERC20 token for the specified owner.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async balanceOf(\n    owner: string,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<number> {\n    const { ctx } = (await this.logCtx(args, \"balance\", true)).for(\n      this.balanceOf\n    );\n    const balance = await this.adapter.evaluateTransaction(ctx, \"BalanceOf\", [\n      owner,\n    ]);\n    return Number(this.decode(balance));\n  }\n\n  /**\n   * Transfers a specified amount of ERC20 tokens to a recipient.\n   *\n   * @description\n   * This function interacts with the blockchain network to transfer a specified amount of ERC20 tokens to a recipient.\n   * It calls the \"Transfer\" transaction on the smart contract with the recipient's address and the transfer amount as parameters.\n   * The returned data is then decoded and checked to determine if the transfer was successful.\n   *\n   * @param to - The address of the recipient.\n   * @param value - The amount of ERC20 tokens to transfer.\n   *\n   * @returns {Promise<boolean>} A promise that resolves with `true` if the transfer was successful, and `false` otherwise.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async transfer(\n    to: string,\n    value: number,\n    ...args: MaybeContextualArg<ContextOf<A>>\n  ): Promise<boolean> {\n    const { ctx } = (await this.logCtx(args, \"transfer\", true)).for(\n      this.transfer\n    );\n    const transferred = await this.adapter.submitTransaction(ctx, \"Transfer\", [\n      to,\n      value.toString(),\n    ]);\n    return this.decode(transferred) === \"true\" ? true : false;\n  }\n\n  /**\n   * Transfers a specified amount of ERC20 tokens from one account to another.\n   *\n   * @description\n   * This function interacts with the blockchain network to transfer a specified amount of ERC20 tokens from one account to another.\n   * For this transfer to work the spender ( account that will trigger this function ) need to have the value approved as an allowance by the sender.\n   * It calls the \"TransferFrom\" transaction on the smart contract with the sender's address, recipient's address, and the transfer amount as parameters.\n   * The returned data is then decoded and checked to determine if the transfer was successful.\n   *\n   * @param from - The address of the sender.\n   * @param to - The address of the recipient.\n   * @param value - The amount of ERC20 tokens to transfer.\n   *\n   * @returns {Promise<boolean>} A promise that resolves with `true` if the transfer was successful, and `false` otherwise.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async transferFrom(\n    from: string,\n    to: string,\n    value: number\n  ): Promise<boolean> {\n    const contextArgs = await Context.args(\n      \"transferFrom\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.transferFrom);\n    const transferred = await this.adapter.submitTransaction(\n      ctx,\n      \"TransferFrom\",\n      [from, to, value.toString()]\n    );\n\n    return this.decode(transferred) === \"true\" ? true : false;\n  }\n\n  /**\n   * Approves a specified amount of ERC20 tokens to be spent by a specified spender.\n   *\n   * This function interacts with the blockchain network to approve a specified amount of ERC20 tokens to be spent by a specified spender.\n   * It calls the \"Approve\" transaction on the smart contract with the spender's address and the approval amount as parameters.\n   * The returned data is then decoded and checked to determine if the approval was successful.\n   *\n   * @param spender - The address of the spender.\n   * @param value - The amount of ERC20 tokens to approve for the spender.\n   *\n   * @returns {Promise<boolean>} A promise that resolves with `true` if the approval was successful, and `false` otherwise.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async approve(spender: string, value: number): Promise<boolean> {\n    const contextArgs = await Context.args(\n      \"approve\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.approve);\n    const approved = await this.adapter.submitTransaction(ctx, \"Approve\", [\n      spender,\n      value.toString(),\n    ]);\n    return this.decode(approved) === \"true\" ? true : false;\n  }\n\n  /**\n   * Retrieves the allowance of ERC20 tokens that the specified owner has approved for a spender.\n   *\n   * @description\n   * This function interacts with the blockchain network to fetch the allowance of ERC20 tokens that the specified owner has approved for a spender.\n   * It calls the \"Allowance\" transaction on the smart contract with the owner's address and the spender's address as parameters.\n   * The returned data is then decoded and converted to a number.\n   *\n   * @param owner - The address of the ERC20 token owner.\n   * @param spender - The address of the spender.\n   *\n   * @returns {Promise<number>} A promise that resolves with the allowance of ERC20 tokens that the specified owner has approved for the spender.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async allowance(owner: string, spender: string): Promise<number> {\n    const contextArgs = await Context.args(\n      \"allowance\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.allowance);\n    const allowance = await this.adapter.submitTransaction(ctx, \"Allowance\", [\n      owner,\n      spender,\n    ]);\n    return Number(this.decode(allowance));\n  }\n\n  /**\n   * Initializes the ERC20 contract with the provided token information.\n   *\n   * @description\n   * This function interacts with the blockchain network to initialize the ERC20 contract with the given token information.\n   * It calls the \"Initialize\" transaction on the smart contract with the serialized token data as a parameter.\n   * The returned data is then decoded and checked to determine if the initialization was successful.\n   *\n   * @param token - The ERC20 token information to initialize the contract with.\n   *\n   * @returns {Promise<boolean>} A promise that resolves with `true` if the initialization was successful, and `false` otherwise.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async initialize(token: ERC20Token): Promise<boolean> {\n    const contextArgs = await Context.args(\n      \"initialize\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.initialize);\n    const initiliazed = await this.adapter.submitTransaction(\n      ctx,\n      \"Initialize\",\n      [FabricERC20ClientRepository.serializer.serialize(token)]\n    );\n\n    return this.decode(initiliazed) === \"true\" ? true : false;\n  }\n\n  /**\n   * Checks if the ERC20 contract has been initialized.\n   *\n   * This function interacts with the blockchain network to verify if the ERC20 contract has been initialized.\n   * It calls the \"CheckInitialized\" transaction on the smart contract, which does not require any parameters.\n   *\n   * @returns {Promise<void>} A promise that resolves when the initialization check is completed.\n   *\n   * @throws {Error} If the transaction fails.\n   */\n  async checkInitialized(): Promise<void> {\n    const contextArgs = await Context.args(\n      \"checkInitialized\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.checkInitialized);\n    await this.adapter.evaluateTransaction(ctx, \"CheckInitialized\");\n  }\n\n  /**\n   * Mints a specified amount of ERC20 tokens.\n   *\n   * @description\n   * This function interacts with the blockchain network to mint a specified amount of ERC20 tokens.\n   * It calls the \"Mint\" transaction on the smart contract with the minting amount as a parameter.\n   * The function does not return any value, but it updates the minter's number of tokens.\n   *\n   * @param amount - The amount of ERC20 tokens to mint.\n   *\n   * @returns {Promise<void>} A promise that resolves when the minting process is completed.\n   *\n   * @throws {Error} If the transaction fails.\n   */\n  async mint(amount: number): Promise<void> {\n    const contextArgs = await Context.args(\n      \"mint\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.mint);\n    await this.adapter.submitTransaction(ctx, \"Mint\", [amount.toString()]);\n  }\n\n  /**\n   * Burns a specified amount of ERC20 tokens from the minter's account.\n   *\n   * This function interacts with the blockchain network to burn a specified amount of ERC20 tokens.\n   * It calls the \"Burn\" transaction on the smart contract with the burning amount as a parameter.\n   * The function does not return any value, but it decreases the minter's number of tokens.\n   *\n   * @param amount - The amount of ERC20 tokens to burn.\n   *\n   * @returns {Promise<void>} A promise that resolves when the burning process is completed.\n   *\n   * @throws {Error} If the transaction fails.\n   */\n  async burn(amount: number): Promise<void> {\n    const contextArgs = await Context.args(\n      \"burn\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.burn);\n    await this.adapter.submitTransaction(ctx, \"Burn\", [amount.toString()]);\n  }\n\n  /**\n   * Burns a specified amount of ERC20 tokens from a specified account.\n   *\n   * This function interacts with the blockchain network to burn a specified amount of ERC20 tokens from a given account.\n   * It calls the \"BurnFrom\" transaction on the smart contract with the account's address and the burning amount as parameters.\n   * The function does not return any value, but it decreases the specified account's number of tokens.\n   *\n   * @param account - The address of the account from which to burn the ERC20 tokens.\n   * @param amount - The amount of ERC20 tokens to burn.\n   *\n   * @returns {Promise<void>} A promise that resolves when the burning process is completed.\n   *\n   * @throws {Error} If the transaction fails.\n   */\n  async burnFrom(account: string, amount: number): Promise<void> {\n    const contextArgs = await Context.args(\n      \"burnFrom\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.burnFrom);\n    await this.adapter.submitTransaction(ctx, \"BurnFrom\", [\n      account,\n      amount.toString(),\n    ]);\n  }\n\n  /**\n   * Retrieves the balance of ERC20 tokens associated with the client's account.\n   *\n   * This function interacts with the blockchain network to fetch the balance of ERC20 tokens associated with the client's account.\n   * It calls the \"ClientAccountBalance\" transaction on the smart contract, which does not require any parameters.\n   * The returned data is then decoded and converted to a number.\n   *\n   * @returns {Promise<number>} A promise that resolves with the balance of ERC20 tokens associated with the client's account.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async clientAccountBalance(): Promise<number> {\n    const contextArgs = await Context.args(\n      \"accountBalance\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.clientAccountBalance);\n    const serializedAccountBalance = await this.adapter.evaluateTransaction(\n      ctx,\n      \"ClientAccountBalance\"\n    );\n\n    return Number(this.decode(serializedAccountBalance));\n  }\n\n  /**\n   * Retrieves the client's account ID from the blockchain network.\n   *\n   * This function interacts with the blockchain network to fetch the client's account ID.\n   * It calls the \"ClientAccountID\" transaction on the smart contract, which does not require any parameters.\n   * The returned data is then decoded and returned as a string.\n   *\n   * @returns {Promise<string>} A promise that resolves with the client's account ID.\n   *\n   * @throws {Error} If the transaction fails or the decoding process fails.\n   */\n  async clientAccountID(): Promise<string> {\n    const contextArgs = await Context.args(\n      \"accountId\",\n      this.class,\n      [],\n      this.adapter,\n      this._overrides || {}\n    );\n    const { ctx } = this.logCtx(contextArgs.args, this.clientAccountID);\n    const clientAccountID = await this.adapter.evaluateTransaction(\n      ctx,\n      \"ClientAccountID\"\n    );\n\n    return this.decode(clientAccountID);\n  }\n}\n","import { Model } from \"@decaf-ts/decorator-validation\";\nimport { InternalError, PrimaryKeyType } from \"@decaf-ts/db-decorators\";\nimport { Constructor } from \"@decaf-ts/decoration\";\nimport { SequenceOptions } from \"@decaf-ts/core\";\nimport { composeAttributeValue } from \"@decaf-ts/db-decorators\";\n\nexport function extractIds<M extends Model>(\n  clazz: Constructor<M>,\n  models: M | M[] | Record<string, any> | Record<string, any>[],\n  ids: PrimaryKeyType | PrimaryKeyType[]\n) {\n  let pk: keyof M;\n  let composed: any;\n  let pkProps: SequenceOptions;\n\n  function extractId(m: M | Record<string, any>, ids: PrimaryKeyType) {\n    pk = pk || Model.pk(clazz);\n    pkProps = pkProps || Model.sequenceFor(clazz);\n    composed = composed || Model.composed(clazz, pk);\n\n    if (composed) {\n      return composeAttributeValue(m as any, composed);\n    }\n\n    const id = (m as any)[pk] || ids;\n    if (typeof id === \"undefined\")\n      throw new InternalError(`could not rebuild id for ${m.constructor.name}`);\n    return id;\n  }\n\n  if (Array.isArray(models)) {\n    if (!Array.isArray(ids) || ids.length !== models.length)\n      throw new InternalError(\n        \"inconsistent parameters. both must be arrays of equal length\"\n      );\n    return models.map((m, i) => extractId(m, ids[i]));\n  }\n  return extractId(models, ids as PrimaryKeyType);\n}\n","import { BaseModel, column, pk } from \"@decaf-ts/core\";\nimport { model, type ModelArg, required } from \"@decaf-ts/decorator-validation\";\nimport { description } from \"@decaf-ts/decoration\";\n\n/**\n * @description Identity credential model storing cryptographic materials\n * @summary Holds certificate chain and private key information for a Fabric identity, managed as a separate entity linked from Identity\n * @param {ModelArg<IdentityCredentials>} [arg] - Optional initialization object used to populate model fields\n * @class IdentityCredentials\n * @example\n * // Create credentials entry\n * const creds = new IdentityCredentials({ id: \"creds1\", certificate: \"...\", rootCertificate: \"...\", privateKey: \"...\" });\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Model as IdentityCredentials\n *   App->>Model: new IdentityCredentials({ id, certificate, rootCertificate, privateKey })\n *   Model-->>App: instance\n * @see model\n */\n@model()\nexport class IdentityCredentials extends BaseModel {\n  /**\n   * @description Unique identifier of the credentials record\n   * @summary Primary key for referencing this credentials entry\n   */\n  @description(\"Unique identifier of the credentials record\")\n  @column()\n  @pk()\n  id!: string;\n\n  /**\n   * @description PEM-encoded X.509 certificate for the identity\n   * @summary Leaf certificate associated with the identity\n   */\n  @description(\"PEM-encoded X.509 certificate for the identity\")\n  @column()\n  @required()\n  certificate!: string;\n\n  /**\n   * @description PEM-encoded root or intermediate certificate\n   * @summary Root of trust used to validate the leaf certificate\n   */\n  @description(\"PEM-encoded root or intermediate certificate\")\n  @column()\n  @required()\n  rootCertificate!: string;\n\n  /**\n   * @description PEM-encoded private key material\n   * @summary Private key corresponding to the identity certificate\n   */\n  @description(\"PEM-encoded private key\")\n  @column()\n  @required()\n  privateKey!: string;\n\n  constructor(arg?: ModelArg<IdentityCredentials>) {\n    super(arg);\n  }\n}\n","/**\n * @description Keys used to mark Fabric-specific model metadata\n * @summary Enumeration of special keys used by the serialization layer to persist Fabric-related flags on models\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.shared\n */\nexport enum FabricModelKeys {\n  /** Private data marker used to tag properties or models for Fabric private collections */\n  PRIVATE = \"private\",\n  SHARED = \"shared\",\n  /** Namespace prefix used for Fabric-specific metadata keys */\n  FABRIC = \"fabric\",\n  OWNED_BY = \"owned-by\",\n  TRANSACTION_ID = \"transaction-id\",\n  MIRROR = \"mirror\",\n}\n/**\n * @description Supported identity types for Fabric credentials\n * @summary Enumeration of identity formats recognized by this library\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.shared\n */\nexport enum IdentityType {\n  /** Standard X.509 identity format used by Hyperledger Fabric */\n  X509 = \"X.509\",\n}\n\n/**\n * @description String identifier for the Fabric adapter flavour\n * @summary Used to tag adapters/repositories that operate against Hyperledger Fabric\n * @const FabricFlavour\n * @memberOf module:for-fabric.shared\n */\nexport const FabricFlavour = \"hlf-fabric\";\n","import {\n  BaseModel,\n  Cascade,\n  column,\n  index,\n  oneToOne,\n  pk,\n} from \"@decaf-ts/core\";\nimport { model, type ModelArg, required } from \"@decaf-ts/decorator-validation\";\nimport { IdentityCredentials } from \"./IdentityCredentials\";\nimport { IdentityType } from \"../constants\";\nimport { description } from \"@decaf-ts/decoration\";\n\n/**\n * @description Identity model representing a Fabric wallet entry\n * @summary Encapsulates an identity stored in a Fabric wallet, including its MSP identifier, credential linkage, and type information. Built on BaseModel for integration with Decaf validation and persistence.\n * @param {ModelArg<Identity>} [arg] - Optional initialization object used to populate model fields\n * @class Identity\n * @example\n * // Create a new identity referencing existing credentials\n * const id = new Identity({ id: \"user1\", mspId: \"Org1MSP\", type: IdentityType.X509 });\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Model as Identity\n *   App->>Model: new Identity({ id, mspId, type })\n *   Model-->>App: instance\n */\n@model()\nexport class Identity extends BaseModel {\n  /**\n   * @description Unique identifier of the identity in the wallet\n   * @summary Primary key used to reference this identity record\n   */\n  @description(\"Unique identifier of the identity\")\n  @pk()\n  id!: string;\n\n  /**\n   * @description Link to the identity credentials stored separately\n   * @summary One-to-one relationship to the credentials entity; cascades on update and delete\n   */\n  @oneToOne(IdentityCredentials, {\n    update: Cascade.CASCADE,\n    delete: Cascade.CASCADE,\n  })\n  credentials!: IdentityCredentials;\n\n  /**\n   * @description Membership Service Provider identifier\n   * @summary The MSP ID corresponding to the organization that issued this identity\n   */\n  @column()\n  @required()\n  @index()\n  mspId!: string;\n\n  /**\n   * @description Type of identity\n   * @summary Indicates the identity encoding/format; defaults to X.509\n   */\n  @column()\n  @required()\n  type: IdentityType = IdentityType.X509;\n\n  constructor(arg: ModelArg<Identity>) {\n    super(arg);\n  }\n}\n","import { stringFormat } from \"@decaf-ts/decorator-validation\";\nimport { Logger, MiniLogger } from \"@decaf-ts/logging\";\nimport { Identity, Signer, signers } from \"@hyperledger/fabric-gateway\";\nimport { CryptoSetting, ICryptoSuite, User } from \"fabric-common\";\nimport { HSMOptions } from \"../shared/types\";\nimport { normalizeImport } from \"@decaf-ts/core\";\nimport crypto, { X509Certificate } from \"crypto\";\nimport { X509Certificate as X509Cert } from \"@peculiar/x509\";\n\n/**\n * @description Core utilities for interacting with files, crypto identities, and Fabric SDK helpers\n * @summary Provides static helper methods to read credentials and keys from disk or raw content, construct Fabric gateway Identities and Signers, and perform common filesystem operations used by the Fabric client tooling.\n * @class CoreUtils\n * @example\n * // Read an identity and signer from directories\n * const identity = await CoreUtils.getIdentity('Org1MSP', '/msp/signcerts');\n * const signer = await CoreUtils.getSigner('/msp/keystore');\n * // Build a CA user\n * const user = await CoreUtils.getCAUser('appUser', pemKey, pemCert, 'Org1MSP');\n */\nexport class CoreUtils {\n  private static logger: Logger = new MiniLogger(CoreUtils.name);\n\n  private static cryptoSuite: ICryptoSuite;\n\n  private constructor() {}\n\n  /**\n   * @description Resolve file content from a path or return provided raw content\n   * @summary If the input is a Uint8Array or PEM content, returns it as-is; otherwise uses a provided async fileReader to load the content from disk.\n   * @param {string|Uint8Array} contentOrPath - Either a raw content buffer/string or a filesystem path\n   * @param {function(string): Promise<string|Uint8Array|Buffer>} fileReader - Async function to read file content when a path is provided\n   * @return {Promise<string|Uint8Array|Buffer>} The content to be used downstream\n   */\n  private static async contentOfLoadFile(\n    contentOrPath: string | Uint8Array,\n    fileReader: (path: string) => Promise<string | Uint8Array | Buffer>\n  ) {\n    if (contentOrPath instanceof Uint8Array) return contentOrPath;\n    if (\n      contentOrPath.match(\n        /-----BEGIN (CERTIFICATE|KEY|PRIVATE KEY)-----.+?-----END \\1-----$/gms\n      )\n    )\n      return contentOrPath;\n    return await fileReader(contentOrPath);\n  }\n\n  /**\n   * @description Read file content from a path or return provided Buffer\n   * @summary Convenience wrapper that loads a file using fs.promises when a path string is provided; otherwise returns the given Buffer directly.\n   * @param {string|Buffer} contentOrPath - Path to a file on disk or an already-loaded Buffer\n   * @return {Promise<string|Uint8Array|Buffer>} The file content as a Buffer/string depending on reader\n   */\n  static async readFile(contentOrPath: string | Buffer) {\n    if (typeof contentOrPath !== \"string\") return contentOrPath;\n\n    const fileReader = async (path: string) => {\n      const { promises } = await normalizeImport(import(\"fs\"));\n      return await promises.readFile(path);\n    };\n\n    return await fileReader(contentOrPath);\n  }\n\n  /**\n   * @description Create a Fabric CA User object with enrollment\n   * @summary Constructs a fabric-common User, sets a crypto suite, imports the provided private key, and sets enrollment with certificate and MSP ID.\n   * @param {string} userName - The user name for the CA user\n   * @param {string} privateKey - PEM-encoded private key\n   * @param {string} certificate - PEM-encoded X.509 certificate\n   * @param {string} mspId - Membership Service Provider identifier\n   * @return {Promise<User>} The enrolled Fabric User instance\n   */\n  static async getCAUser(\n    userName: string,\n    privateKey: string | undefined,\n    certificate: string,\n    mspId: string,\n    options?: { hsm?: HSMOptions }\n  ): Promise<User> {\n    this.logger.debug(\n      stringFormat(\n        \"Creating CA {0} user {1} with certificate {2}\",\n        mspId,\n        userName,\n        certificate\n      )\n    );\n    const user = new User(userName);\n    const config = options?.hsm\n      ? {\n          software: false,\n          lib: options.hsm.library,\n          slot: options.hsm.slot,\n          label: options.hsm.tokenLabel,\n          pin: String(options.hsm.pin),\n        }\n      : undefined;\n    const cryptoSuite = this.getCryptoSuite(config);\n\n    user.setCryptoSuite(cryptoSuite);\n    const enrollmentKey = options?.hsm\n      ? await this.getHSMEnrollmentKey(cryptoSuite, certificate, options.hsm)\n      : this.getSoftwareEnrollmentKey(cryptoSuite, privateKey);\n    await user.setEnrollment(enrollmentKey, certificate, mspId);\n    return user;\n  }\n\n  static getCryptoSuite(options?: CryptoSetting): ICryptoSuite {\n    if (!options) return User.newCryptoSuite();\n    if (CoreUtils.cryptoSuite) return CoreUtils.cryptoSuite;\n\n    CoreUtils.cryptoSuite = User.newCryptoSuite(options);\n    return CoreUtils.cryptoSuite;\n  }\n\n  private static getSoftwareEnrollmentKey(\n    cryptoSuite: any,\n    privateKey?: string\n  ) {\n    if (!privateKey) {\n      throw new Error(\n        \"Private key must be provided when HSM configuration is not supplied\"\n      );\n    }\n    return cryptoSuite.createKeyFromRaw(privateKey);\n  }\n\n  private static async getHSMEnrollmentKey(\n    cryptoSuite: any,\n    certificate: string,\n    hsm: HSMOptions\n  ) {\n    const ski =\n      hsm.keyIdHex && hsm.keyIdHex.trim().length > 0\n        ? Buffer.from(hsm.keyIdHex, \"hex\")\n        : await this.getCertificateSKI(certificate);\n    const key = await cryptoSuite.getKey(ski);\n    if (!key || (typeof key.isPrivate === \"function\" && !key.isPrivate())) {\n      throw new Error(\"Unable to resolve private key from HSM\");\n    }\n    return key;\n  }\n\n  static async getCertificateSKI(certificate: string): Promise<Buffer> {\n    const x509 = new X509Certificate(certificate);\n    const jwk = x509.publicKey.export({ format: \"jwk\" });\n    const prefix = Buffer.from([0x04]);\n    const x = Buffer.from(jwk.x || \"\", \"base64url\");\n    const y = Buffer.from(jwk.y || \"\", \"base64url\");\n    return crypto\n      .createHash(\"sha256\")\n      .update(Buffer.concat([prefix, x, y]))\n      .digest();\n  }\n\n  /**\n   * @description Build a Fabric Gateway Identity from an MSP ID and certificate\n   * @summary Reads a certificate from a directory path or accepts raw content and returns an Identity object suitable for the Fabric Gateway.\n   * @param {string} mspId - Membership Service Provider ID\n   * @param {string} certDirectoryPath - Path to a directory containing the certificate file, or PEM content\n   * @return {Promise<Identity>} The identity containing mspId and certificate credentials\n   */\n  static async getIdentity(\n    mspId: string,\n    certDirectoryPath: string\n  ): Promise<Identity> {\n    const identityFileReader = async (path: string) => {\n      const { promises } = await normalizeImport(import(\"fs\"));\n      const certPath = await this.getFirstDirFileName(path);\n      const credentials = await promises.readFile(certPath);\n      return credentials;\n    };\n\n    const credentials: Uint8Array = (await this.contentOfLoadFile(\n      certDirectoryPath,\n      identityFileReader\n    )) as Uint8Array;\n\n    return { mspId, credentials };\n  }\n\n  static async getFirstDirFileName(dirPath: string): Promise<string> {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    const { join } = await normalizeImport(import(\"path\"));\n    const files = await promises.readdir(dirPath);\n    return join(dirPath, files[0]);\n  }\n\n  static async getFirstDirFileNameContent(dirPath: string): Promise<string> {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    const { join } = await normalizeImport(import(\"path\"));\n    const files = await promises.readdir(dirPath);\n    return (await promises.readFile(join(dirPath, files[0]))).toString();\n  }\n\n  static async getFileContent(filePath: string): Promise<string> {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    return (await promises.readFile(filePath)).toString();\n  }\n\n  static async getSigner(keyDirectoryPath: string): Promise<Signer> {\n    const signerFileReader = async (path: string) => {\n      const { promises } = await normalizeImport(import(\"fs\"));\n      const keyPath = await this.getFirstDirFileName(path);\n      return await promises.readFile(keyPath);\n    };\n\n    const privateKeyPem = (await this.contentOfLoadFile(\n      keyDirectoryPath,\n      signerFileReader\n    )) as Buffer;\n    const privateKey = await this.extractPrivateKey(privateKeyPem);\n    const keys = Object.getOwnPropertySymbols(privateKey);\n    const k = (privateKey as any)[keys[0]];\n    // --\n\n    return signers.newPrivateKeySigner(k as any);\n  }\n\n  private static async extractPrivateKey(pem: Buffer) {\n    const libName = \"crypto\";\n    let subtle: any;\n    if (\n      (globalThis as any).window &&\n      ((globalThis as any).window as { Crypto: any }).Crypto\n    ) {\n      subtle = ((globalThis as any).Crypto as any).subtle;\n    } else {\n      const lib = (await normalizeImport(import(libName))) as any;\n      subtle = lib.subtle || lib.webcrypto.subtle;\n    }\n\n    if (!subtle) throw new Error(\"Could not load SubtleCrypto module\");\n\n    function str2ab(str: string) {\n      const buf = new ArrayBuffer(str.length);\n      const bufView = new Uint8Array(buf);\n      for (let i = 0, strLen = str.length; i < strLen; i++) {\n        bufView[i] = str.charCodeAt(i);\n      }\n      return buf;\n    }\n\n    const str = pem\n      .toString(\"utf8\")\n      .replace(\"-----BEGIN PRIVATE KEY-----\", \"\")\n      .replaceAll(\"\\n\", \"\")\n      .replace(\"-----END PRIVATE KEY-----\", \"\");\n    const decoded = Buffer.from(str, \"base64\").toString(\"binary\");\n    const binaryDer = str2ab(decoded);\n    const key = await subtle.importKey(\n      \"pkcs8\",\n      binaryDer,\n      {\n        name: \"ECDSA\",\n        namedCurve: \"P-256\",\n      },\n      true,\n      [\"sign\"]\n    );\n\n    return key;\n  }\n}\n\n/**\n * Extracts the certificate Serial Number and the AKI (Authority Key Identifier)\n * in the format Fabric CA expects (plain hex, no colons).\n */\nexport function getAkiAndSerialFromCert(cert: string): {\n  aki: string;\n  serial: string;\n} {\n  const x509Certificate = new X509Cert(cert);\n\n  // Find the AKI (Authority Key Identifier) extension by its OID: 2.5.29.35\n  const akiExt = x509Certificate.extensions?.find(\n    (e) => e.type === \"2.5.29.35\"\n  );\n  if (!akiExt) {\n    throw new Error(\n      \"Authority Key Identifier (AKI) extension not found in certificate.\"\n    );\n  }\n\n  // akiExt.value is the extension content in DER bytes. Convert it to a hex string.\n  let aki = Buffer.from(new Uint8Array(akiExt.value))\n    .toString(\"hex\")\n    .toUpperCase();\n\n  /**\n   * Common case:\n   * The DER-encoded AKI extension often starts with:\n   *   30 16 80 14 <20-byte keyIdentifier>\n   * In hex, that's \"30168014\" + 40 hex chars (20 bytes).\n   *\n   * Fabric CA expects ONLY the 20-byte keyIdentifier (40 hex chars),\n   * so we strip the \"30168014\" prefix when present.\n   */\n  if (aki.startsWith(\"30168014\") && aki.length >= 8 + 40)\n    aki = aki.slice(8, 8 + 40);\n\n  return { aki, serial: x509Certificate.serialNumber };\n}\n","import * as x509 from \"@peculiar/x509\";\nimport { Crypto, CryptoKey } from \"@peculiar/webcrypto\";\nimport { stringFormat } from \"@decaf-ts/decorator-validation\";\nimport { isBrowser, MiniLogger } from \"@decaf-ts/logging\";\n\nconst crypto = new Crypto();\nx509.cryptoProvider.set(crypto);\n\nexport enum BASE_ALPHABET {\n  BASE2 = \"01\",\n  BASE8 = \"01234567\",\n  BASE11 = \"0123456789a\",\n  BASE16 = \"0123456789abcdef\",\n  BASE32 = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\",\n  BASE32_Z = \"ybndrfg8ejkmcpqxot1uwisza345h769\",\n  BASE36 = \"0123456789abcdefghijklmnopqrstuvwxyz\",\n  BASE58 = \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\",\n  BASE62 = \"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ\",\n  BASE64 = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\",\n  BASE67 = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.!~\",\n}\n\nexport type keyObject = {\n  iv: ArrayBuffer;\n  key: CryptoKey;\n};\n\nexport enum CRYPTO {\n  HASH = \"SHA-256\",\n  ITERATIONS = 1000,\n  KEYLENGTH = 48,\n  DERIVED_IV_LENGTH = 16,\n  DERIVED_KEY_LENGTH = 32, // Because SHA-256 used has a native size of 32 bytes\n  ALGORYTHM = \"AES-GCM\",\n  KEY_ALGORYTHM = \"PBKDF2\",\n}\n\nexport class BaseEncoder {\n  private readonly baseMap: Uint8Array = new Uint8Array(256);\n  private readonly base: number;\n  private readonly leader: string;\n  private readonly factor: number;\n  private readonly iFactor: number;\n\n  constructor(private alphabet: BASE_ALPHABET) {\n    if (this.alphabet.length >= 255) throw new Error(\"Alphabet too long\");\n\n    for (let j = 0; j < this.baseMap.length; j++) this.baseMap[j] = 255;\n\n    for (let i = 0; i < alphabet.length; i++) {\n      const x = alphabet.charAt(i);\n      const xc = x.charCodeAt(0);\n      if (this.baseMap[xc] !== 255) throw new Error(x + \" is ambiguous\");\n\n      this.baseMap[xc] = i;\n    }\n\n    this.base = this.alphabet.length;\n    this.leader = this.alphabet.charAt(0);\n    this.factor = Math.log(this.base) / Math.log(256); // log(BASE) / log(256), rounded up\n    this.iFactor = Math.log(256) / Math.log(this.base); // log(256) / log(BASE), rounded up\n  }\n\n  encode(source: Uint8Array | DataView | any[] | string) {\n    if (typeof source === \"string\") {\n      source = Buffer.from(source);\n    } else if (ArrayBuffer.isView(source)) {\n      source = new Uint8Array(\n        source.buffer,\n        source.byteOffset,\n        source.byteLength\n      );\n    } else if (Array.isArray(source)) {\n      source = Uint8Array.from(source);\n    }\n\n    if (source.length === 0) return \"\";\n\n    // Skip & count leading zeroes.\n    let zeroes = 0;\n    let length = 0;\n    let pbegin = 0;\n    const pend = source.length;\n    while (pbegin !== pend && source[pbegin] === 0) {\n      pbegin++;\n      zeroes++;\n    }\n    // Allocate enough space in big-endian base58 representation.\n    const size = ((pend - pbegin) * this.iFactor + 1) >>> 0;\n    const b58 = new Uint8Array(size);\n    // Process the bytes.\n    while (pbegin !== pend) {\n      let carry = source[pbegin];\n      // Apply \"b58 = b58 * 256 + ch\".\n      let i = 0;\n      for (\n        let it1 = size - 1;\n        (carry !== 0 || i < length) && it1 !== -1;\n        it1--, i++\n      ) {\n        carry += (256 * b58[it1]) >>> 0;\n        b58[it1] = carry % this.base >>> 0;\n        carry = (carry / this.base) >>> 0;\n      }\n      if (carry !== 0) throw new Error(\"Non-zero carry\");\n\n      length = i;\n      pbegin++;\n    }\n    // Skip leading zeroes in base58 result.\n    let it2 = size - length;\n    while (it2 !== size && b58[it2] === 0) it2++;\n\n    // Translate the result into a string.\n    let str = this.leader.repeat(zeroes);\n    for (; it2 < size; ++it2) {\n      str += this.alphabet.charAt(b58[it2]);\n    }\n    return str;\n  }\n\n  private decodeUnsafe(source: string): Uint8Array | undefined {\n    if (source.length === 0) return new Uint8Array(0);\n\n    let psz = 0;\n    // Skip and count leading '1's.\n    let zeroes = 0;\n    let length = 0;\n    while (source[psz] === this.leader) {\n      zeroes++;\n      psz++;\n    }\n    // Allocate enough space in big-endian base256 representation.\n    const size = ((source.length - psz) * this.factor + 1) >>> 0; // log(58) / log(256), rounded up.\n    const b256 = new Uint8Array(size);\n    // Process the characters.\n    while (source[psz]) {\n      // Decode character\n      let carry = this.baseMap[source.charCodeAt(psz)];\n      // Invalid character\n      if (carry === 255) return;\n\n      let i = 0;\n      for (\n        let it3 = size - 1;\n        (carry !== 0 || i < length) && it3 !== -1;\n        it3--, i++\n      ) {\n        carry += (this.base * b256[it3]) >>> 0;\n        b256[it3] = carry % 256 >>> 0;\n        carry = (carry / 256) >>> 0;\n      }\n      if (carry !== 0) throw new Error(\"Non-zero carry\");\n\n      length = i;\n      psz++;\n    }\n    // Skip leading zeroes in b256.\n    let it4 = size - length;\n    while (it4 !== size && b256[it4] === 0) it4++;\n\n    const vch = new Uint8Array(zeroes + (size - it4));\n    let j = zeroes;\n    while (it4 !== size) vch[j++] = b256[it4++];\n\n    return vch;\n  }\n\n  decode(source: string) {\n    const buffer = this.decodeUnsafe(source);\n    if (buffer) return buffer;\n    throw new Error(\"Non-base\" + this.base + \" character\");\n  }\n}\n\nexport class CryptoUtils {\n  private static readonly b58encoder = new BaseEncoder(BASE_ALPHABET.BASE58);\n  private static readonly logger = new MiniLogger(CryptoUtils.name);\n  private constructor() {}\n\n  static fabricIdFromCertificate(certificate: string) {\n    this.logger.debug(stringFormat(\"Parsing certificate: {0}\", certificate));\n    const cert = new x509.X509Certificate(certificate);\n    const { subject, issuer } = cert;\n    this.logger.debug(\n      stringFormat(\n        \"Certificate parsed with subject {0} and issuer {1}\",\n        subject,\n        issuer\n      )\n    );\n    return `x509::/${subject.replaceAll(\", \", \"/\")}::/${issuer.replaceAll(\", \", \"/\")}`;\n  }\n\n  static encode(str: string): string {\n    return this.b58encoder.encode(str);\n  }\n  static decode(str: string): string {\n    const decoded = this.b58encoder.decode(str);\n    const result = new TextDecoder().decode(decoded);\n    return result;\n  }\n\n  static stringToArrayBuffer(str: string) {\n    const buf = new ArrayBuffer(str.length);\n    const bufView = new Uint8Array(buf);\n    for (let i = 0, strLen = str.length; i < strLen; i++) {\n      bufView[i] = str.charCodeAt(i);\n    }\n    return buf;\n  }\n\n  private static async extractKey(\n    type: \"private\" | \"public\",\n    pem: Buffer | string,\n    usages?: any[]\n  ) {\n    const subtle = crypto.subtle;\n\n    const str = pem\n      .toString(\"utf8\")\n      .replace(\n        new RegExp(`-----BEGIN (${type.toUpperCase()} KEY|CERTIFICATE)-----`),\n        \"\"\n      )\n      .replaceAll(\"\\n\", \"\")\n      .replace(\n        new RegExp(`-----END (${type.toUpperCase()} KEY|CERTIFICATE)-----`),\n        \"\"\n      );\n    const decoded = Buffer.from(str, \"base64\").toString(\"binary\");\n    const binaryDer = this.stringToArrayBuffer(decoded);\n    const key = await subtle.importKey(\n      \"pkcs8\",\n      binaryDer,\n      {\n        name: \"ECDSA\",\n        namedCurve: \"P-256\",\n      },\n      true,\n      usages ? usages : [\"sign\"]\n    );\n\n    return key;\n  }\n\n  static async extractPrivateKey(pem: Buffer | string, usages?: any[]) {\n    return this.extractKey(\"private\", pem, usages);\n  }\n\n  static async extractPublicKey(pem: Buffer | string, usages?: any[]) {\n    return this.extractKey(\"public\", pem, usages);\n  }\n\n  static async sign(privateKey: string, data: Buffer): Promise<string> {\n    const key = await this.extractPrivateKey(privateKey);\n    const buff = (await crypto.subtle.sign(\n      {\n        name: \"ECDSA\",\n        hash: \"SHA-256\",\n      },\n      key,\n      data as any\n    )) as ArrayBuffer;\n\n    return Array.from(new Uint8Array(buff))\n      .map((b) => b.toString(16).padStart(2, \"0\"))\n      .join(\"\");\n  }\n\n  static async verify(\n    certificate: string,\n    signature: Buffer | string,\n    data: Buffer | string\n  ): Promise<boolean> {\n    const cert = new x509.X509Certificate(certificate);\n    const key = await cert.publicKey.export();\n    signature = (\n      typeof signature === \"string\" ? Buffer.from(signature, \"hex\") : signature\n    ) as Buffer;\n    data = (typeof data === \"string\" ? Buffer.from(data) : data) as Buffer;\n    return crypto.subtle.verify(\n      {\n        name: \"ECDSA\",\n        hash: \"SHA-256\",\n      },\n      key,\n      signature as any,\n      data as any\n    );\n  }\n\n  static async encrypt(certificate: string, data: string | Buffer) {\n    const cert = new x509.X509Certificate(certificate);\n    const key = await cert.publicKey.export();\n    data = (typeof data === \"string\" ? Buffer.from(data) : data) as Buffer;\n    const buff = await this.getSubtleCrypto().encrypt(\n      {\n        name: \"ECDSA\",\n      },\n      key,\n      data\n    );\n\n    return Array.from(new Uint8Array(buff))\n      .map((b) => b.toString(16).padStart(2, \"0\"))\n      .join(\"\");\n  }\n\n  private static getSubtleCrypto() {\n    return isBrowser()\n      ? (globalThis as any).window.crypto.subtle\n      : crypto.subtle;\n  }\n\n  static async decrypt(privateKey: string, data: string | Buffer) {\n    const key = await this.extractPrivateKey(privateKey);\n    data = (\n      typeof data === \"string\" ? Buffer.from(data, \"hex\") : data\n    ) as Buffer;\n    return this.getSubtleCrypto().decrypt(\n      {\n        name: \"ECDSA\",\n      },\n      key,\n      data\n    );\n  }\n\n  /**\n   * @summary Util function to get a random master key\n   *\n   * @description If data is not passed, a random ArrayBuffer will be generated\n   *\n   * @param {ArrayBuffer} data encrytion data\n   *\n   * @function getMaster\n   */\n  static async getMaster(data?: ArrayBuffer): Promise<keyObject> {\n    const textEncoder = new TextEncoder();\n    if (data === undefined) {\n      const genGenesis = crypto.randomUUID();\n      data = textEncoder.encode(genGenesis).buffer;\n    }\n\n    const importedKey = await this.getSubtleCrypto().importKey(\n      \"raw\",\n      data,\n      CRYPTO.KEY_ALGORYTHM as string,\n      false,\n      [\"deriveBits\"]\n    );\n\n    return {\n      key: importedKey,\n      iv: data!,\n    };\n  }\n\n  /**\n   * @summary Util function to derive a key from another key\n   *\n   * @param {string} salt\n   * @param {CryptoKey} key Original key\n   *\n   * @function getDerivationKey\n   */\n  static async getDerivationKey(salt: string, key: CryptoKey) {\n    const textEncoder = new TextEncoder();\n    const saltBuffer = textEncoder.encode(salt);\n    const saltHashed = await this.getSubtleCrypto().digest(\n      \"SHA-256\",\n      saltBuffer\n    );\n    const params = {\n      name: CRYPTO.KEY_ALGORYTHM as string,\n      hash: CRYPTO.HASH,\n      salt: saltHashed,\n      iterations: CRYPTO.ITERATIONS,\n    };\n    const derivation = await this.getSubtleCrypto().deriveBits(\n      params,\n      key,\n      CRYPTO.KEYLENGTH * 8\n    );\n    return this.getKey(derivation);\n  }\n\n  /**\n   * @summary Util function to get the key and IV from the CrytoKey array\n   *\n   * @param {ArrayBuffer} derivation\n   *\n   * @function getKey\n   */\n  static async getKey(derivation: ArrayBuffer) {\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    const ivlen = 16;\n    const keylen = 32;\n    const derivedKey = derivation.slice(0, keylen);\n    const iv = derivation.slice(keylen);\n    const importedEncryptionKey = await this.getSubtleCrypto().importKey(\n      \"raw\",\n      derivedKey,\n      { name: CRYPTO.ALGORYTHM as string },\n      false,\n      [\"encrypt\", \"decrypt\"]\n    );\n    return {\n      key: importedEncryptionKey,\n      iv: iv,\n    };\n  }\n\n  /**\n   * @summary Util function to decrypt data\n   *\n   * @param {string} text\n   * @param {keyObject} keyObject\n   *\n   * @function encrypt\n   */\n  static async encryptPin(\n    text: string,\n    keyObject: keyObject\n  ): Promise<ArrayBuffer> {\n    const textEncoder = new TextEncoder();\n    const textBuffer = textEncoder.encode(text);\n    const encryptedText = await this.getSubtleCrypto().encrypt(\n      { name: CRYPTO.ALGORYTHM as string, iv: keyObject.iv },\n      keyObject.key,\n      textBuffer\n    );\n    return encryptedText;\n  }\n\n  /**\n   * @summary Util function to decrypt data\n   *\n   * @param {BufferSource} encryptedText\n   * @param {keyObject} keyObject\n   *\n   * @function decrypt\n   */\n  static async decryptPin(\n    encryptedText: ArrayBuffer,\n    keyObject: keyObject\n  ): Promise<string> {\n    const textDecoder = new TextDecoder();\n    const decryptedText = await this.getSubtleCrypto().decrypt(\n      { name: CRYPTO.ALGORYTHM as string, iv: keyObject.iv },\n      keyObject.key,\n      encryptedText\n    );\n    return textDecoder.decode(decryptedText);\n  }\n}\n","import { BaseError, InternalError } from \"@decaf-ts/db-decorators\";\nimport { AuthorizationError } from \"@decaf-ts/core\";\n// import { MISSING_PRIVATE_DATA_ERROR_MESSAGE } from \"../contracts/private-data\";\n/**\n * @summary Represents an overflow error in arithmetic operations in Smart Contracts\n *\n * @param {string} msg the error message\n *\n * @class OverflowError\n * @extends InternalError\n *\n * @category Errors\n */\nexport class OverflowError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, OverflowError.name);\n  }\n}\n\n/**\n * @summary Represents a failure in balance to perform a transaction in Smart Contracts\n *\n * @param {string} msg the error message\n *\n * @class BalanceError\n * @extends InternalError\n *\n * @category Errors\n */\nexport class BalanceError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, BalanceError.name);\n  }\n}\n\n/**\n * @summary Represents a failure in balance to perform a transaction in Smart Contracts\n *\n * @param {string} msg the error message\n *\n * @class BalanceError\n * @extends InternalError\n *\n * @category Errors\n */\nexport class AllowanceError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, AllowanceError.name);\n  }\n}\n\n/**\n * @summary Represents a failure registrating new entities\n *\n * @param {string} msg the error message\n *\n * @class RegistrationError\n *\n * @categort Errors\n */\nexport class RegistrationError extends AuthorizationError {\n  constructor(msg: string | Error) {\n    super(msg, RegistrationError.name);\n  }\n}\n\n/**\n * @description Error thrown when an unsupported operation is attempted\n * @summary This error is thrown when an operation is requested that is not supported by the current\n * persistence adapter or configuration. It extends the BaseError class and sets a 500 status code.\n * @param {string|Error} msg - The error message or an Error object to wrap\n * @class UnsupportedError\n * @example\n * ```typescript\n * // Throwing an UnsupportedError\n * if (!adapter.supportsTransactions()) {\n *   throw new UnsupportedError('Transactions are not supported by this adapter');\n * }\n *\n * // Catching an UnsupportedError\n * try {\n *   await adapter.beginTransaction();\n * } catch (error) {\n *   if (error instanceof UnsupportedError) {\n *     console.error('Operation not supported:', error.message);\n *   }\n * }\n * ```\n *\n * @category Errors\n */\nexport class MissingContextError extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, MissingContextError.name, 500);\n  }\n}\n\nexport class UnauthorizedPrivateDataAccess extends BaseError {\n  constructor(msg: string | Error = \"MISSING_PRIVATE_DATA_ERROR_MESSAGE\") {\n    super(UnauthorizedPrivateDataAccess.name, msg, 403);\n  }\n}\n\n/**\n * Represents an error that occurs when a required initialization step is not performed.\n *\n * @class NotInitializedError\n * @extends BaseError\n *\n * @category Errors\n *\n * @param {string | Error} msg - The error message or an Error object to wrap.\n *\n * @throws {NotInitializedError} - Throws an error when a required initialization step is not performed.\n *\n * @example\n * ```typescript\n * // Initialize the application\n * if (!isInitialized) {\n *   throw new NotInitializedError('Application is not initialized');\n * }\n *\n * // Catching an NotInitializedError\n * try {\n *   // Perform operations that require initialization\n * } catch (error) {\n *   if (error instanceof NotInitializedError) {\n *     console.error('Initialization error:', error.message);\n *   }\n * }\n * ```\n */\nexport class NotInitializedError extends BaseError {\n  constructor(msg: string | Error) {\n    super(NotInitializedError.name, msg, 409);\n  }\n}\n\nexport class MissingPKCSS11Lib extends InternalError {\n  constructor(msg: string | Error) {\n    super(msg, MissingPKCSS11Lib.name, 500);\n  }\n}\n\nexport class EndorsementError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, EndorsementError.name, 500);\n  }\n}\n\nexport class MvccReadConflictError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, MvccReadConflictError.name, 500);\n  }\n}\n\nexport class PhantomReadConflictError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, PhantomReadConflictError.name, 500);\n  }\n}\n\nexport class EndorsementPolicyError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, EndorsementPolicyError.name, 500);\n  }\n}\n\nexport class TransactionLimitsError extends InternalError {\n  constructor(\n    message: string | Error,\n    name: string = TransactionLimitsError.name,\n    code = 590\n  ) {\n    super(message, name, code);\n  }\n}\n\nexport class TransactionTimeoutError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, TransactionTimeoutError.name, 591);\n  }\n}\n\nexport class TransactionBufferSizeError extends InternalError {\n  constructor(message: string | Error) {\n    super(message, TransactionBufferSizeError.name, 592);\n  }\n}\n","import FabricCAServices from \"fabric-ca-client\";\nimport {\n  AffiliationService,\n  IdentityService,\n  IEnrollResponse,\n  IRegisterRequest,\n  IServiceResponse,\n  TLSOptions,\n} from \"fabric-ca-client\";\nimport { User } from \"fabric-common\";\nimport { CAConfig, Credentials } from \"../../shared/types\";\nimport { Identity } from \"../../shared/model/Identity\";\nimport { AuthorizationError } from \"@decaf-ts/core\";\nimport {\n  ConflictError,\n  InternalError,\n  NotFoundError,\n} from \"@decaf-ts/db-decorators\";\nimport { CoreUtils } from \"../utils\";\nimport { CA_ROLE } from \"./constants\";\nimport { CryptoUtils } from \"../crypto\";\nimport {\n  CertificateResponse,\n  FabricIdentity,\n  GetCertificatesRequest,\n  IdentityResponse,\n} from \"../../shared/fabric-types\";\nimport { RegistrationError } from \"../../shared/errors\";\nimport { LoggedClass, Logging } from \"@decaf-ts/logging\";\n\n/**\n * @description Hyperledger Fabric CA identity types.\n * @summary Enumerates the supported identity types recognized by Fabric CA for registration and identity management.\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.client\n */\nexport enum HFCAIdentityType {\n  PEER = \"peer\",\n  ORDERER = \"orderer\",\n  CLIENT = \"client\",\n  USER = \"user\",\n  ADMIN = \"admin\",\n}\n/**\n * @description Key/value attribute used during CA registration.\n * @summary Represents an attribute entry that can be attached to a Fabric CA identity during registration, optionally marking it for inclusion in ecert.\n * @interface IKeyValueAttribute\n * @template T\n * @param {string} name - Attribute name.\n * @param {string} value - Attribute value.\n * @param {boolean} [ecert] - Whether the attribute should be included in the enrollment certificate (ECert).\n * @memberOf module:for-fabric.client\n */\nexport interface IKeyValueAttribute {\n  name: string;\n  value: string;\n  ecert?: boolean;\n}\n\n/**\n * @description Standard Fabric CA identity attribute keys.\n * @summary Enumerates well-known Fabric CA attribute keys that can be assigned to identities for delegations and permissions.\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.client\n */\nexport enum HFCAIdentityAttributes {\n  HFREGISTRARROLES = \"hf.Registrar.Roles\",\n  HFREGISTRARDELEGATEROLES = \"hf.Registrar.DelegateRoles\",\n  HFREGISTRARATTRIBUTES = \"hf.Registrar.Attributes\",\n  HFINTERMEDIATECA = \"hf.IntermediateCA\",\n  HFREVOKER = \"hf.Revoker\",\n  HFAFFILIATIONMGR = \"hf.AffiliationMgr\",\n  HFGENCRL = \"hf.GenCRL\",\n}\n\n/**\n * @description Service wrapper for interacting with a Fabric CA.\n * @summary Provides high-level operations for managing identities against a Hyperledger Fabric Certificate Authority, including registration, enrollment, revocation, and administrative queries. Encapsulates lower-level Fabric CA client calls with consistent logging and error mapping.\n * @param {CAConfig} caConfig - Connection and TLS configuration for the target CA.\n * @class FabricEnrollmentService\n * @example\n * // Register and enroll a new user\n * const svc = new FabricEnrollmentService({\n *   url: 'https://localhost:7054',\n *   caName: 'Org1CA',\n *   tls: { trustedRoots: ['/path/to/ca.pem'], verify: false },\n *   caCert: '/path/to/admin/certDir',\n *   caKey: '/path/to/admin/keyDir'\n * });\n * await svc.register({ userName: 'alice', password: 's3cr3t' }, false, 'org1.department1', CA_ROLE.USER);\n * const id = await svc.enroll('alice', 's3cr3t');\n * @mermaid\n * sequenceDiagram\n *   autonumber\n *   participant App\n *   participant Svc as FabricEnrollmentService\n *   participant CA as Fabric CA\n *   App->>Svc: register(credentials, ...)\n *   Svc->>CA: register(request, adminUser)\n *   CA-->>Svc: enrollmentSecret\n *   Svc-->>App: secret\n *   App->>Svc: enroll(enrollmentId, secret)\n *   Svc->>CA: enroll({enrollmentID, secret})\n *   CA-->>Svc: certificates\n *   Svc-->>App: Identity\n */\nexport class FabricEnrollmentService extends LoggedClass {\n  private ca?: FabricCAServices;\n\n  private certificateService?: any;\n\n  private affiliationService?: AffiliationService;\n\n  private identityService?: IdentityService;\n\n  private client?: any;\n\n  private user?: User;\n\n  constructor(private caConfig: CAConfig) {\n    CoreUtils.getCryptoSuite(\n      caConfig.hsm\n        ? {\n            software: false,\n            lib: caConfig.hsm.library,\n            slot: caConfig.hsm.slot,\n            label: caConfig.hsm.tokenLabel,\n            pin: String(caConfig.hsm.pin),\n          }\n        : undefined\n    );\n    super();\n  }\n\n  protected async User(): Promise<User> {\n    if (this.user) return this.user;\n    const { caName, caCert, caKey, url, hsm } = this.caConfig;\n    const log = this.log.for(this.User);\n    log.debug(`Creating CA user for ${caName} at ${url}`);\n    log.debug(`Retrieving CA certificate from ${caCert}`);\n    const certificate = await CoreUtils.getFirstDirFileNameContent(caCert);\n    let key: string | undefined;\n    if (!hsm) {\n      if (!caKey) {\n        throw new InternalError(\n          `Missing caKey configuration for CA ${caName}. Provide a key directory or configure HSM support.`\n        );\n      }\n      log.debug(`Retrieving CA key from ${caKey}`);\n      key = await CoreUtils.getFirstDirFileNameContent(caKey);\n    } else {\n      log.debug(\n        `Using HSM configuration for CA ${caName} with library ${hsm.library}`\n      );\n    }\n    log.debug(`Loading Admin user for ca ${caName}`);\n    this.user = await CoreUtils.getCAUser(\"admin\", key, certificate, caName, {\n      hsm,\n    });\n    return this.user;\n  }\n\n  protected async CA(): Promise<FabricCAServices> {\n    if (this.ca) return this.ca;\n    const log = this.log.for(this.CA);\n    const { url, tls, caName } = this.caConfig;\n\n    // FOR Some Reason the verification fails need to investigate this works for now\n    // eslint-disable-next-line prefer-const\n    let { trustedRoots, verify } = tls as TLSOptions;\n\n    const root = (trustedRoots as string[])[0] as string;\n    log.debug(`Retrieving CA certificate from ${root}. cwd: ${process.cwd()}`);\n\n    const certificate = await CoreUtils.getFileContent(root);\n    log.debug(`Creating CA Client for CA ${caName} under ${url}`);\n    this.ca = new FabricCAServices(\n      url,\n      {\n        trustedRoots: Buffer.from(certificate),\n        verify,\n      } as TLSOptions,\n      caName\n    );\n    return this.ca;\n  }\n\n  protected async Client(): Promise<{ newCertificateService: any }> {\n    if (this.client) return this.client;\n    const ca = await this.CA();\n    this.client = (ca as any)[\"_FabricCAServices\"];\n    return this.client;\n  }\n\n  protected async Certificate() {\n    if (!this.certificateService)\n      this.certificateService = (await this.Client()).newCertificateService();\n    return this.certificateService;\n  }\n\n  protected async Affiliations() {\n    if (!this.affiliationService)\n      this.affiliationService = (await this.CA()).newAffiliationService();\n    return this.affiliationService;\n  }\n\n  protected async Identities() {\n    if (!this.identityService)\n      this.identityService = (await this.CA()).newIdentityService();\n    return this.identityService;\n  }\n\n  /**\n   * @description Retrieve certificates from the CA.\n   * @summary Calls the CA certificate service to list certificates, optionally mapping to PEM strings only.\n   * @param {GetCertificatesRequest} [request] - Optional filter request for certificate lookup.\n   * @param {boolean} [doMap=true] - When true, returns array of PEM strings; otherwise returns full response object.\n   * @return {Promise<string[] | CertificateResponse>} Array of PEM strings or the full certificate response.\n   */\n  async getCertificates(\n    request?: GetCertificatesRequest,\n    doMap = true\n  ): Promise<string[] | CertificateResponse> {\n    const certificateService = await this.Certificate();\n    const user = await this.User();\n    const log = this.log.for(this.getCertificates);\n    log.debug(\n      `Retrieving certificates${request ? ` for ${request.id}` : \"\"} for CA ${this.caConfig.caName}`\n    );\n    const response: CertificateResponse = (\n      await certificateService.getCertificates(request || {}, user)\n    ).result;\n    log.debug(\n      `Found ${response.certs.length} certificates: ${JSON.stringify(response)}`\n    );\n    return doMap ? response.certs.map((c) => c.PEM) : response;\n  }\n\n  /**\n   * @description List identities registered in the CA.\n   * @summary Queries the CA identity service to fetch all identities and returns the list as FabricIdentity objects.\n   * @return {Promise<FabricIdentity[]>} The list of identities registered in the CA.\n   */\n  async getIdentities(): Promise<FabricIdentity[]> {\n    const identitiesService = await this.Identities();\n    const log = this.log.for(this.getIdentities);\n    log.debug(`Retrieving Identities under CA ${this.caConfig.caName}`);\n    const response: IdentityResponse = (\n      await identitiesService.getAll(await this.User())\n    ).result;\n    log.debug(\n      `Found ${response.identities.length} Identities: ${JSON.stringify(response)}`\n    );\n    return response.identities;\n  }\n\n  protected parseError(e: Error) {\n    const regexp = /.*code:\\s(\\d+).*?message:\\s[\"'](.+)[\"']/gs;\n    const match = regexp.exec(e.message);\n    if (!match) return new RegistrationError(e);\n    const [, code, message] = match;\n    switch (code) {\n      case \"74\":\n      case \"71\":\n        return new ConflictError(message);\n      case \"20\":\n        return new AuthorizationError(message);\n      default:\n        return new RegistrationError(message);\n    }\n  }\n\n  /**\n   * @description Retrieve affiliations from the CA.\n   * @summary Queries the CA for the list of affiliations available under the configured CA.\n   * @return {string} The affiliations result payload.\n   */\n  async getAffiliations() {\n    const affiliationService = await this.Affiliations();\n    const log = this.log.for(this.getAffiliations);\n    log.debug(`Retrieving Affiliations under CA ${this.caConfig.caName}`);\n    const response = (await affiliationService.getAll(await this.User()))\n      .result;\n    log.debug(\n      `Found ${response.a.length} Affiliations: ${JSON.stringify(response)}`\n    );\n    return response;\n  }\n\n  /**\n   * @description Read identity details from the CA by enrollment ID.\n   * @summary Retrieves and validates a single identity, throwing NotFoundError when missing.\n   * @param {string} enrollmentId - Enrollment ID to lookup.\n   * @return {Promise<FabricIdentity>} The identity details stored in the CA.\n   */\n  async read(enrollmentId: string) {\n    const ca = await this.CA();\n    const user = await this.User();\n    let result: IServiceResponse;\n    try {\n      result = await ca.newIdentityService().getOne(enrollmentId, user);\n    } catch (e: any) {\n      throw new NotFoundError(\n        `Couldn't find enrollment with id ${enrollmentId}: ${e}`\n      );\n    }\n\n    if (!result.success)\n      throw new NotFoundError(\n        `Couldn't find enrollment with id ${enrollmentId}: ${result.errors.join(\"\\n\")}`\n      );\n\n    return result.result as FabricIdentity;\n  }\n\n  /**\n   * @description Register a new identity with the CA.\n   * @summary Submits a registration request for a new enrollment ID, returning the enrollment secret upon success.\n   * @param {Credentials} model - Credentials containing userName and password for the new identity.\n   * @param {boolean} [isSuperUser=false] - Whether to register the identity as a super user.\n   * @param {string} [affiliation=\"\"] - Affiliation string (e.g., org1.department1).\n   * @param {CA_ROLE | string} [userRole] - Role to assign to the identity.\n   * @param {IKeyValueAttribute} [attrs] - Optional attributes to attach to the identity.\n   * @param {number} [maxEnrollments] - Maximum number of enrollments allowed for the identity.\n   * @return {Promise<string>} The enrollment secret for the registered identity.\n   */\n  async register(\n    model: Credentials,\n    isSuperUser: boolean = false,\n    affiliation: string = \"\",\n    userRole?: CA_ROLE | string,\n    attrs?: IKeyValueAttribute,\n    maxEnrollments?: number\n  ): Promise<string> {\n    let registration: string;\n    const log = this.log.for(this.register);\n    try {\n      const { userName, password } = model;\n      const ca = await this.CA();\n      const user = await this.User();\n      const props = {\n        enrollmentID: userName as string,\n        enrollmentSecret: password,\n        affiliation: affiliation,\n        userRole: userRole,\n        attrs: attrs,\n        maxEnrollments: maxEnrollments,\n      } as IRegisterRequest;\n      registration = await ca.register(props, user);\n      log.info(\n        `Registration for ${userName} created with user type ${userRole ?? \"Undefined Role\"} ${isSuperUser ? \"as super user\" : \"\"}`\n      );\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return registration;\n  }\n\n  protected static identityFromEnrollment(\n    enrollment: IEnrollResponse,\n    mspId: string\n  ): Identity {\n    const { certificate, key, rootCertificate } = enrollment;\n    const log = Logging.for(FabricEnrollmentService, {}).for(\n      this.identityFromEnrollment\n    );\n    log.debug(\n      `Generating Identity from certificate ${certificate} in msp ${mspId}`\n    );\n    const clientId = CryptoUtils.fabricIdFromCertificate(certificate);\n    const id = CryptoUtils.encode(clientId);\n    log.debug(`Identity ${clientId} and encodedId ${id}`);\n    const now = new Date();\n    return new Identity({\n      id: id,\n      credentials: {\n        id: id,\n        certificate: certificate,\n        privateKey: key.toBytes(),\n        rootCertificate: rootCertificate,\n        createdOn: now,\n        updatedOn: now,\n      },\n      mspId: mspId,\n      createdOn: now,\n      updatedOn: now,\n    });\n  }\n\n  /**\n   * @description Enroll an identity with the CA using a registration secret.\n   * @summary Exchanges the enrollment ID and secret for certificates, returning a constructed Identity model.\n   * @param {string} enrollmentId - Enrollment ID to enroll.\n   * @param {string} registration - Enrollment secret returned at registration time.\n   * @return {Promise<Identity>} The enrolled identity object with credentials.\n   */\n  async enroll(enrollmentId: string, registration: string) {\n    let identity: Identity;\n    const log = this.log.for(this.enroll);\n    try {\n      const ca = await this.CA();\n      log.debug(`Enrolling ${enrollmentId}`);\n      const enrollment: IEnrollResponse = await ca.enroll({\n        enrollmentID: enrollmentId,\n        enrollmentSecret: registration,\n      });\n      identity = FabricEnrollmentService.identityFromEnrollment(\n        enrollment,\n        this.caConfig.caName\n      );\n      log.info(\n        `Successfully enrolled ${enrollmentId} under ${this.caConfig.caName} as ${identity.id}`\n      );\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return identity;\n  }\n\n  /**\n   * @description Register and enroll a new identity in one step.\n   * @summary Registers a new enrollment ID with the CA and immediately exchanges the secret to enroll, returning the created Identity.\n   * @param {Credentials} model - Credentials for the new identity containing userName and password.\n   * @param {boolean} [isSuperUser=false] - Whether to register the identity as a super user.\n   * @param {string} [affiliation=\"\"] - Affiliation string (e.g., org1.department1).\n   * @param {CA_ROLE | string} [userRole] - Role to assign to the identity.\n   * @param {IKeyValueAttribute} [attrs] - Optional attributes to attach to the identity.\n   * @param {number} [maxEnrollments] - Maximum number of enrollments allowed for the identity.\n   * @return {Promise<Identity>} The enrolled identity.\n   */\n  async registerAndEnroll(\n    model: Credentials,\n    isSuperUser: boolean = false,\n    affiliation: string = \"\",\n    userRole?: CA_ROLE | string,\n    attrs?: IKeyValueAttribute,\n    maxEnrollments?: number\n  ): Promise<Identity> {\n    const registration = await this.register(\n      model,\n      isSuperUser,\n      affiliation,\n      userRole,\n      attrs,\n      maxEnrollments\n    );\n    const { userName } = model;\n    return this.enroll(userName as string, registration);\n  }\n\n  /**\n   * Revokes the enrollment of an identity with the specified enrollment ID.\n   *\n   * @param enrollmentId - The enrollment ID of the identity to be revoked.\n   *\n   * @returns A Promise that resolves to the result of the revocation operation.\n   *\n   * @throws {NotFoundError} If the enrollment with the specified ID does not exist.\n   * @throws {InternalError} If there is an error during the revocation process.\n   */\n  async revoke(enrollmentId: string) {\n    const ca = await this.CA();\n    const user = await this.User();\n    const identity = await this.read(enrollmentId);\n    if (!identity)\n      throw new NotFoundError(\n        `Could not find enrollment with id ${enrollmentId}`\n      );\n    let result: IServiceResponse;\n    try {\n      result = await ca.revoke(\n        { enrollmentID: identity.id, reason: \"User Deletation\" },\n        user\n      );\n    } catch (e: unknown) {\n      throw new InternalError(\n        `Could not revoke enrollment with id ${enrollmentId}: ${e}`\n      );\n    }\n    if (!result.success)\n      throw new InternalError(\n        `Could not revoke enrollment with id ${enrollmentId}: ${result.errors.join(\"\\n\")}`\n      );\n    return result;\n  }\n}\n","import { IRegisterRequest, IKeyValueAttribute } from \"fabric-ca-client\";\nimport { CA_ROLE } from \"./constants\";\nimport {\n  min,\n  minlength,\n  Model,\n  required,\n} from \"@decaf-ts/decorator-validation\";\nimport { ValidationError } from \"@decaf-ts/db-decorators\";\n\nexport class RegistrationRequestBuilder extends Model {\n  @required()\n  affiliation: string = \"\";\n  @minlength(1)\n  attrs?: IKeyValueAttribute[];\n  @required()\n  enrollmentID!: string;\n  @required()\n  enrollmentSecret!: string;\n  @min(0)\n  maxEnrollments?: number;\n  @required()\n  role!: string;\n\n  build(): IRegisterRequest {\n    const errs = this.hasErrors();\n    if (errs) throw new ValidationError(errs.toString());\n    const response: IRegisterRequest = {\n      enrollmentID: this.enrollmentID,\n      enrollmentSecret: this.enrollmentSecret,\n      role: this.role,\n      affiliation: this.affiliation,\n    };\n    if (typeof this.maxEnrollments !== \"undefined\")\n      response.maxEnrollments = this.maxEnrollments;\n    if (this.attrs) response.attrs = this.attrs;\n    return response;\n  }\n\n  setAffiliation(value: string) {\n    this.affiliation = value;\n    return this;\n  }\n\n  addAttr(attr: IKeyValueAttribute) {\n    this.attrs = this.attrs || [];\n    this.attrs.push(attr);\n    return this;\n  }\n\n  setAttrs(value: IKeyValueAttribute[]) {\n    this.attrs = value;\n    return this;\n  }\n\n  setEnrollmentID(value: string) {\n    this.enrollmentID = value;\n    return this;\n  }\n\n  setEnrollmentSecret(value: string) {\n    this.enrollmentSecret = value;\n    return this;\n  }\n\n  setMaxEnrollments(value: number) {\n    this.maxEnrollments = value;\n    return this;\n  }\n\n  setRole(value: CA_ROLE | string) {\n    this.role = value;\n    return this;\n  }\n}\n","/**\n * Enum representing the events emitted by an ERC20 contract.\n *\n * @remarks\n * This enum is used to identify the specific events that can be emitted by an ERC20 contract.\n * The events are named according to the EIP-20 standard.\n */\nexport enum ERC20Events {\n  /**\n   * Emitted when a `transfer` function is called successfully.\n   *\n   * @param from - The address of the sender.\n   * @param to - The address of the recipient.\n   * @param value - The amount of tokens transferred.\n   */\n  TRANSFER = \"Transfer\",\n\n  /**\n   * Emitted when an `approve` function is called successfully.\n   *\n   * @param owner - The address of the token owner.\n   * @param spender - The address of the approved spender.\n   * @param value - The amount of tokens approved for the spender.\n   */\n  APPROVAL = \"Approval\",\n}\n","import { Model, type ModelArg } from \"@decaf-ts/decorator-validation\";\nimport { column, createdAt, updatedAt } from \"@decaf-ts/core\";\nimport { version } from \"@decaf-ts/db-decorators\";\nimport { description, uses } from \"@decaf-ts/decoration\";\nimport { FabricFlavour } from \"../constants\";\n\n@uses(FabricFlavour)\nexport class FabricBaseModel extends Model {\n  @description(\"Stores the original timestamp of creation\")\n  @column()\n  @createdAt()\n  createdAt!: Date;\n\n  @description(\"Stores the timestamp of the last update\")\n  @column()\n  @updatedAt()\n  updatedAt!: Date;\n\n  @description(\"Stores the version of the model\")\n  @column()\n  @version()\n  version!: number;\n\n  constructor(arg?: ModelArg<FabricBaseModel>) {\n    super(arg);\n  }\n}\n","import { type ModelArg } from \"@decaf-ts/decorator-validation\";\nimport { column, createdBy, updatedBy } from \"@decaf-ts/core\";\nimport { description, uses } from \"@decaf-ts/decoration\";\nimport { FabricFlavour } from \"../constants\";\nimport { FabricBaseModel } from \"./FabricBaseModel\";\n\n@uses(FabricFlavour)\nexport abstract class FabricIdentifiedBaseModel extends FabricBaseModel {\n  @description(\"Stores the creator\")\n  @column()\n  @createdBy()\n  createdBy!: string;\n\n  @description(\"Stores the user that last updated the model\")\n  @column()\n  @updatedBy()\n  updatedBy!: string;\n\n  protected constructor(arg?: ModelArg<FabricIdentifiedBaseModel>) {\n    super(arg);\n  }\n}\n","import { Model } from \"@decaf-ts/decorator-validation\";\nimport { Constructor, Metadata } from \"@decaf-ts/decoration\";\nimport { FabricModelKeys } from \"../constants\";\nimport { SegregatedModel } from \"../types\";\nimport { DBKeys } from \"@decaf-ts/db-decorators\";\nimport { CollectionResolver, MirrorMetadata } from \"../decorators\";\n\nModel.prototype.isShared = function isShared<M extends Model>(\n  this: M\n): boolean {\n  return Model.isShared(this.constructor as Constructor<M>);\n};\n\nModel.prototype.isPrivate = function isPrivate<M extends Model>(\n  this: M\n): boolean {\n  return Model.isPrivate(this.constructor as Constructor<M>);\n};\n\nModel.prototype.segregate = function segregate<M extends Model>(\n  this: M\n): SegregatedModel<M> {\n  return Model.segregate(this);\n};\n\n(Model as any).segregate = function segregate<M extends Model>(\n  model: M\n): SegregatedModel<M> {\n  if (!Model.isTransient(model)) return { model: model };\n  const decoratedProperties =\n    Metadata.getAttributes(model.constructor as any) || [];\n\n  const transientProps = Metadata.get(\n    model.constructor as any,\n    DBKeys.TRANSIENT\n  );\n  const privateProperties = Metadata.get(\n    model.constructor as any,\n    FabricModelKeys.PRIVATE\n  );\n  const sharedProperties = Metadata.get(\n    model.constructor as any,\n    FabricModelKeys.SHARED\n  );\n\n  const result: SegregatedModel<M> = {\n    model: {} as Record<keyof M, any>,\n    public: {} as Record<keyof M, any>,\n    transient: {} as Record<keyof M, any>,\n    privates: {} as Record<keyof M, any>,\n    shared: {} as Record<keyof M, any>,\n  };\n\n  const transientKeys = Object.keys(transientProps || {});\n  const privateKeys = Object.keys(privateProperties || {});\n  const sharedKeys = Object.keys(sharedProperties || {});\n\n  // const pkKey = Model.pk(model.constructor as any);\n  for (const key of decoratedProperties) {\n    const value = model[key as keyof M];\n    const isTransient = transientKeys.includes(key);\n    const isPublic = !isTransient;\n    const isPrivate = privateKeys.includes(key);\n    const isShared = sharedKeys.includes(key);\n    // const isPrimaryKey = key === pkKey;\n\n    if (isTransient || isPrivate || isShared) {\n      result.transient = result.transient || ({} as any);\n      (result.transient as any)[key] = value;\n    }\n    if (isPrivate) {\n      result.privates = result.privates || ({} as any);\n      (result.privates as any)[key] = value;\n    }\n    if (isShared) {\n      result.shared = result.shared || ({} as any);\n      (result.shared as any)[key] = value;\n    }\n    if (isPublic) {\n      result.public = (result.public || {}) as any;\n      (result.public as any)[key] = value;\n    }\n  }\n\n  result.model = Model.build(result.public, model.constructor.name);\n  return result as SegregatedModel<M>;\n}.bind(Model);\n\n(Model as any).isPrivate = function isPrivate<M extends Model>(\n  model: M | Constructor<M>\n): boolean {\n  return !!Metadata.get(\n    typeof model !== \"function\" ? (model.constructor as any) : model,\n    FabricModelKeys.PRIVATE\n  );\n}.bind(Model);\n\n(Model as any).isShared = function isShared<M extends Model>(\n  model: M | Constructor<M>\n): boolean {\n  return !!Metadata.get(\n    typeof model !== \"function\" ? (model.constructor as any) : model,\n    FabricModelKeys.SHARED\n  );\n}.bind(Model);\n\n(Model as any).mirrored = function mirrored<M extends Model>(\n  model: M | Constructor<M>\n): boolean {\n  return Metadata.get(\n    typeof model !== \"function\" ? (model.constructor as any) : model,\n    Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.MIRROR)\n  );\n}.bind(Model);\n\n(Model as any).ownerOf = function ownerOf<M extends Model>(\n  model: M\n): string | undefined {\n  const meta = Metadata.get(\n    model.constructor as any,\n    Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.OWNED_BY)\n  );\n  if (!meta) return undefined;\n  return model[meta as keyof M] as string;\n}.bind(Model);\n\n(Model as any).mirroredAt = function mirroredAt<M extends Model>(\n  model: M | Constructor<M>\n): MirrorMetadata | undefined {\n  model = typeof model !== \"function\" ? (model.constructor as any) : model;\n  return Metadata.get(\n    model as any,\n    Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.MIRROR)\n  );\n}.bind(Model);\n\n(Model as any).collectionsFor = function collectionsFor<M extends Model>(\n  model: M | Constructor<M>\n): {\n  privateCols: (string | CollectionResolver)[];\n  sharedCols: (string | CollectionResolver)[];\n} {\n  const privateKeys: string[] = [FabricModelKeys.PRIVATE] as string[];\n  const sharedKeys: string[] = [FabricModelKeys.SHARED] as string[];\n\n  const privateKey = Metadata.key(...privateKeys);\n  const sharedKey = Metadata.key(...sharedKeys);\n\n  const constr = typeof model === \"function\" ? model : model.constructor;\n\n  const privateMeta: { collections: string[] } = Metadata.get(\n    constr as any,\n    privateKey\n  );\n  const sharedMeta: { collections: string[] } = Metadata.get(\n    constr as any,\n    sharedKey\n  );\n\n  return {\n    privateCols: privateMeta?.collections || [],\n    sharedCols: sharedMeta?.collections || [],\n  };\n}.bind(Model);\n","import {\n  AuthorizationError,\n  Repo,\n  Context,\n  UnsupportedError,\n  Repository,\n  ContextOf,\n} from \"@decaf-ts/core\";\nimport {\n  generated,\n  InternalError,\n  NotFoundError,\n  onCreate,\n  onDelete,\n  onRead,\n  onUpdate,\n  readonly,\n  transient,\n  ValidationError,\n  DBKeys,\n  DBOperations,\n  on,\n} from \"@decaf-ts/db-decorators\";\nimport { Model, required } from \"@decaf-ts/decorator-validation\";\nimport { FabricModelKeys } from \"./constants\";\nimport type { Context as HLContext } from \"fabric-contract-api\";\nimport { ClientIdentity } from \"fabric-shim-api\";\nimport { FabricERC20Contract } from \"../contracts/erc20/erc20contract\";\nimport {\n  apply,\n  Constructor,\n  Decoration,\n  metadata,\n  Metadata,\n  prop,\n  propMetadata,\n} from \"@decaf-ts/decoration\";\nimport { FabricFlags } from \"./types\";\nimport { toPascalCase } from \"@decaf-ts/logging\";\nimport { FabricContractFlags } from \"../contracts/types\";\nimport \"../shared/overrides\";\nimport { type FabricContractContext } from \"../contracts/ContractContext\";\n\n/**\n * @description Extracts the MSP ID from either a string or ClientIdentity object\n * @param identity - The identity value which can be a string MSP ID or ClientIdentity object\n * @returns The MSP ID as a string, or undefined if not available\n */\nexport function extractMspId(\n  identity: string | ClientIdentity | undefined\n): string | undefined {\n  if (!identity) return undefined;\n  if (typeof identity === \"string\") return identity;\n  return identity.getMSPID();\n}\n\n/**\n * Decorator for marking methods that require ownership authorization.\n * Checks the owner of the token before allowing the method to be executed.\n *\n * @example\n * ```typescript\n * class TokenContract extends Contract {\n *   @Owner()\n *   async Mint(ctx: Context, amount: number) {\n *     // Mint token logic\n *   }\n * }\n * ```\n *\n * @returns {MethodDecorator} A method decorator that checks ownership authorization.\n */\nexport function Owner() {\n  return function (\n    target: any,\n    propertyKey: string,\n    descriptor: PropertyDescriptor\n  ) {\n    const originalMethod = descriptor.value;\n\n    descriptor.value = async function (\n      this: FabricERC20Contract,\n      ...args: any[]\n    ) {\n      const ctx: HLContext = args[0];\n      const acountId = ctx.clientIdentity.getID();\n\n      const select = await (this as FabricERC20Contract)[\n        \"tokenRepository\"\n      ].select();\n\n      const tokens = await select.execute(ctx);\n\n      if (tokens.length == 0) {\n        throw new NotFoundError(\"No tokens avaialble\");\n      }\n\n      if (tokens.length > 1) {\n        throw new NotFoundError(`To many token available : ${tokens.length}`);\n      }\n\n      if (tokens[0].owner != acountId) {\n        throw new AuthorizationError(\n          `User not authorized to run ${propertyKey} on the token`\n        );\n      }\n\n      return await originalMethod.apply(this, args);\n    };\n\n    return descriptor;\n  };\n}\n\nexport async function ownedByOnCreate<\n  M extends Model<boolean>,\n  R extends Repo<M>,\n  V,\n>(\n  this: R,\n  context: ContextOf<R>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const { stub } = context as any;\n\n  const allowGenerationOverride =\n    context.getOrUndefined(\"allowGenerationOverride\") || false;\n\n  const creator = await stub.getCreator();\n  let owner = creator.mspid;\n  context.log.info(\n    `Expected mspid to be ${model[key]} | ${owner}. \\n Using allowGenerationOverride: ${allowGenerationOverride}`\n  );\n\n  if (allowGenerationOverride) owner = model[key] ? model[key] : owner;\n\n  const setOwnedByKeyValue = function <M extends Model>(\n    target: M,\n    propertyKey: string,\n    value: string | number | bigint\n  ) {\n    Object.defineProperty(target, propertyKey, {\n      enumerable: true,\n      writable: false,\n      configurable: true,\n      value: value,\n    });\n  };\n\n  setOwnedByKeyValue(model, key as string, owner);\n}\n\nexport function ownedBy() {\n  function ownedBy() {\n    return function (obj: any, attribute?: any) {\n      return apply(\n        required(),\n        generated(),\n        readonly(),\n        onCreate(ownedByOnCreate),\n        propMetadata(\n          Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.OWNED_BY),\n          attribute\n        )\n      )(obj, attribute);\n    };\n  }\n\n  return Decoration.for(FabricModelKeys.OWNED_BY)\n    .define({\n      decorator: ownedBy,\n      args: [],\n    })\n    .apply();\n}\n\nexport async function transactionIdOnCreate<\n  M extends Model<boolean>,\n  R extends Repo<M>,\n  V,\n>(\n  this: R,\n  context: ContextOf<R>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const { stub } = context as any;\n  model[key] = stub.getTxID();\n}\n\nexport function transactionId() {\n  function transactionId() {\n    return function (obj: any, attribute?: any) {\n      return apply(\n        required(),\n        readonly(),\n        onCreate(transactionIdOnCreate),\n        onUpdate(transactionIdOnCreate),\n        propMetadata(\n          Metadata.key(\n            FabricModelKeys.FABRIC,\n            attribute,\n            FabricModelKeys.TRANSACTION_ID\n          ),\n          attribute\n        )\n      )(obj, attribute);\n    };\n  }\n\n  return Decoration.for(FabricModelKeys.TRANSACTION_ID)\n    .define({\n      decorator: transactionId,\n      args: [],\n    })\n    .apply();\n}\n\nexport type MirrorCondition = (msp: string) => boolean;\n\nexport type MirrorMetadata = {\n  condition?: MirrorCondition;\n  resolver: CollectionResolver | string;\n  mspId: string;\n};\n\nexport async function evalMirrorMetadata<M extends Model>(\n  model: M,\n  resolver: undefined | string | CollectionResolver,\n  ctx: Context<FabricContractFlags>\n) {\n  let collection: CollectionResolver | string | undefined = resolver;\n  if (typeof collection !== \"string\") {\n    try {\n      const owner =\n        Model.ownerOf(model) || ctx.get(\"stub\").getCreator().toString();\n      if (resolver && typeof resolver === \"function\")\n        collection = await resolver(model, owner, ctx);\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to resolve collection mirror name: ${e}`);\n    }\n  }\n\n  if (!collection || typeof collection !== \"string\")\n    throw new InternalError(\n      `No collection found model ${model.constructor.name}`\n    );\n  return collection;\n}\n\nexport async function createMirrorHandler<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const collection = await evalMirrorMetadata(model, data.resolver, context);\n  const fabricCtx = context as FabricContractContext;\n  const sourceModel = model;\n  // Put mirror flags directly on context so adapter.prepare() and adapter.create() can see them\n  fabricCtx.put(\"mirror\" as any, true);\n  fabricCtx.put(\"mirrorCollection\" as any, collection);\n  try {\n    const repo = this.override(\n      Object.assign({}, (this as any)._overrides, {\n        mirror: true,\n        mirrorCollection: collection,\n        ignoreValidation: true,\n        ignoreHandlers: true,\n      } as any)\n    );\n    const mirror = await repo.create(sourceModel, context);\n    context.logger.info(\n      `Mirror for ${Model.tableName(this.class)} created with ${Model.pk(model) as string}: ${mirror[Model.pk(model)]}`\n    );\n  } finally {\n    // Clean up mirror flags from context\n    fabricCtx.put(\"mirror\" as any, undefined);\n    fabricCtx.put(\"mirrorCollection\" as any, undefined);\n  }\n}\n\nexport async function updateMirrorHandler<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const collection = await evalMirrorMetadata(model, data.resolver, context);\n  const fabricCtx = context as FabricContractContext;\n  const sourceModel = model;\n  fabricCtx.put(\"mirror\" as any, true);\n  fabricCtx.put(\"mirrorCollection\" as any, collection);\n  try {\n    const repo = this.override(\n      Object.assign({}, (this as any)._overrides, {\n        mirror: true,\n        mirrorCollection: collection,\n        ignoreValidation: true,\n        ignoreHandlers: true,\n        applyUpdateValidation: false,\n        mergeForUpdate: false,\n      } as any)\n    );\n    await repo.update(sourceModel, context);\n    context.logger.info(\n      `Mirror for ${Model.tableName(this.class)} updated: ${(model as any)[Model.pk(model)]}`\n    );\n  } finally {\n    fabricCtx.put(\"mirror\" as any, undefined);\n    fabricCtx.put(\"mirrorCollection\" as any, undefined);\n  }\n}\n\nexport async function deleteMirrorHandler<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const collection = await evalMirrorMetadata(model, data.resolver, context);\n  const fabricCtx = context as FabricContractContext;\n  fabricCtx.put(\"mirror\" as any, true);\n  fabricCtx.put(\"mirrorCollection\" as any, collection);\n  fabricCtx.put(\"segregated\" as any, collection);\n  try {\n    const pkProp = Model.pk(model) as keyof M;\n    const id = model[pkProp];\n    const repo = this.override(\n      Object.assign({}, (this as any)._overrides, {\n        segregated: collection,\n        mirror: true,\n        ignoreValidation: true,\n        ignoreHandlers: true,\n      } as any)\n    );\n    try {\n      await repo.delete(id as any, context);\n    } catch {\n      // May already be deleted by adapter.deleteSegregatedCollections\n    }\n    context.logger.info(\n      `Mirror for ${Model.tableName(this.class)} deleted: ${String(id)}`\n    );\n  } finally {\n    fabricCtx.put(\"mirror\" as any, undefined);\n    fabricCtx.put(\"mirrorCollection\" as any, undefined);\n    fabricCtx.put(\"segregated\" as any, undefined);\n  }\n}\n\nexport async function mirrorWriteGuard<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  key: keyof M,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  model: M\n): Promise<void> {\n  const msp = extractMspId(\n    context.get(\"identity\") as string | ClientIdentity | undefined\n  );\n  if (!msp) return;\n  if (msp === data.mspId || (data.condition && data.condition(msp))) {\n    throw new AuthorizationError(\n      `Organization ${msp} is not authorized to modify mirrored data`\n    );\n  }\n}\n\nexport async function readMirrorHandler<\n  M extends Model,\n  R extends Repository<M, any>,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: MirrorMetadata,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  const msp = extractMspId(\n    context.get(\"identity\") as string | ClientIdentity | undefined\n  );\n\n  if (!msp) return;\n\n  const collection = await evalMirrorMetadata(model, data.resolver, context);\n  const fabricCtx = context as FabricContractContext;\n  const matches = msp === data.mspId || (data.condition && data.condition(msp));\n\n  if (matches) {\n    context.logger.info(\n      `Mirror read: MSP ${msp} matches, routing reads to mirror collection ${collection}`\n    );\n    // Route reads exclusively through the mirror collection\n    fabricCtx.put(\"mirror\" as any, true);\n    fabricCtx.put(\"mirrorCollection\" as any, collection);\n    fabricCtx.put(\"fullySegregated\", true);\n    fabricCtx.readFrom(collection);\n  }\n  // When MSP does NOT match, normal read flow — all data is in public state\n}\n\nexport function mirror(\n  collection: CollectionResolver | string,\n  mspIdOrCondition?: string | MirrorCondition,\n  condition?: MirrorCondition\n) {\n  const isConditionOnly =\n    typeof mspIdOrCondition !== \"string\" && Boolean(mspIdOrCondition);\n  const mspId = isConditionOnly\n    ? undefined\n    : (mspIdOrCondition as string | undefined);\n  const cond = isConditionOnly\n    ? (mspIdOrCondition as MirrorCondition)\n    : condition;\n\n  function mirror(\n    resolver: CollectionResolver | string,\n    mspId: string,\n    condition?: MirrorCondition\n  ) {\n    const meta: MirrorMetadata = {\n      condition: condition,\n      mspId: mspId,\n      resolver: resolver,\n    };\n    return apply(\n      metadata(\n        Metadata.key(FabricModelKeys.FABRIC, FabricModelKeys.MIRROR),\n        meta\n      ),\n      // Read handler runs early (priority 30) to set up context before any reads\n      onRead(readMirrorHandler as any, meta, { priority: 30 }),\n      // Write guards — reject matching MSPs before any processing\n      onCreate(mirrorWriteGuard as any, meta, { priority: 20 }),\n      onUpdate(mirrorWriteGuard as any, meta, { priority: 20 }),\n      onDelete(mirrorWriteGuard as any, meta, { priority: 20 }),\n      // Mirror sync handlers — write full model after other handlers (priority 100)\n      onCreate(createMirrorHandler as any, meta, { priority: 100 }),\n      onUpdate(updateMirrorHandler as any, meta, { priority: 100 }),\n      onDelete(deleteMirrorHandler as any, meta, { priority: 100 })\n    );\n  }\n\n  return Decoration.for(FabricModelKeys.MIRROR)\n    .define({\n      decorator: mirror,\n      args: [collection, mspId, cond],\n    })\n    .apply();\n}\n\nexport type CollectionResolver = <M extends Model>(\n  model: M | Constructor<M>,\n  msp?: string,\n  ...args: any[]\n) => string;\n\nexport const ModelCollection: CollectionResolver = <M extends Model>(\n  model: M | Constructor<M>,\n  mspId?: string\n) => {\n  const orgName =\n    mspId || (typeof model !== \"function\" ? Model.ownerOf(model) : undefined);\n  const constr = typeof model === \"function\" ? model : model.constructor;\n  if (!orgName)\n    throw new InternalError(\n      `Model ${constr.name} is not owned by any organization. did you use @ownedBy() (or provide the name)?`\n    );\n  return `${toPascalCase(constr.name)}${orgName ? toPascalCase(orgName) : \"\"}`;\n};\n\nexport function NamespaceCollection(namespace: string): CollectionResolver {\n  return <M extends Model>(model: M | Constructor<M>, mspId?: string) => {\n    const orgName =\n      mspId || (typeof model !== \"function\" ? Model.ownerOf(model) : undefined);\n    const constr = typeof model === \"function\" ? model : model.constructor;\n    if (!orgName)\n      throw new InternalError(\n        `Model ${constr.name} is not owned by any organization. did you use @ownedBy() (or provide the name)?`\n      );\n    return `${namespace}${orgName ? toPascalCase(orgName) : \"\"}`;\n  };\n}\n\nexport const ImplicitPrivateCollection: CollectionResolver = <M extends Model>(\n  model: M | Constructor<M>,\n  mspId?: string\n) => {\n  const orgName =\n    mspId || (typeof model !== \"function\" ? Model.ownerOf(model) : undefined);\n  if (!orgName)\n    throw new InternalError(\n      `Model ${model.constructor.name} is not owned by any organization. did you use @ownedBy() (or provide the name)?`\n    );\n  return `__${toPascalCase(orgName)}PrivateCollection`;\n};\n\nexport type SegregatedDataMetadata = {\n  collections: string | CollectionResolver;\n};\n\n/**\n * @description Priority for early collection extraction (before pk generation at priority 60)\n * @summary This priority ensures collections are registered in context before any sequence\n * operations occur, allowing sequences to be replicated to private/shared collections.\n */\nexport const SEGREGATED_COLLECTION_EXTRACTION_PRIORITY = 35;\n\nexport function applySegregationFlags<M extends Model>(\n  clazz: M,\n  collections: string[],\n  ctx: any\n) {\n  // Register collections early using readFrom - this allows sequence code\n  // to know which collections to replicate to during pk generation\n  if (collections.length > 0) {\n    (ctx as FabricContractContext).readFrom(collections);\n  }\n\n  // Check if model is fully segregated (all non-pk properties are private/shared/transient).\n  // Use Model.segregate() which is the canonical way to determine what's transient,\n  // rather than reading DBKeys.TRANSIENT metadata which may not accumulate correctly\n  // when class-level @privateData applies decorators iteratively.\n  if (!ctx.isFullySegregated && collections.length) {\n    if (!hasPublicProperties(clazz.constructor as Constructor<M>)) {\n      ctx.markFullySegregated();\n    }\n  }\n}\n\nexport async function applyMirrorFlags<M extends Model>(\n  clazz: Constructor<M>,\n  msp: string | undefined,\n  ctx: FabricContractContext\n) {\n  if (!msp) return;\n  const mirrorMeta = Model.mirroredAt(clazz);\n  if (!mirrorMeta) return;\n  const matches =\n    msp === mirrorMeta.mspId ||\n    (mirrorMeta.condition && mirrorMeta.condition(msp));\n  if (!matches) return;\n  const collection = await evalMirrorMetadata(\n    new clazz(),\n    mirrorMeta.resolver,\n    ctx\n  );\n  // Mirror MSP matches — route reads exclusively through the mirror\n  // collection. Clear any previously registered collections so queries\n  // go ONLY to the mirror, not to the regular private/shared ones.\n  ctx.put(\"segregateRead\", undefined);\n  ctx.put(\"segregateReadStack\", undefined);\n  ctx.put(\"fullySegregated\", true);\n  ctx.put(\"mirror\" as any, true);\n  ctx.put(\"mirrorCollection\" as any, collection);\n  ctx.readFrom(collection);\n}\n\nfunction hasPublicProperties<M extends Model>(clazz: Constructor<M>): boolean {\n  const attributes = Metadata.getAttributes(clazz) || [];\n  const pk = Model.pk(clazz);\n  const transientMeta = Metadata.get(clazz as any, DBKeys.TRANSIENT) || {};\n  const privateMeta =\n    Metadata.get(clazz as any, Metadata.key(FabricModelKeys.PRIVATE)) || {};\n  const sharedMeta =\n    Metadata.get(clazz as any, Metadata.key(FabricModelKeys.SHARED)) || {};\n\n  return attributes.some((attr) => {\n    if (attr === pk) return false;\n    if (attr in transientMeta) return false;\n    if (attr in privateMeta) return false;\n    if (attr in sharedMeta) return false;\n    return true;\n  });\n}\n\n/**\n * @description Early handler to extract and register collections in context\n * @summary Runs with priority < 40 to extract collection names before pk generation (priority 60).\n * This allows FabricContractSequence to know which collections to replicate to.\n * @template M - Type that extends Model\n * @param {ContextOf<Repository<M, any>>} context - The execution context\n * @param {SegregatedDataMetadata | SegregatedDataMetadata[]} data - The segregated data metadata\n * @param {string | string[]} keys - The property key(s) being segregated\n * @param {M} model - The model instance\n * @return {Promise<void>}\n */\nexport async function extractSegregatedCollections<M extends Model>(\n  this: Repository<M, any>,\n  context: ContextOf<typeof this>,\n  data: SegregatedDataMetadata | SegregatedDataMetadata[],\n  keys: keyof M | (keyof M)[],\n  model: M\n): Promise<void> {\n  const dataArray = (\n    Array.isArray(data) ? data : [data]\n  ) as SegregatedDataMetadata[];\n\n  const msp =\n    Model.ownerOf(model) ||\n    extractMspId(\n      context.get(\"identity\") as string | ClientIdentity | undefined\n    );\n  if (!msp) {\n    // Can't extract collections without MSP, will be caught by later handlers\n    return;\n  }\n\n  const collections: string[] = [];\n  for (const metadata of dataArray) {\n    const collectionResolver = metadata.collections;\n    const collection =\n      typeof collectionResolver === \"string\"\n        ? collectionResolver\n        : collectionResolver(model, msp, context);\n    if (collection && !collections.includes(collection)) {\n      collections.push(collection);\n    }\n  }\n  applySegregationFlags(model, collections, context);\n\n  // Store segregation metadata per-sequence so FabricContractSequence can decide\n  // where to store/replicate sequence records (public vs private/shared).\n  //\n  // - `@pk()` sequences use the shared name `${table}_pk` (no id component).\n  // - `@sequence()` / persistent `@version(true)` sequences are per-model-instance:\n  //   `${table}_${id}_${property}`.\n  const keyArray = (Array.isArray(keys) ? keys : [keys]) as (keyof M)[];\n  const pkKey = Model.pk(model.constructor as any) as keyof M;\n  const pkSeqName = Model.sequenceName(model, \"pk\");\n\n  const idValue = (model as any)[pkKey as any];\n  const canBuildPerInstance =\n    typeof idValue !== \"undefined\" && idValue !== null;\n\n  // Always union collections for the pk sequence when the model uses segregated data.\n  (context as any).setSequenceSegregation(\n    pkSeqName,\n    (context as any).isFullySegregated,\n    collections\n  );\n\n  // For per-property sequences, only register when we can compute an id-scoped name.\n  // This keeps sequences constrained to the collections the attribute exists in.\n  if (canBuildPerInstance) {\n    for (const k of keyArray) {\n      const propSeqName = Model.sequenceName(\n        model,\n        String(idValue),\n        String(k)\n      );\n      (context as any).setSequenceSegregation(\n        propSeqName,\n        (context as any).isFullySegregated,\n        collections\n      );\n    }\n  }\n}\n\nexport async function segregatedDataOnCreate<M extends Model>(\n  this: Repository<M, any>,\n  context: ContextOf<typeof this>,\n  data: SegregatedDataMetadata | SegregatedDataMetadata[],\n  keys: keyof M | (keyof M)[],\n  model: M\n): Promise<void> {\n  const dataArray = (\n    Array.isArray(data) ? data : [data]\n  ) as SegregatedDataMetadata[];\n  const keyArray = (Array.isArray(keys) ? keys : [keys]) as (keyof M)[];\n  if (keyArray.length !== dataArray.length)\n    throw new InternalError(\n      `Segregated data keys and metadata length mismatch`\n    );\n\n  const msp =\n    Model.ownerOf(model) ||\n    extractMspId(\n      context.get(\"identity\") as string | ClientIdentity | undefined\n    );\n  if (!msp)\n    throw new ValidationError(\n      `There's no assigned organization for model ${model.constructor.name}`\n    );\n\n  const collectionResolver = dataArray[0].collections;\n  const collection =\n    typeof collectionResolver === \"string\"\n      ? collectionResolver\n      : collectionResolver(model, msp, context);\n\n  // Validate all keys resolve to the same collection\n  keyArray.forEach((_k, i) => {\n    const c =\n      typeof dataArray[i].collections === \"string\"\n        ? dataArray[i].collections\n        : dataArray[i].collections(model, msp, context);\n    if (c !== collection)\n      throw new UnsupportedError(\n        `Segregated data collection mismatch: ${c} vs ${collection}`\n      );\n  });\n\n  const keyStrings = keyArray.map((key) => String(key));\n  // Store the segregated model — prepare() will filter to collection-specific fields\n  (context as FabricContractContext).writeTo(collection, keyStrings);\n}\n\nexport async function segregatedDataOnRead<M extends Model>(\n  this: Repository<M, any>,\n  context: Context<FabricFlags>,\n  data: SegregatedDataMetadata | SegregatedDataMetadata[],\n  keys: keyof M | (keyof M)[],\n  model: M\n): Promise<void> {\n  const dataArray = (\n    Array.isArray(data) ? data : [data]\n  ) as SegregatedDataMetadata[];\n  const keyArray = (Array.isArray(keys) ? keys : [keys]) as (keyof M)[];\n  if (keyArray.length !== dataArray.length)\n    throw new InternalError(\n      `Segregated data keys and metadata length mismatch`\n    );\n\n  const msp = Model.ownerOf(model) || extractMspId(context.get(\"identity\"));\n  if (!msp)\n    throw new ValidationError(\n      `There's no assigned organization for model ${model.constructor.name}`\n    );\n\n  const collectionResolver = dataArray[0].collections;\n  const collection =\n    typeof collectionResolver === \"string\"\n      ? collectionResolver\n      : await collectionResolver(model, msp, context);\n\n  (context as FabricContractContext).readFrom(collection);\n}\n\nexport async function segregatedDataOnUpdate<M extends Model>(\n  this: Repository<M, any>,\n  context: ContextOf<typeof this>,\n  data: SegregatedDataMetadata | SegregatedDataMetadata[],\n  key: keyof M | (keyof M)[],\n  model: M,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  oldModel: M\n): Promise<void> {\n  const dataArray = (\n    Array.isArray(data) ? data : [data]\n  ) as SegregatedDataMetadata[];\n  const keyArray = (Array.isArray(key) ? key : [key]) as (keyof M)[];\n  if (keyArray.length !== dataArray.length)\n    throw new InternalError(\n      `Segregated data keys and metadata length mismatch`\n    );\n\n  const msp =\n    Model.ownerOf(model) ||\n    extractMspId(\n      context.get(\"identity\") as string | ClientIdentity | undefined\n    );\n  if (!msp)\n    throw new ValidationError(\n      `There's no assigned organization for model ${model.constructor.name}`\n    );\n\n  const collectionResolver = dataArray[0].collections;\n  const collection =\n    typeof collectionResolver === \"string\"\n      ? collectionResolver\n      : collectionResolver(model, msp, context);\n\n  keyArray.forEach((k, i) => {\n    const c =\n      typeof dataArray[i].collections === \"string\"\n        ? dataArray[i].collections\n        : dataArray[i].collections(model, msp, context);\n    if (c !== collection)\n      throw new UnsupportedError(\n        `Segregated data collection mismatch: ${c} vs ${collection}`\n      );\n  });\n\n  const keyStrings = (keyArray as (keyof M)[]).map((key) => String(key));\n  // Store the original model — prepare() will filter to collection-specific fields\n  (context as FabricContractContext).writeTo(collection, keyStrings);\n}\n\nexport async function segregatedDataOnDelete<\n  M extends Model,\n  R extends Repository<M, any>,\n  V extends SegregatedDataMetadata,\n>(\n  this: R,\n  context: ContextOf<R>,\n  data: V | V[],\n  key: (keyof M)[],\n  model: M\n): Promise<void> {\n  const dataArray = (Array.isArray(data) ? data : [data]) as V[];\n  const keyArray = (Array.isArray(key) ? key : [key]) as (keyof M)[];\n  if (keyArray.length !== dataArray.length)\n    throw new InternalError(\n      `Segregated data keys and metadata length mismatch`\n    );\n\n  const msp =\n    Model.ownerOf(model) ||\n    extractMspId(\n      context.get(\"identity\") as string | ClientIdentity | undefined\n    );\n  if (!msp)\n    throw new ValidationError(\n      `There's no assigned organization for model ${model.constructor.name}`\n    );\n\n  const collectionResolver = dataArray[0].collections;\n  const collection =\n    typeof collectionResolver === \"string\"\n      ? collectionResolver\n      : collectionResolver(model, msp, context);\n\n  (context as FabricContractContext).readFrom(collection);\n}\n\nfunction segregated(\n  collection: string | CollectionResolver,\n  type: FabricModelKeys.PRIVATE | FabricModelKeys.SHARED,\n  filter?: (propName: string) => boolean\n) {\n  return function innerSegregated(target: object, propertyKey?: any) {\n    function segregatedDec(target: object, propertyKey?: any) {\n      const key = Metadata.key(type, propertyKey);\n      const constr: Constructor = target.constructor as Constructor;\n\n      const meta = Metadata.get(constr as Constructor, key) || {};\n      const collections = new Set(meta.collections || []);\n      collections.add(collection);\n      meta.collections = [...collections];\n      Metadata.set(constr as Constructor, key, meta);\n\n      const constrMeta = Metadata.get(constr as Constructor, type) || {};\n      const constrCollections = new Set(constrMeta.collections || []);\n      constrCollections.add(collection);\n      constrMeta.collections = [...constrCollections];\n      Metadata.set(constr as Constructor, type, constrMeta);\n\n      const transientMeta =\n        Metadata.get(constr as Constructor, DBKeys.TRANSIENT) || {};\n      const updatedTransientMeta = {\n        ...transientMeta,\n        [propertyKey as any]: {},\n      };\n      Metadata.set(\n        constr as Constructor,\n        DBKeys.TRANSIENT,\n        updatedTransientMeta\n      );\n    }\n\n    const decs: any[] = [];\n    if (!propertyKey) {\n      // decorated at the class level\n      const properties = Metadata.getAttributes(target as Constructor);\n      properties?.forEach((p) => {\n        if (!filter || filter(p)) {\n          segregated(collection, type)((target as any).prototype, p);\n        }\n      });\n      return target;\n    } else {\n      const groupName =\n        typeof collection === \"string\" ? collection : collection.toString();\n      // Use different group names for extraction vs data handlers to prevent merging\n      const extractGroupName = `${groupName}:extract`;\n      const dataGroupName = `${groupName}:data`;\n      const earlyExtractionMeta = { collections: collection };\n      const earlyExtractionGroupSort = {\n        priority: SEGREGATED_COLLECTION_EXTRACTION_PRIORITY,\n        group: extractGroupName,\n      };\n      decs.push(\n        prop(),\n        transient(),\n        segregatedDec,\n        // Early extraction handlers - run BEFORE pk generation (priority 60)\n        // This ensures collections are registered in context for sequence replication\n        // We register for each operation explicitly to ensure proper handler lookup\n        on(\n          DBOperations.ALL,\n          extractSegregatedCollections as any,\n          earlyExtractionMeta,\n          earlyExtractionGroupSort\n        ),\n        // Main handlers for segregated data operations (priority 95)\n        onCreate(\n          segregatedDataOnCreate,\n          { collections: collection },\n          {\n            priority: 95,\n            group: dataGroupName,\n          }\n        ),\n        onRead(\n          segregatedDataOnRead as any,\n          { collections: collection },\n          {\n            priority: 95,\n            group: dataGroupName,\n          }\n        ),\n        onUpdate(\n          segregatedDataOnUpdate as any,\n          { collections: collection },\n          {\n            priority: 95,\n            group: dataGroupName,\n          }\n        ),\n        onDelete(\n          segregatedDataOnDelete as any,\n          { collections: collection },\n          {\n            priority: 95,\n            group: dataGroupName,\n          }\n        )\n      );\n    }\n    return apply(...decs)(target, propertyKey);\n  };\n}\n\nexport function privateData(\n  collection: string | CollectionResolver = ImplicitPrivateCollection\n) {\n  function privateData(collection: string | CollectionResolver) {\n    return segregated(collection, FabricModelKeys.PRIVATE);\n  }\n\n  return Decoration.for(FabricModelKeys.PRIVATE)\n    .define({\n      decorator: privateData,\n      args: [collection],\n    })\n    .apply();\n}\n\nexport function sharedData(collection: string | CollectionResolver) {\n  function sharedData(collection: string | CollectionResolver) {\n    return segregated(collection, FabricModelKeys.SHARED);\n  }\n\n  return Decoration.for(FabricModelKeys.SHARED)\n    .define({\n      decorator: sharedData,\n      args: [collection],\n    })\n    .apply();\n}\n","/* eslint-disable @typescript-eslint/no-require-imports */\nimport { Constructor, Metadata } from \"@decaf-ts/decoration\";\nimport {\n  JSONSerializer,\n  Model,\n  ModelKeys,\n} from \"@decaf-ts/decorator-validation\";\n\n/**\n * @description Recursively sorts object keys without reordering arrays\n * @param {any} obj - The value to process\n * @return {any} A copy with sorted object keys but preserved array order\n */\nexport function sortKeysOnlyRecursive(obj: any): any {\n  if (obj === null || typeof obj !== \"object\") return obj;\n  if (Array.isArray(obj)) return obj.map(sortKeysOnlyRecursive);\n  if (obj.constructor !== Object) return obj;\n  return Object.keys(obj)\n    .sort()\n    .reduce((acc: Record<string, any>, key) => {\n      acc[key] = sortKeysOnlyRecursive(obj[key]);\n      return acc;\n    }, {});\n}\n\n/**\n * @description Deterministic JSON serializer for Fabric models\n * @summary Ensures stable, deterministic JSON output by sorting object keys recursively before stringification, which is important for Fabric endorsement and hashing. Extends JSONSerializer to plug into existing Decaf model serialization flow.\n * @template M - The Decaf Model subtype serialized by this instance\n * @param {void} [constructor] No public constructor arguments\n * @class DeterministicSerializer\n * @example\n * const serializer = new DeterministicSerializer<MyModel>();\n * const json = serializer.serialize(model);\n * const rebuilt = serializer.deserialize(json);\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant DS as DeterministicSerializer\n *   Caller->>DS: serialize(model)\n *   DS->>DS: preSerialize(model)\n *   DS->>DS: sort-keys-recursive\n *   DS->>DS: json-stringify-deterministic\n *   DS-->>Caller: string\n *   Caller->>DS: deserialize(string)\n *   DS-->>Caller: model\n */\nexport class DeterministicSerializer<\n  M extends Model,\n> extends JSONSerializer<M> {\n  constructor() {\n    super();\n  }\n  protected override preSerialize(model: M) {\n    // TODO: nested preserialization (so increase performance when deserializing)\n    // TODO: Verify why there is no metadata\n    const toSerialize: Record<string, any> = Object.assign({}, model);\n    let metadata;\n    try {\n      metadata = Metadata.modelName(model.constructor as Constructor);\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (error: unknown) {\n      metadata = undefined;\n    }\n    toSerialize[ModelKeys.ANCHOR] = metadata || model.constructor.name;\n\n    const preSerialize = function preSerialize(\n      this: DeterministicSerializer<any>,\n      obj: any\n    ): any {\n      // eslint-disable-next-line @typescript-eslint/no-this-alias\n      const self = this;\n      if (typeof obj !== \"object\") return obj;\n      if (Array.isArray(obj)) return obj.map((o) => preSerialize.call(self, o));\n      return this.preSerialize.call(this, obj);\n    }.bind(this);\n\n    Model.relations(model).forEach((r) => {\n      toSerialize[r] = preSerialize(toSerialize[r]);\n    });\n    return toSerialize;\n  }\n\n  /**\n   * @summary Rebuilds a model from a serialization\n   * @param {string} str\n   *\n   * @throws {Error} If it fails to parse the string, or to build the model\n   */\n  override deserialize(str: string): M {\n    const deserialization = JSON.parse(str);\n    const className = deserialization[ModelKeys.ANCHOR];\n    if (!className)\n      throw new Error(\"Could not find class reference in serialized model\");\n    const model: M = Model.build(deserialization, className) as unknown as M;\n    return model;\n  }\n\n  /**\n   * @description Serialize a model into a deterministic JSON string\n   * @summary Prepares the model with preSerialize, sorts keys recursively, and stringifies deterministically for stable ordering\n   * @param {M} model - The model instance to serialize\n   * @return {string} Deterministic JSON representation of the model\n   */\n  override serialize(model: M): string {\n    const stringify = require(\"json-stringify-deterministic\");\n    return stringify(sortKeysOnlyRecursive(this.preSerialize(model)));\n  }\n}\n","import { BulkCrudOperationKeys, OperationKeys } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Generates a Fabric event name from components\n * @summary Creates a standardized event name by joining table, event, and optional owner with underscores\n * @param {string} table - The table/collection name\n * @param {OperationKeys | BulkCrudOperationKeys | string} event - The event type\n * @param {string} [owner] - Optional owner identifier\n * @return {string} The generated event name in format \"table_event\" or \"table_event_owner\"\n * @function generateFabricEventName\n * @memberOf module:for-fabric.shared\n */\nexport function generateFabricEventName(\n  table: string,\n  event: OperationKeys | BulkCrudOperationKeys | string,\n  owner?: string\n) {\n  const params = [table, event];\n  if (owner) params.push(owner);\n  return params.join(\"_\");\n}\n\n/**\n * @description Parses a Fabric event name into its components\n * @summary Splits an event name by underscores and extracts table, event, and optional owner\n * @param {string} name - The event name to parse\n * @return {{table: string, event: OperationKeys | BulkCrudOperationKeys | string, owner: string}} The parsed components as a structured object\n * @throws {InternalError} If the event name format is invalid\n * @function parseEventName\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant Parser as parseEventName\n *   Caller->>Parser: parseEventName(name)\n *   Parser->>Parser: split name by \"_\"\n *   alt parts length invalid\n *     Parser-->>Caller: throw InternalError\n *   else\n *     Parser-->>Caller: { table, event, owner? }\n *   end\n * @memberOf module:for-fabric.shared\n */\nexport function parseEventName(name: string): {\n  table?: string;\n  event: OperationKeys | BulkCrudOperationKeys | string;\n  owner?: string;\n} {\n  const parts = name.split(\"_\");\n  if (parts.length < 2 || parts.length > 3)\n    return { table: undefined, event: name, owner: undefined };\n  return {\n    table: parts[0],\n    event: parts[1],\n    owner: parts[2],\n  } as {\n    table: string;\n    event: OperationKeys | BulkCrudOperationKeys | string;\n    owner?: string;\n  };\n}\n","import { stringFormat } from \"@decaf-ts/decorator-validation\";\nimport { OverflowError } from \"./errors\";\nimport { ValidationError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Overflow-safe addition operation\n * @summary Adds two numbers and verifies no overflow by reverse-checking the operands\n * @param {number} a - First operand\n * @param {number} b - Second operand\n * @return {number} The sum of a and b\n * @function add\n * @throws {OverflowError} on addition overflow\n * @memberOf module:for-fabric.shared\n */\nexport function add(a: number, b: number): number {\n  const c = a + b;\n  if (a !== c - b || b !== c - a) {\n    throw new OverflowError(`Addition overflow: ${a} + ${b}`);\n  }\n  return c;\n}\n\n/**\n * @description Overflow-safe subtraction operation\n * @summary Subtracts b from a and validates no overflow by reverse-checking the operands\n * @param {number} a - Minuend\n * @param {number} b - Subtrahend\n * @return {number} The difference a - b\n * @function sub\n * @throws {OverflowError} on subtaction overflow\n * @memberOf module:for-fabric.shared\n */\nexport function sub(a: number, b: number): number {\n  const c = a - b;\n  if (a !== c + b || b !== a - c) {\n    throw new OverflowError(`Subtraction overflow: ${a} - ${b}`);\n  }\n  return c;\n}\n\n/**\n * @summary Safe Integer Parse\n *\n * @param {string} string\n *\n * @function safeParseInt\n *\n * @throws {ValidationError} if parseInt returns NaN\n *\n * @memberOf module:for-fabric.shared\n */\nexport function safeParseInt(string: string): number {\n  // Regular expression to check if string only have digits\n  const digitRegex = /^\\d+$/;\n  if (!digitRegex.test(string)) {\n    throw new ValidationError(\n      stringFormat(\"Failed to parse: {0}\", \"string contains digits\")\n    );\n  }\n  const parsedint = parseInt(string);\n  if (isNaN(parsedint)) {\n    throw new ValidationError(\n      stringFormat(\"Failed to parse: {0}\", \"string is not a parsable integer\")\n    );\n  }\n  return parsedint;\n}\n","import {\n  JSONSerializer,\n  Model,\n  ModelKeys,\n} from \"@decaf-ts/decorator-validation\";\nimport { Constructor, Metadata } from \"@decaf-ts/decoration\";\nimport { sortKeysOnlyRecursive } from \"./DeterministicSerializer\";\n\nexport class SimpleDeterministicSerializer<\n  M extends Model,\n> extends JSONSerializer<M> {\n  constructor() {\n    super();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  override deserialize(str: string, tableName?: string): M {\n    const deserialization = JSON.parse(str);\n    // const className = tableName;\n    // if (!className)\n    //   throw new Error(\"Could not find class reference in serialized model\");\n\n    // // this will return undefined values\n    // const model: M = Model.build(deserialization, className) as unknown as M;\n\n    // // Populate Model\n    // const processedDesealization = Object.keys(model).reduce(\n    //   (accum: M, key) => {\n    //     (accum as Record<string, any>)[key] =\n    //       deserialization[Repository.column(accum, key)];\n    //     return accum;\n    //   },\n    //   model\n    // );\n\n    // const result = Model.build(\n    //   processedDesealization,\n    //   className\n    // ) as unknown as M;\n\n    // return result;\n    return deserialization;\n  }\n\n  override serialize(model: M, putAnchor = true): string {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    const stringify = require(\"json-stringify-deterministic\");\n    const preSerialization = this.preSerialize(model, putAnchor);\n    return stringify(sortKeysOnlyRecursive(preSerialization));\n  }\n\n  protected override preSerialize(model: M, putAnchor: boolean = true) {\n    // TODO: nested preserialization (so increase performance when deserializing)\n    // TODO: Verify why there is no metadata\n    const toSerialize: Record<string, any> = Object.assign({}, model);\n    let metadata;\n    try {\n      metadata = Metadata.modelName(model.constructor as Constructor);\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (error: unknown) {\n      metadata = undefined;\n    }\n    if (putAnchor)\n      toSerialize[ModelKeys.ANCHOR] = metadata || model.constructor.name;\n\n    function preSerialize(\n      this: SimpleDeterministicSerializer<any>,\n      obj: any\n    ): any {\n      if (typeof obj !== \"object\") return obj;\n      if (Array.isArray(obj)) return obj.map(preSerialize);\n      return this.preSerialize(obj);\n    }\n    Model.relations(model).forEach((r) => {\n      toSerialize[r] = preSerialize.call(this, toSerialize[r]);\n    });\n    return toSerialize;\n  }\n}\n","import {\n  AuthorizationError,\n  ClientBasedService,\n  Context,\n  MaybeContextualArg,\n  PersistenceKeys,\n} from \"@decaf-ts/core\";\nimport FabricCAServices, {\n  AffiliationService,\n  IAttributeRequest,\n  IdentityService,\n  IEnrollResponse,\n  IIdentityRequest,\n  IRegisterRequest,\n  IRevokeRequest,\n  IServiceResponse,\n  TLSOptions,\n} from \"fabric-ca-client\";\nimport { CAConfig, Credentials } from \"../../shared/types\";\nimport {\n  ConflictError,\n  InternalError,\n  NotFoundError,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { CoreUtils, getAkiAndSerialFromCert } from \"../utils\";\nimport {\n  CertificateResponse,\n  FabricIdentity,\n  GetCertificatesRequest,\n  IdentityResponse,\n} from \"../../shared/fabric-types\";\nimport { User } from \"fabric-common\";\nimport { RegistrationError } from \"../../shared/errors\";\nimport { CA_ROLE } from \"./constants\";\nimport { IKeyValueAttribute } from \"./FabricEnrollmentService\";\nimport { Identity } from \"../../shared/index\";\nimport { CryptoUtils } from \"../crypto\";\n\nexport class FabricIdentityService extends ClientBasedService<\n  FabricCAServices,\n  CAConfig\n> {\n  protected _user!: User;\n\n  constructor() {\n    super();\n  }\n\n  protected get rootClient(): { newCertificateService: any } {\n    return (this.client as any)[\"_FabricCaServices\"] as any;\n  }\n\n  protected get user(): User {\n    if (!this._user)\n      throw new InternalError(\n        \"Fabric identity service not properly setup: missing user\"\n      );\n    return this._user;\n  }\n\n  protected get certificates() {\n    return this.rootClient.newCertificateService();\n  }\n\n  protected get affiliations(): AffiliationService {\n    return this.client.newAffiliationService();\n  }\n\n  protected get identities(): IdentityService {\n    return this.client.newIdentityService();\n  }\n\n  protected async getUser(cfg: CAConfig, ctx: Context) {\n    const log = ctx.logger.for(this.getUser);\n    const { caName, caCert, caKey, url, hsm } = cfg;\n\n    log.info(`Creating CA user for ${caName} at ${url}`);\n    log.verbose(`Retrieving CA certificate from ${caCert}`);\n    const certificate = await CoreUtils.getFirstDirFileNameContent(caCert);\n    let key: string | undefined;\n    if (!hsm) {\n      if (!caKey) {\n        throw new InternalError(\n          `Missing caKey configuration for CA ${caName}. Provide a key directory or configure HSM support.`\n        );\n      }\n      log.debug(`Retrieving CA key from ${caKey}`);\n      key = await CoreUtils.getFirstDirFileNameContent(caKey);\n    } else {\n      log.debug(\n        `Using HSM configuration for CA ${caName} with library ${hsm.library}`\n      );\n    }\n    log.debug(`Loading Admin user for ca ${caName}`);\n    this._user = await CoreUtils.getCAUser(\"admin\", key, certificate, caName, {\n      hsm,\n    });\n    return this._user;\n  }\n\n  override async initialize(\n    ...args: MaybeContextualArg<any>\n  ): Promise<{ config: CAConfig; client: FabricCAServices }> {\n    const { log, ctx } = (\n      await this.logCtx(args, PersistenceKeys.INITIALIZATION, true)\n    ).for(this.initialize);\n    const [config] = args;\n    if (!config) throw new InternalError(\"Missing Fabric CA configuration\");\n\n    const { url, tls, caName } = config;\n    log.info(`Initializing CA Client for CA ${config.caName} at ${config.url}`);\n    const { trustedRoots, verify } = tls as TLSOptions;\n\n    const root = (trustedRoots as string[])[0] as string;\n    log.debug(`Retrieving CA certificate from ${root}. cwd: ${process.cwd()}`);\n\n    const certificate = await CoreUtils.getFileContent(root);\n\n    log.debug(`CA Certificate: ${certificate.toString()}`);\n\n    const client = new FabricCAServices(\n      url,\n      {\n        trustedRoots: Buffer.from(certificate),\n        verify,\n      } as TLSOptions,\n      caName\n    );\n\n    const user = await this.getUser(config, ctx);\n    log.debug(`CA user loaded: ${user.getName()}`);\n    return {\n      config,\n      client,\n    };\n  }\n\n  async getCertificates(...args: MaybeContextualArg<any>): Promise<string[]>;\n  async getCertificates(\n    request: GetCertificatesRequest,\n    ...args: MaybeContextualArg<any>\n  ): Promise<string[]>;\n  async getCertificates<MAP extends boolean>(\n    doMap: MAP,\n    ...args: MaybeContextualArg<any>\n  ): Promise<MAP extends false ? CertificateResponse : string[]>;\n  async getCertificates<MAP extends boolean>(\n    request: GetCertificatesRequest,\n    doMap: MAP,\n    ...args: MaybeContextualArg<any>\n  ): Promise<MAP extends false ? CertificateResponse : string[]>;\n  async getCertificates<MAP extends boolean>(\n    request?: GetCertificatesRequest | MAP,\n    doMap: MAP = true as MAP,\n    ...args: MaybeContextualArg<any>\n  ): Promise<MAP extends false ? CertificateResponse : string[]> {\n    if (request instanceof Context) {\n      args = [request];\n      doMap = true as MAP;\n      request = undefined;\n    } else if (typeof request === \"boolean\") {\n      doMap = request;\n      request = undefined;\n    } else if (typeof doMap !== \"boolean\") {\n      args = [doMap as MaybeContextualArg<any>, ...args];\n      doMap = true as MAP;\n    }\n\n    const { log } = (await this.logCtx(args, OperationKeys.READ, true)).for(\n      this.getCertificates\n    );\n    log.debug(\n      `Retrieving certificates${request ? ` for ${request.id}` : \"\"} for CA ${this.config.caName}`\n    );\n    const response: CertificateResponse = (\n      await this.certificates.getCertificates(request || {}, this.user)\n    ).result;\n    log.verbose(`Found ${response.certs.length} certificates`);\n    log.debug(response.certs);\n    return (\n      doMap ? response.certs.map((c) => c.PEM) : response\n    ) as MAP extends false ? CertificateResponse : string[];\n  }\n\n  async getIdentities(ctx: Context): Promise<FabricIdentity[]> {\n    const log = ctx.logger.for(this.getIdentities);\n    log.verbose(`Retrieving Identities under CA ${this.config.caName}`);\n    const response: IdentityResponse = (await this.identities.getAll(this.user))\n      .result;\n    log.verbose(`Found ${response.identities.length} Identities`);\n    log.debug(response.identities);\n    return response.identities;\n  }\n\n  /**\n   * @description Retrieve affiliations from the CA.\n   * @summary Queries the CA for the list of affiliations available under the configured CA.\n   * @return {string} The affiliations result payload.\n   */\n  async getAffiliations(ctx: Context) {\n    const log = ctx.logger.for(this.getAffiliations);\n    log.verbose(`Retrieving Affiliations under CA ${this.config.caName}`);\n    const response = (await this.affiliations.getAll(this.user)).result;\n    log.verbose(`Found ${response.a.length} Affiliations`);\n    log.debug(JSON.stringify(response));\n    return response;\n  }\n\n  protected parseError(e: Error) {\n    const regexp = /.*code:\\s(\\d+).*?message:\\s[\"'](.+)[\"']/gs;\n    const match = regexp.exec(e.message);\n    if (!match) return new RegistrationError(e);\n    const [, code, message] = match;\n    switch (code) {\n      case \"74\":\n      case \"71\":\n        return new ConflictError(message);\n      case \"20\":\n        return new AuthorizationError(message);\n      default:\n        return new RegistrationError(message);\n    }\n  }\n\n  /**\n   * @description Read identity details from the CA by enrollment ID.\n   * @summary Retrieves and validates a single identity, throwing NotFoundError when missing.\n   * @param {string} enrollmentId - Enrollment ID to lookup.\n   * @return {Promise<FabricIdentity>} The identity details stored in the CA.\n   */\n  async read(\n    enrollmentId: string,\n    ...args: MaybeContextualArg<any>\n  ): Promise<FabricIdentity> {\n    const { log } = (await this.logCtx(args, OperationKeys.READ, true)).for(\n      this.read\n    );\n    log.verbose(`Retrieving identity with enrollment ID ${enrollmentId}`);\n    let result: IServiceResponse;\n    try {\n      result = await this.identities.getOne(enrollmentId, this.user);\n    } catch (e: any) {\n      throw new NotFoundError(\n        `Couldn't find enrollment with id ${enrollmentId}: ${e}`\n      );\n    }\n\n    if (!result.success)\n      throw new NotFoundError(\n        `Couldn't find enrollment with id ${enrollmentId}: ${result.errors.join(\"\\n\")}`\n      );\n\n    return result.result as FabricIdentity;\n  }\n\n  /**\n   * @description Register a new identity with the CA.\n   * @summary Submits a registration request for a new enrollment ID, returning the enrollment secret upon success.\n   * @param {Credentials} model - Credentials containing userName and password for the new identity.\n   * @param {boolean} [isSuperUser=false] - Whether to register the identity as a super user.\n   * @param {string} [affiliation=\"\"] - Affiliation string (e.g., org1.department1).\n   * @param {CA_ROLE | string} [userRole] - Role to assign to the identity.\n   * @param {IKeyValueAttribute} [attrs] - Optional attributes to attach to the identity.\n   * @param {number} [maxEnrollments] - Maximum number of enrollments allowed for the identity.\n   * @return {Promise<string>} The enrollment secret for the registered identity.\n   */\n  async register(\n    model: Credentials,\n    isSuperUser: boolean = false,\n    affiliation: string = \"\",\n    userRole?: CA_ROLE | string,\n    attrs?: IKeyValueAttribute,\n    maxEnrollments?: number,\n    ...args: MaybeContextualArg<any>\n  ): Promise<string> {\n    const { log } = (await this.logCtx(args, \"register\", true)).for(\n      this.register\n    );\n\n    let registration: string;\n    try {\n      const { userName, password } = model;\n      const props = {\n        enrollmentID: userName as string,\n        enrollmentSecret: password,\n        affiliation: affiliation,\n        userRole: userRole,\n        attrs: attrs,\n        maxEnrollments: maxEnrollments,\n      } as IRegisterRequest;\n      registration = await this.client.register(props, this.user);\n      log.info(\n        `Registration for ${userName} created with user type ${userRole ?? \"Undefined Role\"} ${isSuperUser ? \"as super user\" : \"\"}`\n      );\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return registration;\n  }\n\n  protected static identityFromEnrollment(\n    enrollment: IEnrollResponse,\n    mspId: string,\n    ctx: Context\n  ): Identity {\n    const log = ctx.logger.for(this.identityFromEnrollment);\n    const { certificate, key, rootCertificate } = enrollment;\n    log.verbose(\n      `Generating Identity from certificate ${certificate} in msp ${mspId}`\n    );\n    const clientId = CryptoUtils.fabricIdFromCertificate(certificate);\n    const id = CryptoUtils.encode(clientId);\n    log.debug(`Identity ${clientId} and encodedId ${id}`);\n    return new Identity({\n      id: id,\n      credentials: {\n        id: id,\n        certificate: certificate,\n        privateKey: key.toBytes(),\n        rootCertificate: rootCertificate,\n      },\n      mspId: mspId,\n    });\n  }\n\n  /**\n   * @description Enroll an identity with the CA using a registration secret.\n   * @summary Exchanges the enrollment ID and secret for certificates, returning a constructed Identity model.\n   * @param {string} enrollmentId - Enrollment ID to enroll.\n   * @param {string} registration - Enrollment secret returned at registration time.\n   * @return {Promise<Identity>} The enrolled identity object with credentials.\n   */\n  async enroll(\n    enrollmentId: string,\n    registration: string,\n    ...args: MaybeContextualArg<any>\n  ): Promise<Identity> {\n    const { log, ctx } = (await this.logCtx(args, \"enroll\", true)).for(\n      this.enroll\n    );\n    let identity: Identity;\n    try {\n      log.debug(`Enrolling ${enrollmentId}`);\n      const enrollment: IEnrollResponse = await this.client.enroll({\n        enrollmentID: enrollmentId,\n        enrollmentSecret: registration,\n      });\n      identity = FabricIdentityService.identityFromEnrollment(\n        enrollment,\n        this.config.caName,\n        ctx\n      );\n      log.info(\n        `Successfully enrolled ${enrollmentId} under ${this.config.caName} as ${identity.id}`\n      );\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return identity;\n  }\n\n  /**\n   * @description Register and enroll a new identity in one step.\n   * @summary Registers a new enrollment ID with the CA and immediately exchanges the secret to enroll, returning the created Identity.\n   * @param {Credentials} model - Credentials for the new identity containing userName and password.\n   * @param {boolean} [isSuperUser=false] - Whether to register the identity as a super user.\n   * @param {string} [affiliation=\"\"] - Affiliation string (e.g., org1.department1).\n   * @param {CA_ROLE | string} [userRole] - Role to assign to the identity.\n   * @param {IKeyValueAttribute} [attrs] - Optional attributes to attach to the identity.\n   * @param {number} [maxEnrollments] - Maximum number of enrollments allowed for the identity.\n   * @return {Promise<Identity>} The enrolled identity.\n   */\n  async registerAndEnroll(\n    model: Credentials,\n    isSuperUser: boolean = false,\n    affiliation: string = \"\",\n    userRole?: CA_ROLE | string,\n    attrs?: IKeyValueAttribute,\n    maxEnrollments?: number,\n    ...args: MaybeContextualArg<any>\n  ): Promise<Identity> {\n    const { ctx } = (await this.logCtx(args, \"register-enroll\", true)).for(\n      this.registerAndEnroll\n    );\n    const registration = await this.register(\n      model,\n      isSuperUser,\n      affiliation,\n      userRole,\n      attrs,\n      maxEnrollments,\n      ctx\n    );\n    const { userName } = model;\n    return this.enroll(userName as string, registration, ctx);\n  }\n\n  /**\n   * @description Re-enroll an existing identity using its current enrollment.\n   * @summary Renews the enrollment certificate by calling the CA reenroll.\n   * @param {User} currentUser - Already enrolled user, must have a signing identity.\n   * @return {Promise<Identity>} The renewed identity object with new credentials.\n   */\n  async updateIdentity(\n    enrollmentId: string,\n    identity: { certificate: string; privateKey: string },\n    identityRequest: IIdentityRequest,\n    ...args: MaybeContextualArg<any>\n  ): Promise<Identity> {\n    const { log, ctx } = (await this.logCtx(args, \"reenroll\", true)).for(\n      this.updateIdentity\n    );\n\n    try {\n      log.info(`Renewing identity for ${enrollmentId}`);\n\n      // Update attributes in the CA registry (admin operation). This changes the \"source of truth\".\n      const identityService = this.client.newIdentityService();\n\n      const caUserIdentity = (await identityService.getOne(\n        enrollmentId,\n        this.user\n      )) as { result: { attrs?: IKeyValueAttribute[] } };\n\n      await identityService.update(enrollmentId, identityRequest, this.user); // as IServiceResponse & { result: IIdentityRequest };\n\n      // Reenroll as the user. Request must be signed using the existing certificate.\n      const reenrollUser = User.createUser(\n        enrollmentId,\n        \"\", // enrollmentSecret not required for reenroll\n        this.user.getMspid(),\n        identity.certificate,\n        identity.privateKey\n      );\n      reenrollUser.setCryptoSuite(this.user.getCryptoSuite());\n\n      const enrollmentAttrs: IAttributeRequest[] = (\n        caUserIdentity.result.attrs || []\n      ).map(({ name }) => ({\n        name,\n        optional: false,\n      }));\n\n      const enrollment = await this.client.reenroll(\n        reenrollUser,\n        enrollmentAttrs\n      );\n\n      const renewedIdentity = FabricIdentityService.identityFromEnrollment(\n        enrollment,\n        this.config.caName,\n        ctx\n      );\n\n      // Revoke the previous certificate only, so the old cert becomes invalid.\n      log.debug(`Revoking previous certificates for ${enrollmentId}`);\n      const { aki, serial } = getAkiAndSerialFromCert(identity.certificate);\n      await this.revoke(enrollmentId, { aki, serial }, args);\n\n      log.debug(`Renew identity successful for ${enrollmentId}`);\n      return renewedIdentity;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  /**\n   * Revokes the enrollment of an identity with the specified enrollment ID.\n   *\n   * @param enrollmentId - The enrollment ID of the identity to be revoked.\n   *\n   * @returns A Promise that resolves to the result of the revocation operation.\n   *\n   * @throws {NotFoundError} If the enrollment with the specified ID does not exist.\n   * @throws {InternalError} If there is an error during the revocation process.\n   */\n  async revoke(\n    enrollmentId: string,\n    revokeOptions: Omit<IRevokeRequest, \"enrollmentID\">,\n    ...args: MaybeContextualArg<any>\n  ): Promise<IServiceResponse> {\n    const { log } = (await this.logCtx(args, \"revoke\", true)).for(this.revoke);\n    log.verbose(`Revoking identity with enrollment ID ${enrollmentId}`);\n    const identity = await this.read(enrollmentId);\n    if (!identity)\n      throw new NotFoundError(\n        `Could not find enrollment with id ${enrollmentId}`\n      );\n    let result: IServiceResponse;\n    try {\n      const reason =\n        Boolean(revokeOptions.serial) || Boolean(revokeOptions.aki)\n          ? \"Revoke User Certificate\"\n          : \"User Deletion\";\n\n      const revokeRequest: IRevokeRequest = {\n        reason,\n        ...revokeOptions,\n        enrollmentID: identity.id,\n      };\n\n      result = await this.client.revoke(revokeRequest, this.user);\n    } catch (e: unknown) {\n      throw new InternalError(\n        `Could not revoke enrollment with id ${enrollmentId}: ${e}`\n      );\n    }\n    if (!result.success)\n      throw new InternalError(\n        `Could not revoke enrollment with id ${enrollmentId}: ${result.errors.join(\"\\n\")}`\n      );\n    return result;\n  }\n}\n","/**\n * @description Certificate Authority role types used during enrollment and registration.\n * @summary Enumerates the standard Hyperledger Fabric CA roles that can be assigned to identities when registering with the CA service.\n * @enum {string}\n * @readonly\n * @memberOf module:for-fabric.client\n */\nexport enum CA_ROLE {\n  /** Administrator role with elevated privileges for managing identities and affiliations */\n  ADMIN = \"admin\",\n  /** Standard user role for application clients interacting with the network */\n  USER = \"user\",\n  /** Client role typically used for SDK-based interactions and service accounts */\n  CLIENT = \"client\",\n}\n","import { FabricClientFlags } from \"./types\";\n\nexport const DefaultFabricClientFlags: FabricClientFlags = Object.assign({\n  evaluateTimeout: 5,\n  endorseTimeout: 15,\n  submitTimeout: 5,\n  commitTimeout: 60,\n  legacy: false,\n  allowManualEndorsingOrgs: false,\n  allowGatewayOverride: false,\n  rebuildWithTransient: true,\n  encryptTransient: false,\n  syntheticEvents: true,\n}) as any;\n","import { isBrowser, MiniLogger } from \"@decaf-ts/logging\";\nimport { User } from \"fabric-common\";\nimport { Identity, Signer, signers } from \"@hyperledger/fabric-gateway\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport { normalizeImport } from \"@decaf-ts/core\";\n\nconst log = new MiniLogger(\"fabric-fs\");\n\n/**\n * @description Loads content from a file or returns the content if already loaded\n * @summary Determines if the input is already content or a path to a file, and loads the file if needed\n * @param {string | Uint8Array} contentOrPath - The content or path to load\n * @param {Function} fileReader - Function to read the file if contentOrPath is a path\n * @return {Promise<string | Uint8Array | Buffer>} The content\n * @function contentOfLoadFile\n * @memberOf module:for-fabric.client\n */\nexport async function contentOfLoadFile(\n  contentOrPath: string | Uint8Array,\n  fileReader: (path: string) => Promise<string | Uint8Array | Buffer>\n) {\n  if (contentOrPath instanceof Uint8Array) return contentOrPath;\n  if (\n    contentOrPath.match(\n      /-----BEGIN (CERTIFICATE|KEY|PRIVATE KEY)-----.+?-----END \\1-----$/gms\n    )\n  )\n    return contentOrPath;\n  return await fileReader(contentOrPath);\n}\n\n/**\n * @description Reads a file from the file system\n * @summary Loads a file using the Node.js file system module\n * @param {string | Buffer} contentOrPath - The content or path to load\n * @return {Promise<Buffer>} The file content as a Buffer\n * @function readFile\n * @memberOf module:for-fabric.client\n */\nexport async function readFile(contentOrPath: string | Buffer) {\n  if (typeof contentOrPath !== \"string\") return contentOrPath;\n\n  const fileReader = async (path: string) => {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    return await promises.readFile(path);\n  };\n\n  return await fileReader(contentOrPath);\n}\n\n/**\n * @description Creates a Certificate Authority user\n * @summary Initializes a user with the given credentials for interacting with a Fabric CA\n * @param {string} userName - The user name\n * @param {string} privateKey - The private key as a string\n * @param {string} certificate - The certificate as a string\n * @param {string} mspId - The Membership Service Provider ID\n * @return {Promise<User>} Promise resolving to the created user\n * @function getCAUser\n * @memberOf module:for-fabric.client\n */\nexport async function getCAUser(\n  userName: string,\n  privateKey: string,\n  certificate: string,\n  mspId: string\n): Promise<User> {\n  log.debug(\n    `Creating a CA ${mspId} user ${userName} with certificate ${certificate}`\n  );\n  const user = new User(userName);\n  const cryptoSuite = User.newCryptoSuite();\n  user.setCryptoSuite(cryptoSuite);\n  const importedKey = cryptoSuite.createKeyFromRaw(privateKey);\n  await user.setEnrollment(importedKey, certificate, mspId);\n  return user;\n}\n\n/**\n * @description Gets an identity from a certificate directory\n * @summary Loads a certificate from a directory and creates an Identity object\n * @param {string} mspId - The Membership Service Provider ID\n * @param {string} certDirectoryPath - Path to the directory containing the certificate\n * @return {Promise<Identity>} Promise resolving to the identity\n * @function getIdentity\n * @memberOf module:for-fabric.client\n */\nexport async function getIdentity(\n  mspId: string,\n  certDirectoryPath: string\n): Promise<Identity> {\n  const identityFileReader = async (path: string) => {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    const certPath = await getFirstDirFileName(path);\n    const credentials = await promises.readFile(certPath);\n    return credentials;\n  };\n\n  const credentials: Uint8Array = (await contentOfLoadFile(\n    certDirectoryPath,\n    identityFileReader\n  )) as Uint8Array;\n\n  return { mspId, credentials };\n}\n\n/**\n * @description Gets the full path of the first file in a directory\n * @summary Reads a directory and returns the path to the first file found\n * @param {string} dirPath - Path to the directory\n * @return {Promise<string>} Promise resolving to the full path of the first file\n * @function getFirstDirFileName\n * @memberOf module:for-fabric.client\n */\nexport async function getFirstDirFileName(dirPath: string): Promise<string> {\n  const { promises } = await normalizeImport(import(\"fs\"));\n  const { join } = await normalizeImport(import(\"path\"));\n  const files = await promises.readdir(dirPath);\n  return join(dirPath, files[0]);\n}\n\n/**\n * @description Gets the content of the first file in a directory\n * @summary Reads a directory, finds the first file, and returns its content as a string\n * @param {string} dirPath - Path to the directory\n * @return {Promise<string>} Promise resolving to the content of the first file\n * @function getFirstDirFileNameContent\n * @memberOf module:for-fabric.client\n */\nexport async function getFirstDirFileNameContent(\n  dirPath: string\n): Promise<string> {\n  const { promises } = await normalizeImport(import(\"fs\"));\n  const { join } = await normalizeImport(import(\"path\"));\n  const files = await promises.readdir(dirPath);\n  return (await promises.readFile(join(dirPath, files[0]))).toString();\n}\n\n/**\n * @description Gets a signer from a key directory\n * @summary Loads a private key from a directory and creates a Signer for Fabric transactions\n * @param {string} keyDirectoryPath - Path to the directory containing the private key\n * @return {Promise<Signer>} Promise resolving to the signer\n * @function getSigner\n * @memberOf module:for-fabric.client\n */\nexport async function getSigner(keyDirectoryPath: string): Promise<Signer> {\n  const signerFileReader = async (path: string) => {\n    const { promises } = await normalizeImport(import(\"fs\"));\n    const keyPath = await getFirstDirFileName(path);\n    return await promises.readFile(keyPath);\n  };\n\n  const privateKeyPem = (await contentOfLoadFile(\n    keyDirectoryPath,\n    signerFileReader\n  )) as Buffer;\n  // Node based implementation\n  // privateKey = createPrivateKey(privateKeyPem);\n  // --\n\n  // web based implementation\n  const privateKey = await extractPrivateKey(privateKeyPem);\n  const keys = Object.getOwnPropertySymbols(privateKey);\n  const k = (privateKey as any)[keys[0]];\n  // --\n\n  return signers.newPrivateKeySigner(k as any);\n}\n\n/**\n * @description Extracts a private key from a PEM buffer\n * @summary Converts a PEM-encoded private key to a CryptoKey object\n * @param {Buffer} pem - The PEM-encoded private key\n * @return {Promise<CryptoKey>} Promise resolving to the CryptoKey\n * @function extractPrivateKey\n * @memberOf module:for-fabric.client\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant ExtractPrivateKey\n *   participant SubtleCrypto\n *\n *   Caller->>ExtractPrivateKey: extractPrivateKey(pem)\n *   ExtractPrivateKey->>ExtractPrivateKey: Get SubtleCrypto implementation\n *   ExtractPrivateKey->>ExtractPrivateKey: Parse PEM format\n *   ExtractPrivateKey->>ExtractPrivateKey: Convert to binary DER\n *   ExtractPrivateKey->>SubtleCrypto: importKey(pkcs8, binaryDer, options)\n *   SubtleCrypto-->>ExtractPrivateKey: CryptoKey\n *   ExtractPrivateKey-->>Caller: CryptoKey\n */\nexport async function extractPrivateKey(pem: Buffer) {\n  const libName = \"crypto\";\n  let subtle;\n  if (isBrowser()) {\n    subtle = (globalThis as any).crypto.subtle;\n  } else {\n    const lib = (await normalizeImport(import(libName))) as any;\n    subtle = lib.subtle || lib.webcrypto.subtle;\n  }\n\n  if (!subtle) throw new Error(\"Could not load SubtleCrypto module\");\n\n  function str2ab(str: string) {\n    const buf = new ArrayBuffer(str.length);\n    const bufView = new Uint8Array(buf);\n    for (let i = 0, strLen = str.length; i < strLen; i++) {\n      bufView[i] = str.charCodeAt(i);\n    }\n    return buf;\n  }\n\n  const str = pem\n    .toString(\"utf8\")\n    .replace(\"-----BEGIN PRIVATE KEY-----\", \"\")\n    .replaceAll(\"\\n\", \"\")\n    .replace(\"-----END PRIVATE KEY-----\", \"\");\n  const decoded = Buffer.from(str, \"base64\").toString(\"binary\");\n  const binaryDer = str2ab(decoded);\n\n  try {\n    const key = await subtle.importKey(\n      \"pkcs8\",\n      binaryDer,\n      {\n        name: \"ECDSA\",\n        namedCurve: \"P-256\",\n      },\n      true,\n      [\"sign\"]\n    );\n\n    return key;\n  } catch (e: any) {\n    throw new InternalError(e);\n  }\n}\n","import {\n  AdapterFlags,\n  Condition,\n  Context,\n  GroupOperator,\n  MaybeContextualArg,\n  Operator,\n  OrderDirection,\n  PersistenceKeys,\n  PreparedStatement,\n  PreparedStatementKeys,\n  QueryClause,\n  QueryError,\n  Repository,\n  SelectSelector,\n  Sequence,\n  Statement,\n  StatementExecutor,\n  ViewKind,\n} from \"@decaf-ts/core\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { FabricClientAdapter } from \"./FabricClientAdapter\";\nimport {\n  CouchDBKeys,\n  CouchDBOperator,\n  CouchDBGroupOperator,\n  CouchDBQueryLimit,\n  MangoQuery,\n  MangoOperator,\n  MangoSelector,\n  translateOperators,\n  generateDesignDocName,\n  generateViewName,\n  findViewMetadata,\n  CouchDBViewMetadata,\n  ViewResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport { FabricClientFlags } from \"./types\";\nimport { toCamelCase } from \"@decaf-ts/logging\";\nimport { DBKeys, InternalError } from \"@decaf-ts/db-decorators\";\nimport { Metadata } from \"@decaf-ts/decoration\";\n\ntype FabricViewDescriptor = {\n  ddoc: string;\n  view: string;\n  options: Record<string, any>;\n};\n\ntype FabricAggregateInfo =\n  | {\n      kind: ViewKind;\n      meta: CouchDBViewMetadata;\n      descriptor: FabricViewDescriptor;\n      countDistinct?: boolean;\n    }\n  | {\n      kind: \"avg\";\n      attribute: string;\n      sumDescriptor: FabricViewDescriptor;\n      countDescriptor: FabricViewDescriptor;\n    };\n\nconst escapeRegExp = (value: string): string =>\n  value.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n\nfunction nextLexicographicString(value: string): string {\n  if (!value) return \"\\u0000\";\n  const chars = Array.from(value);\n  for (let i = chars.length - 1; i >= 0; i -= 1) {\n    const code = chars[i].codePointAt(0);\n    if (code === undefined) continue;\n    if (code < 0x10ffff) {\n      chars[i] = String.fromCodePoint(code + 1);\n      return chars.slice(0, i + 1).join(\"\");\n    }\n  }\n  return `${value}\\u0000`;\n}\n\nfunction prefixRange(prefix: string) {\n  return {\n    start: prefix,\n    end: nextLexicographicString(prefix),\n  };\n}\n\nexport class FabricClientStatement<M extends Model, R> extends Statement<\n  M,\n  FabricClientAdapter,\n  R,\n  MangoQuery\n> {\n  constructor(adapter: FabricClientAdapter, overrides?: Partial<AdapterFlags>) {\n    super(adapter, overrides);\n  }\n\n  protected override squash(\n    ctx: Context<FabricClientFlags>\n  ): PreparedStatement<any> | undefined {\n    const squashed: PreparedStatement<M> | undefined = super.squash(\n      ctx as never\n    );\n    if (!squashed) return squashed;\n\n    const { method, params, args } = squashed;\n    const { direction, limit } = params;\n    switch (method) {\n      case PreparedStatementKeys.FIND:\n        break;\n      case PreparedStatementKeys.PAGE:\n        args.push(direction, limit);\n        break;\n      case PreparedStatementKeys.FIND_BY:\n        break;\n      case PreparedStatementKeys.LIST_BY:\n        args.push(direction);\n        break;\n      case PreparedStatementKeys.PAGE_BY:\n        args.push(direction, limit);\n        break;\n      case PreparedStatementKeys.FIND_ONE_BY:\n        break;\n      default:\n        throw new InternalError(`Unsupported method ${method}`);\n    }\n\n    return squashed;\n  }\n\n  protected override async executePrepared(\n    ...argz: MaybeContextualArg<Context<FabricClientFlags>>\n  ): Promise<R> {\n    const repo = Repository.forModel(this.fromSelector, this.adapter.alias);\n    const { method, args } = this.prepared as PreparedStatement<any>;\n    return repo.statement(method, ...args, ...argz);\n  }\n\n  override async prepare(\n    ctx?: Context<FabricClientFlags>\n  ): Promise<StatementExecutor<M, R>> {\n    ctx =\n      ctx ||\n      (await this.adapter.context(\n        PersistenceKeys.QUERY,\n        this.overrides || {},\n        this.fromSelector\n      ));\n\n    if (\n      this.isSimpleQuery() &&\n      (ctx as Context<FabricClientFlags>).get(\"forcePrepareSimpleQueries\")\n    ) {\n      const squashed = this.squash(ctx as Context<FabricClientFlags>);\n      if (squashed) {\n        this.prepared = squashed;\n        return this;\n      }\n    }\n    const args: (string | number)[] = [];\n    const params: any = {} as any;\n\n    const prepared: PreparedStatement<any> = {\n      class: this.fromSelector,\n      args,\n      params,\n    } as any;\n\n    const method: string[] = [QueryClause.FIND_BY];\n\n    if (this.whereCondition) {\n      const parsed = this.prepareCondition(this.whereCondition, ctx as never);\n      method.push(parsed.method);\n      if (parsed.args && parsed.args.length)\n        args.push(...(parsed.args as (string | number)[]));\n    }\n    if (this.selectSelector)\n      method.push(\n        QueryClause.SELECT,\n        this.selectSelector.join(` ${QueryClause.AND.toLowerCase()} `)\n      );\n    if (this.orderBySelectors?.length) {\n      method.push(QueryClause.ORDER_BY, this.orderBySelectors[0][0] as string);\n      args.push(this.orderBySelectors[0][1] as any);\n    }\n    prepared.method = toCamelCase(method.join(\" \"));\n    prepared.params = params;\n    this.prepared = prepared;\n    return this;\n  }\n\n  /**\n   * @description Processes a record from CouchDB/Fabric\n   * @summary Extracts the ID from a CouchDB document and reverts it to a model instance\n   */\n  protected override processRecord(\n    record: any,\n    ctx: Context<FabricClientFlags>\n  ): M {\n    const pkAttr = Model.pk(this.fromSelector);\n    const type = Metadata.get(\n      this.fromSelector,\n      Metadata.key(DBKeys.ID, pkAttr as string)\n    )?.type;\n\n    if (record[CouchDBKeys.ID]) {\n      const [, ...keyArgs] = record[CouchDBKeys.ID].split(CouchDBKeys.SEPARATOR);\n      const id = keyArgs.join(\"_\");\n      record[pkAttr] = Sequence.parseValue(type as any, id);\n    }\n\n    return super.processRecord(record, ctx);\n  }\n\n  /**\n   * @description Executes a raw Mango query\n   * @summary Sends a raw Mango query to Fabric and processes the results\n   */\n  override async raw<R>(rawInput: MangoQuery, ...args: any[]): Promise<R> {\n    const { ctx } = this.logCtx(args, this.raw);\n    const aggregator = (rawInput as any)?.aggregateInfo;\n    if ((rawInput as any)?.aggregate && aggregator) {\n      return this.executeAggregate<R>(aggregator, ctx);\n    }\n    const results: any[] = await this.adapter.raw(\n      rawInput,\n      true,\n      this.fromSelector,\n      ctx\n    );\n\n    if (!this.selectSelector) {\n      const processed = results.map((r) => this.processRecord(r, ctx));\n      if (!ctx.getOrUndefined(\"afterQueryHandlers\")) {\n        return processed as unknown as R;\n      }\n      return (await this.applyAfterHandlersToResult(processed, ctx)) as R;\n    }\n    return results as R;\n  }\n\n  /**\n   * @description Builds a CouchDB Mango query from the statement\n   * @summary Converts the statement's conditions, selectors, and options into a CouchDB Mango query\n   */\n  protected override build(): MangoQuery {\n    const log = this.log.for(this.build);\n    const aggregateQuery = this.buildAggregateQuery();\n    if (aggregateQuery) return aggregateQuery;\n    const selectors: MangoSelector = {};\n    selectors[CouchDBKeys.TABLE] = {};\n    selectors[CouchDBKeys.TABLE] = Model.tableName(this.fromSelector);\n    const query: MangoQuery = { selector: selectors };\n    if (this.selectSelector) query.fields = this.selectSelector as string[];\n\n    if (this.whereCondition) {\n      const condition: MangoSelector = this.parseCondition(\n        Condition.and(\n          this.whereCondition,\n          Condition.attribute<M>(CouchDBKeys.TABLE as keyof M).eq(\n            query.selector[CouchDBKeys.TABLE]\n          )\n        )\n      ).selector;\n      const selectorKeys = Object.keys(condition) as MangoOperator[];\n      if (\n        selectorKeys.length === 1 &&\n        Object.values(CouchDBGroupOperator).indexOf(selectorKeys[0]) !== -1\n      )\n        switch (selectorKeys[0]) {\n          case CouchDBGroupOperator.AND:\n            condition[CouchDBGroupOperator.AND] = [\n              ...Object.values(\n                condition[CouchDBGroupOperator.AND] as MangoSelector\n              ).reduce((accum: MangoSelector[], val: any) => {\n                const keys = Object.keys(val);\n                if (keys.length !== 1)\n                  throw new Error(\n                    \"Too many keys in query selector. should be one\"\n                  );\n                const k = keys[0];\n                if (k === CouchDBGroupOperator.AND)\n                  accum.push(...(val[k] as any[]));\n                else accum.push(val);\n                return accum;\n              }, []),\n            ];\n            query.selector = condition;\n            break;\n          case CouchDBGroupOperator.OR: {\n            const s: Record<any, any> = {};\n            s[CouchDBGroupOperator.AND] = [\n              condition,\n              ...Object.entries(query.selector).map(([key, val]) => {\n                const result: Record<any, any> = {};\n                result[key] = val;\n                return result;\n              }),\n            ];\n            query.selector = s;\n            break;\n          }\n          default:\n            throw new Error(\"This should be impossible\");\n        }\n      else {\n        Object.entries(condition).forEach(([key, val]) => {\n          if (query.selector[key])\n            log.warn(\n              `A ${key} query param is about to be overridden: ${query.selector[key]} by ${val}`\n            );\n          query.selector[key] = val;\n        });\n      }\n    }\n\n    if (this.orderBySelectors?.length) {\n      query.sort = query.sort || [];\n      query.selector = query.selector || ({} as MangoSelector);\n      for (const [selectorKey, direction] of this.orderBySelectors) {\n        const selector = selectorKey as string;\n        const rec: Record<string, OrderDirection> = {};\n        rec[selector] = direction as OrderDirection;\n        (query.sort as Record<string, OrderDirection>[]).push(rec);\n        if (!query.selector[selector]) {\n          query.selector[selector] = {} as MangoSelector;\n          (query.selector[selector] as MangoSelector)[CouchDBOperator.BIGGER] =\n            null;\n        }\n      }\n    }\n\n    if (this.limitSelector) {\n      query.limit = this.limitSelector;\n    } else {\n      log.warn(\n        `No limit selector defined. Using default couchdb limit of ${CouchDBQueryLimit}`\n      );\n      query.limit = CouchDBQueryLimit;\n    }\n\n    if (this.offsetSelector) query.skip = this.offsetSelector;\n\n    return query;\n  }\n\n  /**\n   * @description Parses a condition into a CouchDB Mango query selector\n   * @summary Converts a Condition object into a CouchDB Mango query selector structure\n   */\n  protected override parseCondition(condition: Condition<M>): MangoQuery {\n    function merge(\n      op: MangoOperator,\n      obj1: MangoSelector,\n      obj2: MangoSelector\n    ): MangoQuery {\n      const result: MangoQuery = { selector: {} as MangoSelector };\n      result.selector[op] = [obj1, obj2];\n      return result;\n    }\n\n    const { attr1, operator, comparison } = condition as unknown as {\n      attr1: string | Condition<M>;\n      operator: Operator | GroupOperator;\n      comparison: any;\n    };\n\n    if (operator === Operator.STARTS_WITH) {\n      if (typeof attr1 !== \"string\")\n        throw new QueryError(\"STARTS_WITH requires an attribute name\");\n      if (typeof comparison !== \"string\")\n        throw new QueryError(\"STARTS_WITH requires a string comparison\");\n      const range = prefixRange(comparison);\n      const selector: MangoSelector = {} as MangoSelector;\n      selector[attr1] = {} as MangoSelector;\n      (selector[attr1] as MangoSelector)[CouchDBOperator.BIGGER_EQ] = range.start;\n      (selector[attr1] as MangoSelector)[CouchDBOperator.SMALLER] = range.end;\n      return { selector };\n    }\n\n    if (operator === Operator.ENDS_WITH) {\n      if (typeof attr1 !== \"string\")\n        throw new QueryError(\"ENDS_WITH requires an attribute name\");\n      if (typeof comparison !== \"string\")\n        throw new QueryError(\"ENDS_WITH requires a string comparison\");\n      const selector: MangoSelector = {} as MangoSelector;\n      selector[attr1] = {\n        [CouchDBOperator.REGEXP]: `${escapeRegExp(comparison)}$`,\n      } as MangoSelector;\n      return { selector };\n    }\n\n    if (operator === Operator.BETWEEN) {\n      const attr = attr1 as string;\n      if (!Array.isArray(comparison) || comparison.length !== 2)\n        throw new QueryError(\"BETWEEN operator requires [min, max] comparison\");\n      const [min, max] = comparison;\n      const opBetween: MangoSelector = {} as MangoSelector;\n      opBetween[attr] = {} as MangoSelector;\n      (opBetween[attr] as MangoSelector)[\n        translateOperators(Operator.BIGGER_EQ)\n      ] = min;\n      (opBetween[attr] as MangoSelector)[\n        translateOperators(Operator.SMALLER_EQ)\n      ] = max;\n      return { selector: opBetween };\n    }\n\n    let op: MangoSelector = {} as MangoSelector;\n    if (\n      [GroupOperator.AND, GroupOperator.OR, Operator.NOT].indexOf(\n        operator as GroupOperator\n      ) === -1\n    ) {\n      op[attr1 as string] = {} as MangoSelector;\n      (op[attr1 as string] as MangoSelector)[translateOperators(operator)] =\n        comparison;\n    } else if (operator === Operator.NOT) {\n      op = this.parseCondition(attr1 as Condition<M>).selector as MangoSelector;\n      op[translateOperators(Operator.NOT)] = {} as MangoSelector;\n      (op[translateOperators(Operator.NOT)] as MangoSelector)[\n        (attr1 as unknown as { attr1: string }).attr1\n      ] = comparison;\n    } else {\n      const op1: any = this.parseCondition(attr1 as Condition<M>).selector;\n      const op2: any = this.parseCondition(comparison as Condition<M>).selector;\n      op = merge(translateOperators(operator), op1, op2).selector;\n    }\n\n    return { selector: op };\n  }\n\n  /**\n   * @description Builds an aggregate query if aggregation is requested\n   * @summary Checks for aggregate operations and returns a special MangoQuery for them\n   */\n  private buildAggregateQuery(): MangoQuery | undefined {\n    if (!this.fromSelector) return undefined;\n    if (this.avgSelector) {\n      const attribute = String(this.avgSelector);\n      const sumInfo = this.createAggregateDescriptor(\"sum\", attribute);\n      const countInfo = this.createAggregateDescriptor(\"count\", attribute);\n      if (!sumInfo || !countInfo)\n        throw new QueryError(\n          `Avg operation requires sum and count views for attribute ${attribute}`\n        );\n      return this.createAggregateQuery({\n        kind: \"avg\",\n        attribute,\n        sumDescriptor: sumInfo.descriptor,\n        countDescriptor: countInfo.descriptor,\n      });\n    }\n\n    if (typeof this.countDistinctSelector !== \"undefined\") {\n      const attribute =\n        this.countDistinctSelector == null\n          ? undefined\n          : String(this.countDistinctSelector);\n      const info = this.createAggregateDescriptor(\"distinct\", attribute);\n      if (info) {\n        info.countDistinct = true;\n        return this.createAggregateQuery(info);\n      }\n    }\n\n    const aggregatorUsed =\n      typeof this.countSelector !== \"undefined\" ||\n      typeof this.countDistinctSelector !== \"undefined\" ||\n      !!this.minSelector ||\n      !!this.maxSelector ||\n      !!this.sumSelector ||\n      !!this.distinctSelector;\n\n    const aggregatorChecks: Array<[ViewKind, SelectSelector<M> | undefined]> = [\n      [\n        \"count\",\n        (this.countSelector ?? undefined) as SelectSelector<M> | undefined,\n      ],\n      [\"max\", this.maxSelector],\n      [\"min\", this.minSelector],\n      [\"sum\", this.sumSelector],\n      [\"distinct\", this.distinctSelector],\n    ];\n\n    for (const [kind, selector] of aggregatorChecks) {\n      const attribute = selector ? String(selector) : undefined;\n      const info = this.createAggregateDescriptor(kind, attribute);\n      if (info) return this.createAggregateQuery(info);\n    }\n\n    if (aggregatorUsed) {\n      throw new QueryError(\n        `No CouchDB view metadata found for table ${Model.tableName(\n          this.fromSelector\n        )} aggregator`\n      );\n    }\n    return undefined;\n  }\n\n  /**\n   * @description Creates an aggregate descriptor for a view-based aggregation\n   */\n  private createAggregateDescriptor(\n    kind: ViewKind,\n    attribute?: string\n  ): Extract<FabricAggregateInfo, { kind: ViewKind }> | undefined {\n    if (!this.fromSelector) return undefined;\n    const metas = findViewMetadata(this.fromSelector, kind, attribute);\n    if (!metas.length) return undefined;\n    const meta = metas[0];\n    const tableName = Model.tableName(this.fromSelector);\n    const viewName = generateViewName(tableName, meta.attribute, kind, meta);\n    const ddoc = meta.ddoc || generateDesignDocName(tableName, viewName);\n    const options: Record<string, any> = {\n      reduce: meta.reduce !== undefined ? true : !meta.returnDocs,\n    };\n    if (kind === \"distinct\" || kind === \"groupBy\") options.group = true;\n    return {\n      kind,\n      meta,\n      descriptor: {\n        ddoc,\n        view: viewName,\n        options,\n      },\n    };\n  }\n\n  /**\n   * @description Creates the special aggregate MangoQuery marker\n   */\n  private createAggregateQuery(\n    info: FabricAggregateInfo\n  ): MangoQuery & { aggregate: true; aggregateInfo: FabricAggregateInfo } {\n    return {\n      selector: {},\n      aggregate: true,\n      aggregateInfo: info,\n    } as MangoQuery & { aggregate: true; aggregateInfo: FabricAggregateInfo };\n  }\n\n  /**\n   * @description Gets the adapter cast to FabricClientAdapter for view access\n   */\n  private getFabricAdapter(): FabricClientAdapter {\n    return this.adapter as FabricClientAdapter;\n  }\n\n  /**\n   * @description Executes an aggregate query via adapter's view method\n   */\n  private async executeAggregate<R>(\n    info: FabricAggregateInfo,\n    ctx: Context<FabricClientFlags>\n  ): Promise<R> {\n    if (!this.isViewAggregate(info)) {\n      return this.handleAverage<R>(info, ctx);\n    }\n    const fabricAdapter = this.getFabricAdapter();\n    const viewInfo = info as Extract<FabricAggregateInfo, { kind: ViewKind }>;\n    const response = await fabricAdapter.view<ViewResponse>(\n      viewInfo.descriptor.ddoc,\n      viewInfo.descriptor.view,\n      viewInfo.descriptor.options,\n      ctx\n    );\n    return this.processViewResponse<R>(info, response);\n  }\n\n  /**\n   * @description Handles average calculation from sum and count views\n   */\n  private async handleAverage<R>(\n    info: FabricAggregateInfo,\n    ctx: Context<FabricClientFlags>\n  ): Promise<R> {\n    if (info.kind !== \"avg\")\n      throw new QueryError(\"Average descriptor is not valid\");\n    const fabricAdapter = this.getFabricAdapter();\n    const [sumDesc, countDesc] = [info.sumDescriptor, info.countDescriptor];\n    const [sumResponse, countResponse] = await Promise.all([\n      fabricAdapter.view<ViewResponse>(\n        sumDesc.ddoc,\n        sumDesc.view,\n        sumDesc.options,\n        ctx\n      ),\n      fabricAdapter.view<ViewResponse>(\n        countDesc.ddoc,\n        countDesc.view,\n        countDesc.options,\n        ctx\n      ),\n    ]);\n    const sum = sumResponse.rows?.[0]?.value ?? 0;\n    const count = countResponse.rows?.[0]?.value ?? 0;\n    if (!count) return 0 as unknown as R;\n    return (sum / count) as unknown as R;\n  }\n\n  /**\n   * @description Processes the view response based on aggregate kind\n   */\n  private processViewResponse<R>(\n    info: FabricAggregateInfo,\n    response: ViewResponse\n  ): R {\n    if (info.kind === \"avg\")\n      throw new QueryError(\n        \"Average results should be handled before processing rows\"\n      );\n    const rows = response.rows || [];\n    const viewInfo = info as Extract<FabricAggregateInfo, { kind: ViewKind }>;\n    const meta = viewInfo.meta;\n    if (viewInfo.countDistinct) {\n      return (rows.length || 0) as unknown as R;\n    }\n    if (viewInfo.kind === \"distinct\" || viewInfo.kind === \"groupBy\") {\n      return rows.map((row) => row.key ?? row.value) as unknown as R;\n    }\n    if (meta.returnDocs) {\n      return rows.map((row) => row.value ?? row.doc ?? row) as unknown as R;\n    }\n    if (!rows.length) {\n      return (viewInfo.kind === \"count\" ? 0 : null) as unknown as R;\n    }\n    return (rows[0].value ?? rows[0].key ?? null) as unknown as R;\n  }\n\n  /**\n   * @description Type guard to check if info is a view-based aggregate\n   */\n  private isViewAggregate(\n    info: FabricAggregateInfo\n  ): info is Extract<FabricAggregateInfo, { kind: ViewKind }> {\n    return info.kind !== \"avg\";\n  }\n}\n","import \"../shared/overrides\";\nimport {\n  CouchDBKeys,\n  type MangoQuery,\n  type ViewResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport { Client } from \"@grpc/grpc-js\";\nimport * as grpc from \"@grpc/grpc-js\";\nimport {\n  Model,\n  type ModelConstructor,\n  type Serializer,\n} from \"@decaf-ts/decorator-validation\";\nimport { debug, final, Logging } from \"@decaf-ts/logging\";\nimport {\n  type PeerConfig,\n  type SegregatedModel,\n  type MspDetails,\n} from \"../shared/types\";\nimport {\n  connect,\n  type ConnectOptions,\n  Gateway,\n  Network,\n  ProposalOptions,\n  Contract as Contrakt,\n  type Signer,\n  GatewayError,\n  EndorseError,\n} from \"@hyperledger/fabric-gateway\";\nimport { Gateway as LegacyGateway, Wallets } from \"fabric-network\";\nimport type { Endorser } from \"fabric-common\";\nimport {\n  getIdentity,\n  getSigner,\n  getFirstDirFileNameContent,\n  readFile as readFsFile,\n} from \"./fabric-fs\";\nimport {\n  BaseError,\n  InternalError,\n  OperationKeys,\n  SerializationError,\n  BulkCrudOperationKeys,\n  NotFoundError,\n  ConflictError,\n  BadRequestError,\n  type PrimaryKeyType,\n  ValidationError,\n} from \"@decaf-ts/db-decorators\";\nimport {\n  Context,\n  Adapter,\n  type AdapterFlags,\n  AuthorizationError,\n  ConnectionError,\n  ForbiddenError,\n  MigrationError,\n  ObserverError,\n  PagingError,\n  PersistenceKeys,\n  QueryError,\n  Repository,\n  UnsupportedError,\n  Statement,\n  type PreparedStatement,\n  Paginator,\n  MaybeContextualArg,\n  ContextualArgs,\n  type PreparedModel,\n  AllOperationKeys,\n} from \"@decaf-ts/core\";\nimport { FabricFlavour } from \"../shared/constants\";\nimport { ClientSerializer } from \"../shared/ClientSerializer\";\nimport { FabricClientDispatch } from \"./FabricClientDispatch\";\n// import { HSMSignerFactoryCustom } from \"./fabric-hsm\";\nimport { type Constructor } from \"@decaf-ts/decoration\";\nimport { FabricClientStatement } from \"./FabricClientStatement\";\nimport { FabricClientPaginator } from \"./FabricClientPaginator\";\nimport { FabricClientRepository } from \"./FabricClientRepository\";\nimport {\n  EndorsementError,\n  EndorsementPolicyError,\n  MvccReadConflictError,\n  PhantomReadConflictError,\n  TransactionTimeoutError,\n} from \"../shared/errors\";\nimport { FabricClientFlags } from \"./types\";\nimport { DefaultFabricClientFlags } from \"./constants\";\nimport fs from \"fs\";\nimport { CryptoUtils } from \"./crypto\";\nimport { extractIds } from \"./ids/id-extraction\";\nimport { Identity } from \"../shared/index\";\n\ntype LegacyPeerTarget = {\n  mspId: string;\n  peerEndpoint: string;\n  peerHostAlias?: string;\n  tlsCert?: string | Buffer;\n};\n\ntype LegacyPeerWithName = LegacyPeerTarget & { name: string };\n\n/**\n * @description Adapter for interacting with Hyperledger Fabric networks\n * @summary The FabricAdapter extends CouchDBAdapter to provide a seamless interface for interacting with Hyperledger Fabric networks.\n * It handles connection management, transaction submission, and CRUD operations against Fabric chaincode.\n * @template PeerConfig - Configuration type for connecting to a Fabric peer\n * @template FabricFlags - Flags specific to Fabric operations\n * @template Context<FabricFlags> - Context type containing Fabric-specific flags\n * @param config - Configuration for connecting to a Fabric peer\n * @param alias - Optional alias for the adapter instance\n * @class FabricClientAdapter\n * @example\n * ```typescript\n * // Create a new FabricAdapter instance\n * const config: PeerConfig = {\n *   mspId: 'Org1MSP',\n *   peerEndpoint: 'localhost:7051',\n *   channelName: 'mychannel',\n *   chaincodeName: 'mycc',\n *   contractName: 'mycontract',\n *   tlsCertPath: '/path/to/tls/cert',\n *   certDirectoryPath: '/path/to/cert/dir',\n *   keyDirectoryPath: '/path/to/key/dir'\n * };\n *\n * const adapter = new FabricAdapter(config, 'org1-adapter');\n *\n * // Use the adapter to interact with the Fabric network\n * const result = await adapter.read('users', 'user1', mySerializer);\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant FabricAdapter\n *   participant Gateway\n *   participant Network\n *   participant Contract\n *   participant Chaincode\n *\n *   Client->>FabricAdapter: create(tableName, id, model, transient, serializer)\n *   FabricAdapter->>FabricAdapter: submitTransaction(OperationKeys.CREATE, [serializedModel], transient)\n *   FabricAdapter->>Gateway: connect()\n *   Gateway->>Network: getNetwork(channelName)\n *   Network->>Contract: getContract(chaincodeName, contractName)\n *   FabricAdapter->>Contract: submit(api, proposalOptions)\n *   Contract->>Chaincode: invoke\n *   Chaincode-->>Contract: response\n *   Contract-->>FabricAdapter: result\n *   FabricAdapter->>FabricAdapter: decode(result)\n *   FabricAdapter->>FabricAdapter: serializer.deserialize(decodedResult)\n *   FabricAdapter-->>Client: deserializedResult\n */\nexport class FabricClientAdapter extends Adapter<\n  PeerConfig,\n  Client,\n  MangoQuery,\n  Context<FabricClientFlags>\n> {\n  /**\n   * @description Static text decoder for converting Uint8Array to string\n   */\n  private static decoder = new TextDecoder(\"utf8\");\n\n  private static serializer = new ClientSerializer();\n\n  protected static log = Logging.for(FabricClientAdapter);\n\n  protected readonly serializer: Serializer<any> =\n    FabricClientAdapter.serializer;\n\n  /**\n   * @description Creates a new FabricAdapter instance\n   * @summary Initializes a new adapter for interacting with a Hyperledger Fabric network\n   * @param {PeerConfig} config - Configuration for connecting to a Fabric peer\n   * @param {string} [alias] - Optional alias for the adapter instance\n   */\n  constructor(config: PeerConfig, alias?: string) {\n    super(\n      Object.assign({}, DefaultFabricClientFlags, config),\n      FabricFlavour,\n      alias\n    );\n  }\n\n  override Statement<M extends Model>(\n    overrides?: Partial<AdapterFlags>\n  ): Statement<M, FabricClientAdapter, any, MangoQuery> {\n    return new FabricClientStatement(this, overrides);\n  }\n\n  Paginator<M extends Model>(\n    query: PreparedStatement<any> | MangoQuery,\n    size: number,\n    clazz: Constructor<M>\n  ): Paginator<M, any, MangoQuery> {\n    return new FabricClientPaginator(this, query, size, clazz);\n  }\n\n  protected override async flags<M extends Model>(\n    operation: OperationKeys | string,\n    model: Constructor<M> | Constructor<M>[] | undefined,\n    flags: Partial<FabricClientFlags>,\n    ...args: any[]\n  ): Promise<FabricClientFlags> {\n    const mergedFlags = Object.assign({}, this.config, flags);\n    const f = Object.assign(\n      await super.flags(operation, model, mergedFlags, ...args)\n    );\n    return f;\n  }\n\n  override async context<M extends Model>(\n    operation: ((...args: any[]) => any) | AllOperationKeys,\n    overrides: Partial<FabricClientFlags>,\n    model: Constructor<M> | Constructor<M>[],\n    ...args: MaybeContextualArg<Context<any>>\n  ): Promise<Context<FabricClientFlags>> {\n    const log = this.log.for(this.context);\n    log.silly(\n      `creating new context for ${operation} operation on ${model ? (Array.isArray(model) ? model.map((m) => Model.tableName(m)) : Model.tableName(model)) : \"no\"} table ${overrides && Object.keys(overrides) ? Object.keys(overrides).length : \"no\"} with flag overrides`\n    );\n    let ctx = args.pop();\n    if (typeof ctx !== \"undefined\" && !(ctx instanceof Context)) {\n      args.push(ctx);\n      ctx = undefined;\n    }\n\n    overrides = ctx\n      ? Object.assign({}, ctx.toOverrides(), overrides)\n      : overrides;\n    const flags = await this.flags(\n      typeof operation === \"string\" ? operation : operation.name,\n      model,\n      overrides as Partial<FabricClientFlags>,\n      ...[...args, ctx].filter(Boolean)\n    );\n\n    if (ctx) {\n      if (!(ctx instanceof this.Context)) {\n        const newCtx = new this.Context().accumulate({\n          ...ctx[\"cache\"],\n          ...flags,\n          parentContext: ctx,\n        }) as any;\n        ctx.accumulate({\n          childContexts: [\n            ...(ctx.getOrUndefined(\"childContexts\") || []),\n            newCtx,\n          ],\n        });\n        return newCtx;\n      }\n      const currentOp = ctx.getOrUndefined(\"operation\");\n      const currentModel = ctx.getOrUndefined(\"affectedTables\");\n      if (\n        !currentOp ||\n        currentOp !== operation ||\n        (model && model !== currentModel)\n      ) {\n        const newCtx = new this.Context().accumulate({\n          ...ctx[\"cache\"],\n          ...flags,\n          parentContext: ctx,\n        }) as any;\n\n        ctx.accumulate({\n          childContexts: [\n            ...(ctx.getOrUndefined(\"childContexts\") || []),\n            newCtx,\n          ],\n        });\n        return newCtx;\n      }\n      return ctx.accumulate(flags) as any;\n    }\n\n    return new this.Context().accumulate({\n      ...flags,\n    }) as any;\n  }\n\n  /**\n   * @description Decodes a Uint8Array to a string\n   * @summary Converts binary data received from Fabric to a string using UTF-8 encoding\n   * @param {Uint8Array} data - The binary data to decode\n   * @return {string} The decoded string\n   */\n  decode(data: Uint8Array): string {\n    return FabricClientAdapter.decoder.decode(data);\n  }\n\n  override repository<\n    R extends Repository<\n      any,\n      Adapter<PeerConfig, Client, MangoQuery, Context<FabricClientFlags>>\n    >,\n  >(): Constructor<R> {\n    return FabricClientRepository as unknown as Constructor<R>;\n  }\n\n  protected createPrefix<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    model: Record<string, any>,\n    ...args: MaybeContextualArg<Context<FabricClientFlags>>\n  ): [Constructor<M>, PrimaryKeyType, Record<string, any>, ...any[], Context] {\n    const { ctxArgs } = this.logCtx(args, this.createPrefix);\n    const tableName = Model.tableName(clazz);\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    Object.assign(record, model);\n    return [clazz, id, record, ...ctxArgs];\n  }\n\n  /**\n   * @description Prepares multiple records for creation\n   * @summary Adds necessary CouchDB fields to multiple records before creation\n   * @param {string} tableName - The name of the table\n   * @param {string[]|number[]} ids - The IDs of the records\n   * @param models - The models to prepare\n   * @return A tuple containing the tableName, ids, and prepared records\n   * @throws {InternalError} If ids and models arrays have different lengths\n   */\n  protected createAllPrefix<M extends Model>(\n    clazz: Constructor<M>,\n    ids: string[] | number[],\n    models: Record<string, any>[],\n    ...args: MaybeContextualArg<Context<FabricClientFlags>>\n  ) {\n    const tableName = Model.tableName(clazz);\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const { ctxArgs } = this.logCtx(args, this.createAllPrefix);\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      Object.assign(record, models[count]);\n      return record;\n    });\n    return [clazz, ids, records, ...ctxArgs];\n  }\n\n  protected updateAllPrefix<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    models: Record<string, any>[],\n    ...args: MaybeContextualArg<Context<FabricClientFlags>>\n  ) {\n    const tableName = Model.tableName(clazz);\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const { ctxArgs } = this.logCtx(args, this.updateAllPrefix);\n    const records = ids.map(() => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      return record;\n    });\n    return [clazz, ids, records, ...ctxArgs];\n  }\n\n  /**\n   * @description Creates multiple records in a single transaction\n   * @summary Submits a transaction to create multiple records in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of record identifiers\n   * @param {Array<Record<string, any>>} models - Array of record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the created records\n   */\n  override async createAll<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    models: Record<string, any>[],\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>[]> {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    //HERE!\n    const ctxArgs = [...(args as unknown as any[])];\n    const transient = ctxArgs.shift() as Record<string, any>;\n    const { log, ctx } = this.logCtx(\n      ctxArgs as ContextualArgs<Context<FabricClientFlags>>,\n      this.createAll\n    );\n    const tableName = Model.tableName(clazz);\n\n    log.info(`adding ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const hasTransient = transient && Object.keys(transient).length > 0;\n    const needsFullPayload =\n      hasTransient || this.shouldForceGatewayHydration(ctx);\n    const transientPayload = hasTransient ? { [tableName]: transient } : {};\n\n    const result = await this.submitTransaction(\n      ctx,\n      BulkCrudOperationKeys.CREATE_ALL,\n      [\n        JSON.stringify(\n          models.map((m) => this.serializer.serialize(m, clazz.name))\n        ),\n      ],\n      transientPayload as any,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n\n    let res: Record<string, any>[];\n    try {\n      res = JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n\n    if (\n      this.shouldRefreshAfterWrite(\n        clazz,\n        ctx,\n        needsFullPayload,\n        res[0][Model.pk(clazz) as string] || ids[0]\n      )\n    ) {\n      return this.readAll(\n        clazz,\n        extractIds(\n          clazz,\n          models.map((m, i) =>\n            Model.merge(Object.assign({}, m as any, transient[i] || {}), res[i])\n          ),\n          ids\n        ),\n        ctx\n      );\n    }\n\n    return res;\n  }\n\n  /**\n   * @description Reads multiple records in a single transaction\n   * @summary Submits a transaction to read multiple records from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of record identifiers to read\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the retrieved records\n   */\n  override async readAll<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>[]> {\n    const { log, ctx } = this.logCtx(args, this.readAll);\n    const tableName = Model.tableName(clazz);\n    log.info(`reading ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const result = await this.evaluateTransaction(\n      ctx,\n      BulkCrudOperationKeys.READ_ALL,\n      [JSON.stringify(ids)],\n      undefined,\n      undefined,\n      clazz.name\n    );\n    try {\n      return JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n  }\n\n  /**\n   * @description Updates multiple records in a single transaction\n   * @summary Submits a transaction to update multiple records in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of record identifiers\n   * @param {Array<Record<string, any>>} models - Array of updated record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the updated records\n   */\n  override async updateAll<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    models: Record<string, any>[],\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>[]> {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const ctxArgs = [...(args as unknown as any[])];\n    const transient = ctxArgs.shift() as Record<string, any>;\n    const { log, ctx } = this.logCtx(\n      ctxArgs as ContextualArgs<Context<FabricClientFlags>>,\n      this.updateAll\n    );\n    const tableName = Model.tableName(clazz);\n    log.info(`updating ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const hasTransient = transient && Object.keys(transient).length > 0;\n    const needsFullPayload =\n      hasTransient || this.shouldForceGatewayHydration(ctx);\n    const transientPayload = hasTransient ? { [tableName]: transient } : {};\n\n    const result = await this.submitTransaction(\n      ctx,\n      BulkCrudOperationKeys.UPDATE_ALL,\n      [\n        JSON.stringify(\n          models.map((m) => this.serializer.serialize(m, clazz.name))\n        ),\n      ],\n      transientPayload as any,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n\n    let res: any;\n    try {\n      res = JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n\n    if (this.shouldRefreshAfterWrite(clazz, ctx, needsFullPayload, ids[0])) {\n      return this.readAll(\n        clazz,\n        extractIds(\n          clazz,\n          models.map((m, i) =>\n            Model.merge(Object.assign({}, m as any, transient[i] || {}), res[i])\n          ),\n          ids\n        ),\n        ctx\n      );\n    }\n    return res;\n  }\n\n  /**\n   * @description Deletes multiple records in a single transaction\n   * @summary Submits a transaction to delete multiple records from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of record identifiers to delete\n   * @param {Serializer<any>} serializer - Serializer for the model data\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the deleted records\n   */\n  override async deleteAll<M extends Model>(\n    clazz: Constructor<M>,\n    ids: PrimaryKeyType[],\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>[]> {\n    const { log, ctx, ctxArgs } = this.logCtx(args, this.deleteAll);\n    const tableName = Model.tableName(clazz);\n\n    const needsFullPayload =\n      Model.isTransient(clazz) || this.shouldForceGatewayHydration(ctx);\n    let result: any;\n    const shouldHydrate = this.shouldRefreshAfterWrite(\n      clazz,\n      ctx,\n      needsFullPayload,\n      ids[0]\n    );\n    if (shouldHydrate) {\n      result = await this.readAll(clazz, ids, ...ctxArgs);\n    }\n\n    log.info(`deleting ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const res = await this.submitTransaction(\n      ctx,\n      BulkCrudOperationKeys.DELETE_ALL,\n      [JSON.stringify(ids)],\n      undefined,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n    try {\n      return shouldHydrate\n        ? result\n        : JSON.parse(this.decode(res)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n  }\n\n  /**\n   * @description Prepares a model for persistence\n   * @summary Converts a model instance into a format suitable for database storage,\n   * handling column mapping and separating transient properties\n   * @template M - The model type\n   * @param {M} model - The model instance to prepare\n   * @param pk - The primary key property name\n   * @return The prepared data\n   */\n  override prepare<M extends Model>(\n    model: M,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): SegregatedModel<M> & PreparedModel {\n    const { log, ctx } = this.logCtx(args, this.prepare);\n    const split = Model.segregate(model);\n    if ((model as any)[PersistenceKeys.METADATA]) {\n      log.silly(\n        `Passing along persistence metadata for ${(model as any)[PersistenceKeys.METADATA]}`\n      );\n      Object.defineProperty(split.model, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        configurable: true,\n        value: (model as any)[PersistenceKeys.METADATA],\n      });\n    }\n\n    const mirrorMeta = Model.mirroredAt(model);\n    if (mirrorMeta) {\n      const mirrorMsp = mirrorMeta.mspId;\n      if (!mirrorMsp) throw new InternalError(`No mirror MSP could be found`);\n      let msps = this.getEndorsingOrganizations(ctx) || [];\n      msps = Array.isArray(msps) ? msps : [msps];\n      const merged = [...new Set([...msps, mirrorMsp])];\n      ctx.accumulate({\n        endorsingOrgs: merged,\n        endorsingOrganizations: merged,\n        legacy: true,\n      });\n    }\n\n    return {\n      record: split.model,\n      model: split.model,\n      id: model[Model.pk(model.constructor as Constructor<M>)] as string,\n      transient: split.transient,\n      privates: split.privates,\n      shared: split.shared,\n    };\n  }\n\n  override revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    transient?: Record<string, any>,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): M {\n    const { log, ctx } = this.logCtx(args, this.revert);\n    if (\n      transient &&\n      this.shouldRebuildWithTransient(\n        ctx,\n        ctx.getOrUndefined(\"operation\") as string | undefined\n      )\n    ) {\n      log.verbose(\n        `re-adding transient properties: ${Object.keys(transient).join(\", \")}`\n      );\n      Object.entries(transient as Record<string, any>)\n        .filter(([, v]) => typeof v !== \"undefined\")\n        .forEach(([key, val]) => {\n          if (key in obj && (obj as any)[key] !== undefined)\n            log.warn(\n              `overwriting existing ${key}. if this is not a default value, this may pose a problem`\n            );\n          (obj as M)[key as keyof M] = val;\n        });\n    }\n\n    const result = new (clazz as Constructor<M>)(obj);\n\n    return result;\n  }\n\n  private shouldRebuildWithTransient(\n    ctx: Context<FabricClientFlags>,\n    operation?: string\n  ): boolean {\n    if (!ctx) return false;\n    if (ctx.getOrUndefined(\"rebuildWithTransient\")) return true;\n    const childRebuild =\n      typeof (ctx as any).getFromChildren === \"function\"\n        ? (ctx as any).getFromChildren(\"rebuildWithTransient\")\n        : undefined;\n    if (childRebuild) return true;\n    const resolvedOp = this.resolveOperation(ctx, operation);\n    if (!resolvedOp) return false;\n    const op = resolvedOp.toString().toLowerCase();\n    return (\n      op.includes(\"read\") ||\n      op.includes(\"find\") ||\n      op.includes(\"query\") ||\n      op.includes(\"statement\") ||\n      op.includes(\"page\")\n    );\n  }\n\n  private resolveOperation(\n    ctx: Context<FabricClientFlags>,\n    operation?: string\n  ): string | undefined {\n    if (operation) return operation;\n    if (typeof (ctx as any).getFromChildren === \"function\") {\n      return (ctx as any).getFromChildren(\"operation\");\n    }\n    return undefined;\n  }\n\n  private shouldRefreshAfterWrite<M extends Model>(\n    clazz: Constructor<M>,\n    ctx: Context<FabricClientFlags>,\n    hasTransient: boolean,\n    id?: PrimaryKeyType\n  ): boolean {\n    if (!hasTransient) return false;\n    const pk = Model.pk(clazz);\n    const composed = Model.composed(clazz, pk);\n    const generated = Model.generated(clazz, pk);\n    const hasId = id !== undefined && id !== null;\n    if (!hasId && composed) return true;\n    if (!hasId && generated) {\n      ctx.logger.warn(\n        `Cannot refresh record with private generated primary key`\n      );\n      return false;\n    }\n    return hasId;\n  }\n\n  private getEndorsingOrganizations(\n    ctx: Context<FabricClientFlags>\n  ): string[] | undefined {\n    const direct =\n      ctx.getOrUndefined(\"endorsingOrgs\") ||\n      (ctx.getOrUndefined(\"endorsingOrgs\") as string[] | undefined);\n    if (direct && direct.length) return direct;\n    return (\n      (ctx.getFromChildren(\"endorsingOrgs\") as string[] | undefined) ||\n      (ctx.getFromChildren(\"endorsingOrgs\") as string[] | undefined)\n    );\n  }\n\n  private shouldForceGatewayHydration(\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ctx: Context<FabricClientFlags>\n  ): boolean {\n    return !!this.config.allowGatewayOverride;\n  }\n\n  /**\n   * @description Creates a single record\n   * @summary Submits a transaction to create a record in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @param {Record<string, any>} model - The record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Record<string, any>>} Promise resolving to the created record\n   */\n  @debug()\n  @final()\n  override async create<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    model: Record<string, any>,\n    transient: Record<string, any> = {},\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const ctxArgs = [...(args as unknown as any[])];\n    const { log, ctx } = this.logCtx(\n      ctxArgs as ContextualArgs<Context<FabricClientFlags>>,\n      this.create\n    );\n    const tableName = Model.tableName(clazz);\n    log.verbose(`adding entry to ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const hasTransient = transient && Object.keys(transient).length > 0;\n    const needsFullPayload =\n      hasTransient || this.shouldForceGatewayHydration(ctx);\n    const transientPayload = hasTransient ? { [tableName]: transient } : {};\n    const result = await this.submitTransaction(\n      ctx,\n      OperationKeys.CREATE,\n      [this.serializer.serialize(model, clazz.name)],\n      transientPayload as any,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n    const deserialized = this.serializer.deserialize(this.decode(result));\n    if (this.shouldRefreshAfterWrite(clazz, ctx, needsFullPayload, id)) {\n      return this.read(\n        clazz,\n        extractIds(\n          clazz,\n          Model.merge(\n            Object.assign({}, model, transient || {}),\n            deserialized,\n            clazz\n          ),\n          id\n        ),\n        ctx\n      );\n    }\n    return deserialized;\n  }\n\n  @debug()\n  @final()\n  async healthcheck<M extends Model>(\n    clazz: Constructor<M>,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const { log, ctx } = this.logCtx(args, this.healthcheck);\n    const tableName = Model.tableName(clazz);\n\n    log.verbose(`reading entry from ${tableName} table`);\n    const result = await this.evaluateTransaction(\n      ctx,\n      \"healthcheck\",\n      [],\n      undefined,\n      undefined,\n      clazz.name\n    );\n    return JSON.parse(this.decode(result));\n  }\n\n  /**\n   * @description Reads a single record\n   * @summary Evaluates a transaction to read a record from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @return {Promise<Record<string, any>>} Promise resolving to the retrieved record\n   */\n  @debug()\n  @final()\n  async read<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const { log, ctx } = this.logCtx(args, this.read);\n    const tableName = Model.tableName(clazz);\n\n    log.verbose(`reading entry from ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const result = await this.evaluateTransaction(\n      ctx,\n      OperationKeys.READ,\n      [id.toString()],\n      undefined,\n      undefined,\n      clazz.name\n    );\n    return this.serializer.deserialize(this.decode(result));\n  }\n\n  updatePrefix<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    model: Record<string, any>,\n    ...args: MaybeContextualArg<Context<FabricClientFlags>>\n  ) {\n    const tableName = Model.tableName(clazz);\n    const { ctxArgs } = this.logCtx(args, this.updatePrefix);\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    // record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    Object.assign(record, model);\n    return [clazz, id, record, ...ctxArgs];\n  }\n\n  /**\n   * @description Updates a single record\n   * @summary Submits a transaction to update a record in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @param {Record<string, any>} model - The updated record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Record<string, any>>} Promise resolving to the updated record\n   */\n  @debug()\n  @final()\n  async update<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    model: Record<string, any>,\n    transient: Record<string, any> = {},\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const ctxArgs = [...(args as unknown as any[])];\n    const { log, ctx } = this.logCtx(\n      ctxArgs as ContextualArgs<Context<FabricClientFlags>>,\n      this.update\n    );\n    log.info(`CLIENT UPDATE class : ${typeof clazz}`);\n    const tableName = Model.tableName(clazz);\n    log.verbose(`updating entry to ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const hasTransient = transient && Object.keys(transient).length > 0;\n    const needsFullPayload =\n      hasTransient || this.shouldForceGatewayHydration(ctx);\n    const transientPayload = hasTransient ? { [tableName]: transient } : {};\n    const result = await this.submitTransaction(\n      ctx,\n      OperationKeys.UPDATE,\n      [this.serializer.serialize(model, clazz.name || clazz)], // TODO should be receving class but is receiving string\n      transientPayload as any,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n    const deserialized = this.serializer.deserialize(this.decode(result));\n    if (this.shouldRefreshAfterWrite(clazz, ctx, needsFullPayload, id)) {\n      return this.read(\n        clazz,\n        extractIds(\n          clazz,\n          Model.merge(\n            Object.assign({}, model, transient || {}),\n            deserialized,\n            clazz\n          ),\n          id\n        ),\n        ctx\n      );\n    }\n    return deserialized;\n  }\n\n  /**\n   * @description Deletes a single record\n   * @summary Submits a transaction to delete a record from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier to delete\n   * @return {Promise<Record<string, any>>} Promise resolving to the deleted record\n   */\n  @debug()\n  @final()\n  override async delete<M extends Model>(\n    clazz: Constructor<M>,\n    id: PrimaryKeyType,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<Record<string, any>> {\n    const { log, ctx } = this.logCtx(args, this.delete);\n    const tableName = Model.tableName(clazz);\n    const needsFullPayload =\n      Model.isTransient(clazz) || this.shouldForceGatewayHydration(ctx);\n    let result: any;\n    const shouldHydrate = this.shouldRefreshAfterWrite(\n      clazz,\n      ctx,\n      needsFullPayload,\n      id\n    );\n    if (shouldHydrate) {\n      result = await this.read(clazz, id, ctx);\n    }\n\n    log.verbose(`deleting entry from ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const res = await this.submitTransaction(\n      ctx,\n      OperationKeys.DELETE,\n      [id.toString()],\n      undefined,\n      this.getEndorsingOrganizations(ctx),\n      clazz.name\n    );\n    return shouldHydrate\n      ? result\n      : this.serializer.deserialize(this.decode(res));\n  }\n\n  /**\n   * @description Executes a raw query against the Fabric ledger\n   * @summary Evaluates a transaction to perform a query using Mango Query syntax\n   * @template V - The return type\n   * @param {MangoQuery} rawInput - The Mango Query to execute\n   * @param {boolean} process - Whether to process the result\n   * @return {Promise<V>} Promise resolving to the query result\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant FabricAdapter\n   *   participant Contract\n   *   participant Chaincode\n   *\n   *   Client->>FabricAdapter: raw(rawInput, process)\n   *   FabricAdapter->>FabricAdapter: JSON.stringify(rawInput)\n   *   FabricAdapter->>FabricAdapter: evaluateTransaction(\"query\", [input])\n   *   FabricAdapter->>Contract: evaluate(\"query\", proposalOptions)\n   *   Contract->>Chaincode: invoke\n   *   Chaincode-->>Contract: response\n   *   Contract-->>FabricAdapter: result\n   *   FabricAdapter->>FabricAdapter: JSON.parse(decode(result))\n   *   FabricAdapter->>FabricAdapter: Process result based on type\n   *   FabricAdapter-->>Client: processed result\n   */\n  @debug()\n  async raw<V, D extends boolean>(\n    rawInput: MangoQuery,\n    docsOnly: D = true as D,\n    clazz: ModelConstructor<any>,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<V> {\n    const { log, ctx } = this.logCtx(args, this.raw);\n    const tableName = clazz.name;\n    log.info(`Performing raw statement on table ${Model.tableName(clazz)}`);\n    let transactionResult: any;\n    try {\n      transactionResult = await this.evaluateTransaction(\n        ctx,\n        \"raw\",\n        [JSON.stringify(rawInput), docsOnly],\n        undefined,\n        undefined,\n        tableName\n      );\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n    let result: any;\n    try {\n      result = JSON.parse(this.decode(transactionResult));\n    } catch (e: any) {\n      throw new SerializationError(`Failed to process result: ${e}`);\n    }\n\n    const parseRecord = (record: Record<any, any>) => {\n      if (Model.isModel(record)) return Model.build(record);\n      return record;\n    };\n\n    if (Array.isArray(result)) {\n      if (!result.length) return result as V;\n      const el = result[0];\n      if (Model.isModel(el))\n        // if the first one is a model, all are models\n        return result.map((el) => Model.build(el)) as V;\n      return result as V;\n    }\n\n    return parseRecord(result as any) as V;\n  }\n\n  /**\n   * @description Executes a CouchDB view query against the Fabric chaincode\n   * @summary Evaluates a transaction to query a design document view\n   * @template R - The view response type\n   * @param {string} ddoc - Design document name\n   * @param {string} viewName - View name\n   * @param {Record<string, any>} options - View query options\n   * @param {...ContextualArgs<Context<FabricClientFlags>>} args - Optional contextual arguments\n   * @return {Promise<ViewResponse<R>>} The view response\n   */\n  @debug()\n  async view<R>(\n    ddoc: string,\n    viewName: string,\n    options: Record<string, any>,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<ViewResponse<R>> {\n    const { log, ctx } = this.logCtx(args, this.view);\n    log.info(`Querying view ${ddoc}/${viewName}`);\n    let transactionResult: any;\n    try {\n      transactionResult = await this.evaluateTransaction(\n        ctx,\n        \"view\",\n        [ddoc, viewName, JSON.stringify(options)],\n        undefined,\n        undefined,\n        undefined\n      );\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n    let result: ViewResponse<R>;\n    try {\n      result = JSON.parse(this.decode(transactionResult));\n    } catch (e: any) {\n      throw new SerializationError(`Failed to process view result: ${e}`);\n    }\n    return result;\n  }\n\n  /**\n   * @description Gets or creates a gRPC client for the Fabric peer\n   * @summary Returns a cached client or creates a new one if none exists\n   * @return {Promise<Client>} Promise resolving to the gRPC client\n   */\n  override getClient(): Client {\n    if (!this._client)\n      this._client = FabricClientAdapter.getClient(this.config);\n    return this._client;\n  }\n\n  /**\n   * @description Gets a Gateway instance for the Fabric network\n   * @summary Creates a new Gateway instance using the current client\n   * @return {Promise<Gateway>} Promise resolving to the Gateway instance\n   */\n  protected async Gateway(ctx: Context<FabricClientFlags>): Promise<Gateway> {\n    return FabricClientAdapter.getGateway(ctx, this.config, this.client);\n  }\n\n  private getContractName(className?: string) {\n    if (!className) return undefined;\n    return `${className}Contract`;\n  }\n\n  /**\n   * @description Gets a Contract instance for the Fabric chaincode\n   * @summary Creates a new Contract instance using the current Gateway\n   * @return {Promise<Contrakt>} Promise resolving to the Contract instance\n   */\n  protected async Contract(\n    ctx: Context<FabricClientFlags>,\n    contractName?: string\n  ): Promise<Contrakt> {\n    return FabricClientAdapter.getContract(\n      await this.Gateway(ctx),\n      this.config,\n      contractName\n    );\n  }\n\n  /**\n   * @description Executes a transaction on the Fabric network\n   * @summary Submits or evaluates a transaction on the Fabric chaincode\n   * @param {string} api - The chaincode function to call\n   * @param {boolean} submit - Whether to submit (true) or evaluate (false) the transaction\n   * @param {any[]} [args] - Arguments to pass to the chaincode function\n   * @param {Record<string, string>} [transientData] - Transient data for the transaction\n   * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction\n   * @return {Promise<Uint8Array>} Promise resolving to the transaction result\n   * @mermaid\n   * sequenceDiagram\n   *   participant FabricAdapter\n   *   participant Gateway\n   *   participant Contract\n   *   participant Chaincode\n   *\n   *   FabricAdapter->>Gateway: connect()\n   *   FabricAdapter->>Contract: getContract()\n   *   alt submit transaction\n   *     FabricAdapter->>Contract: submit(api, proposalOptions)\n   *   else evaluate transaction\n   *     FabricAdapter->>Contract: evaluate(api, proposalOptions)\n   *   end\n   *   Contract->>Chaincode: invoke\n   *   Chaincode-->>Contract: response\n   *   Contract-->>FabricAdapter: result\n   *   FabricAdapter->>Gateway: close()\n   */\n  protected async transaction(\n    ctx: Context<FabricClientFlags>,\n    api: string,\n    submit = true,\n    args?: any[],\n    transientData: Record<string, string> = {},\n    endorsingOrganizations?: string[],\n    className?: string\n  ): Promise<Uint8Array> {\n    const log = this.log.for(this.transaction);\n    const gateway = await this.Gateway(ctx);\n    try {\n      const contract = await this.Contract(\n        ctx,\n        this.getContractName(className)\n      );\n      log.verbose(\n        `${submit ? \"Submit\" : \"Evaluate\"}ting transaction ${this.getContractName(className) || this.config.contractName}.${api}`\n      );\n      log.debug(`args: ${args?.map((a) => a.toString()).join(\"\\n\") || \"none\"}`);\n      const method = submit ? contract.submit : contract.evaluate;\n\n      endorsingOrganizations = endorsingOrganizations?.length\n        ? endorsingOrganizations\n        : undefined;\n      const proposalOptions: ProposalOptions = {\n        arguments: args || [],\n        transientData: Object.entries(transientData).reduce(\n          (acc, [key, val]) => {\n            acc[key] = JSON.stringify(val);\n            return acc;\n          },\n          {} as typeof transientData\n        ),\n        endorsingOrganizations: ctx.getOrUndefined(\"allowManualEndorsingOrgs\")\n          ? endorsingOrganizations || undefined\n          : undefined, // mspId list\n      };\n\n      return await method.call(contract, api, proposalOptions);\n    } catch (e: any) {\n      throw this.parseError(e);\n    } finally {\n      this.log.debug(`Closing ${this.config.mspId} gateway connection`);\n      gateway.close();\n    }\n  }\n\n  private shouldUseLegacyGateway(ctx: Context<FabricClientFlags>): boolean {\n    return !!ctx.getOrUndefined(\"legacy\") && !!this.config.allowGatewayOverride;\n  }\n\n  private prepareLegacyArgs(args?: any[]): string[] {\n    return (args || []).map((arg) =>\n      typeof arg === \"string\" ? arg : JSON.stringify(arg)\n    );\n  }\n\n  private buildLegacyTransient(\n    transientData?: Record<string, string>\n  ): Record<string, Buffer> | undefined {\n    if (!transientData) return undefined;\n    const entries = Object.entries(transientData);\n    if (!entries.length) return undefined;\n    const map: Record<string, Buffer> = {};\n    for (const [key, value] of entries) {\n      map[key] = Buffer.from(JSON.stringify(value));\n    }\n    return map;\n  }\n\n  private resolveLegacyMspCount(): number {\n    const configured = this.config.legacyMspCount ?? 1;\n    const parsed = Number(configured);\n    if (!Number.isFinite(parsed) || parsed < 1) return 1;\n    return Math.floor(parsed);\n  }\n\n  private pickLegacyCandidates(\n    candidates: MspDetails[],\n    limit: number\n  ): MspDetails[] {\n    if (!candidates.length || limit <= 0) return [];\n    const available = [...candidates];\n    const target = Math.min(limit, available.length);\n    const picked: MspDetails[] = [];\n    while (picked.length < target && available.length) {\n      const idx = Math.floor(Math.random() * available.length);\n      const [selection] = available.splice(idx, 1);\n      if (selection) {\n        picked.push(selection);\n      }\n    }\n    return picked;\n  }\n\n  private buildLegacyPeerConfigs(\n    ctx: Context<FabricClientFlags>\n  ): LegacyPeerTarget[] {\n    const peers: LegacyPeerTarget[] = [\n      {\n        mspId: this.config.mspId,\n        peerEndpoint: this.config.peerEndpoint,\n        peerHostAlias: this.config.peerHostAlias,\n        tlsCert: this.config.tlsCert,\n      },\n    ];\n\n    let endorsingOrgs = this.getEndorsingOrganizations(ctx) || [];\n    endorsingOrgs = Array.isArray(endorsingOrgs)\n      ? endorsingOrgs\n      : [endorsingOrgs];\n    const endorsers =\n      endorsingOrgs.filter((org): org is string => Boolean(org)) || [];\n    const extras = endorsers.filter((org) => org !== this.config.mspId);\n    if (!extras.length) return peers;\n\n    const map = this.config.mspMap;\n    const legacyCount = this.resolveLegacyMspCount();\n    for (const msp of extras) {\n      const candidates = map?.[msp];\n      if (!candidates?.length) {\n        throw new UnsupportedError(\n          `No peer mapping available for MSP ${msp}. Provide it via config.mspMap`\n        );\n      }\n      const selections = this.pickLegacyCandidates(candidates, legacyCount);\n      if (!selections.length) {\n        throw new UnsupportedError(\n          `No valid peer mapping available for MSP ${msp}. Provide it via config.mspMap`\n        );\n      }\n      for (const choice of selections) {\n        if (!choice.endpoint) {\n          throw new UnsupportedError(\n            `Invalid peer mapping for MSP ${msp}: missing endpoint`\n          );\n        }\n        peers.push({\n          mspId: msp,\n          peerEndpoint: choice.endpoint,\n          peerHostAlias: choice.alias,\n          tlsCert: choice.tlsCert || this.config.tlsCert,\n        });\n      }\n    }\n\n    return peers;\n  }\n\n  private async submitLegacyWithExplicitEndorsers(\n    ctx: Context<FabricClientFlags>,\n    fcn: string,\n    args: string[],\n    transientMap: Record<string, Buffer> | undefined,\n    peerConfigs: LegacyPeerTarget[],\n    className?: string\n  ): Promise<Uint8Array> {\n    const log = this.log.for(this.submitLegacyWithExplicitEndorsers);\n    const peers = this.normalizeLegacyPeers(peerConfigs);\n    const identityMaterial = await this.resolveLegacyIdentityMaterial();\n    const wallet = await Wallets.newInMemoryWallet();\n    const identityLabel = `${this.config.mspId}-legacy`;\n    await wallet.put(identityLabel, {\n      credentials: {\n        certificate: identityMaterial.certificate,\n        privateKey: identityMaterial.privateKey,\n      },\n      mspId: this.config.mspId,\n      type: \"X.509\",\n    } as Identity);\n\n    const connectionProfile = await this.buildLegacyConnectionProfile(peers);\n    const gateway = new LegacyGateway();\n\n    try {\n      await gateway.connect(connectionProfile, {\n        identity: identityLabel,\n        wallet,\n        discovery: {\n          enabled: true,\n          asLocalhost: this.shouldTreatPeersAsLocalhost(peers),\n        },\n        tlsInfo: {\n          certificate: identityMaterial.certificate,\n          key: identityMaterial.privateKey,\n        },\n      });\n\n      const network = await gateway.getNetwork(this.config.channel);\n      const contract = network.getContract(\n        this.config.chaincodeName,\n        this.getContractName(className)\n      );\n      const transaction = contract.createTransaction(fcn);\n\n      if (transientMap) {\n        transaction.setTransient(transientMap);\n      }\n\n      const endorsers = peers\n        .map((peer) => network.getChannel().getEndorser(peer.name))\n        .filter((endorser): endorser is Endorser => Boolean(endorser));\n      if (endorsers.length) {\n        transaction.setEndorsingPeers(endorsers);\n      }\n\n      log.verbose(\n        `Legacy submitting ${this.getContractName(className) || this.config.contractName}.${fcn} via peers ${peers.map((p) => p.peerEndpoint).join(\", \")}`\n      );\n\n      const result = await transaction.submit(...args);\n      return Uint8Array.from(result);\n    } catch (e: any) {\n      throw this.parseError(e);\n    } finally {\n      gateway.disconnect();\n    }\n  }\n\n  private normalizeLegacyPeers(\n    peers: LegacyPeerTarget[]\n  ): LegacyPeerWithName[] {\n    const deduped = new Map<string, LegacyPeerWithName>();\n    const addPeer = (peer: LegacyPeerTarget) => {\n      const key = `${peer.peerEndpoint}|${peer.peerHostAlias || \"\"}`;\n      if (deduped.has(key)) return;\n      const name = `peer-${peer.mspId}-${deduped.size}`;\n      deduped.set(key, {\n        ...peer,\n        name,\n      });\n    };\n\n    peers.forEach(addPeer);\n    addPeer({\n      mspId: this.config.mspId,\n      peerEndpoint: this.config.peerEndpoint,\n      peerHostAlias: this.config.peerHostAlias,\n    });\n\n    return Array.from(deduped.values());\n  }\n\n  private async resolveLegacyIdentityMaterial(): Promise<{\n    certificate: string;\n    privateKey: string;\n  }> {\n    const certificate = await this.readPemInput(\n      this.config.certCertOrDirectoryPath\n    );\n    const privateKey = await this.readPemInput(\n      this.config.keyCertOrDirectoryPath\n    );\n    return { certificate, privateKey };\n  }\n\n  private async buildLegacyConnectionProfile(peers: LegacyPeerWithName[]) {\n    const peerEntries: Record<string, any> = {};\n    const channelPeers: Record<string, any> = {};\n    const orgs: Record<string, any> = {};\n    for (const peer of peers) {\n      const tlsPem = await this.readPemInput(\n        peer.tlsCert || this.config.tlsCert\n      );\n      const hostname =\n        peer.peerHostAlias || this.extractHost(peer.peerEndpoint);\n      peerEntries[peer.name] = {\n        url: this.ensureGrpcUrl(peer.peerEndpoint),\n        tlsCACerts: { pem: tlsPem },\n        grpcOptions: {\n          \"ssl-target-name-override\": hostname,\n          hostnameOverride: hostname,\n        },\n      };\n      channelPeers[peer.name] = {\n        endorsingPeer: true,\n        chaincodeQuery: true,\n        ledgerQuery: true,\n        eventSource: true,\n      };\n      orgs[peer.mspId] = orgs[peer.mspId] || {\n        mspid: peer.mspId,\n        peers: [],\n      };\n      orgs[peer.mspId].peers.push(peer.name);\n    }\n\n    return {\n      name: \"legacy-manual\",\n      version: \"1.0.0\",\n      client: {\n        organization: this.config.mspId,\n      },\n      organizations: orgs,\n      peers: peerEntries,\n      orderers: {},\n      channels: {\n        [this.config.channel]: {\n          peers: channelPeers,\n        },\n      },\n    };\n  }\n\n  private shouldTreatPeersAsLocalhost(peers: LegacyPeerWithName[]): boolean {\n    return peers.every((peer) => this.isLocalEndpoint(peer.peerEndpoint));\n  }\n\n  private isLocalEndpoint(endpoint: string): boolean {\n    const host = this.extractHost(endpoint).toLowerCase();\n    return host === \"localhost\" || host === \"127.0.0.1\";\n  }\n\n  private extractHost(endpoint: string): string {\n    const sanitized = endpoint.replace(/^grpcs?:\\/\\//, \"\");\n    return sanitized.split(\":\")[0];\n  }\n\n  private ensureGrpcUrl(endpoint: string): string {\n    if (/^grpcs?:\\/\\//i.test(endpoint)) return endpoint;\n    return `grpcs://${endpoint}`;\n  }\n\n  private async readPemInput(source?: string | Buffer): Promise<string> {\n    if (!source) throw new InternalError(\"Missing certificate or key material\");\n    if (Buffer.isBuffer(source)) return source.toString(\"utf8\");\n    const trimmed = source.trim();\n    if (/-----BEGIN [A-Z ]+-----/.test(trimmed)) return trimmed;\n    const stats = await fs.promises.stat(source).catch(() => undefined);\n    if (stats?.isDirectory()) {\n      return await getFirstDirFileNameContent(source);\n    }\n    return (await readFsFile(source)).toString();\n  }\n\n  /**\n   * @description Parses an error into a BaseError\n   * @summary Converts any error into a standardized BaseError\n   * @param {Error | string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error\n   */\n  override parseError<E extends BaseError>(err: Error | string): E {\n    return FabricClientAdapter.parseError<E>(err);\n  }\n\n  /**\n   * @description Submits a transaction to the Fabric network\n   * @summary Executes a transaction that modifies the ledger state\n   * @param {string} api - The chaincode function to call\n   * @param {any[]} [args] - Arguments to pass to the chaincode function\n   * @param {Record<string, string>} [transientData] - Transient data for the transaction\n   * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction\n   * @return {Promise<Uint8Array>} Promise resolving to the transaction result\n   */\n  async submitTransaction(\n    ctx: Context<FabricClientFlags>,\n    api: string,\n    args?: any[],\n    transientData?: Record<string, string>,\n    endorsingOrganizations?: Array<string>,\n    className?: string\n  ): Promise<Uint8Array> {\n    if (this.shouldUseLegacyGateway(ctx)) {\n      const legacyArgs = this.prepareLegacyArgs(args);\n      const transientMap = this.buildLegacyTransient(transientData);\n      const peerConfigs = this.buildLegacyPeerConfigs(ctx);\n      return this.submitLegacyWithExplicitEndorsers(\n        ctx,\n        api,\n        legacyArgs,\n        transientMap,\n        peerConfigs,\n        className\n      );\n    }\n    return this.transaction(\n      ctx,\n      api,\n      true,\n      args,\n      transientData,\n      endorsingOrganizations,\n      className\n    );\n  }\n\n  /**\n   * @description Evaluates a transaction on the Fabric network\n   * @summary Executes a transaction that does not modify the ledger state\n   * @param {string} api - The chaincode function to call\n   * @param {any[]} [args] - Arguments to pass to the chaincode function\n   * @param {Record<string, string>} [transientData] - Transient data for the transaction\n   * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction\n   * @return {Promise<Uint8Array>} Promise resolving to the transaction result\n   */\n  async evaluateTransaction(\n    ctx: Context<FabricClientFlags>,\n    api: string,\n    args?: any[],\n    transientData?: Record<string, string>,\n    endorsingOrganizations?: Array<string>,\n    className?: string\n  ): Promise<Uint8Array> {\n    return this.transaction(\n      ctx,\n      api,\n      false,\n      args,\n      transientData,\n      endorsingOrganizations,\n      className\n    );\n  }\n\n  /**\n   * @description Shuts down the connection to the Fabric network\n   * @summary Closes the active dispatch (which in turn closes any gateway\n   * event subscription) via the base class, then closes the gRPC client.\n   * Works correctly regardless of whether `syntheticEvents` is enabled.\n   * @return {Promise<void>} Promise that resolves when all connections are closed\n   */\n  override async shutdown(...args: MaybeContextualArg<Context<FabricClientFlags>>): Promise<void> {\n    // Base class handles dispatch.close() internally.\n    await super.shutdown(...args);\n    if (this.client) {\n      this.log.verbose(`Closing ${this.config.mspId} gateway client`);\n      this.client.close();\n    }\n  }\n\n  /**\n   * @description Gets a Contract instance from a Gateway\n   * @summary Retrieves a chaincode contract from the specified network\n   * @param {Gateway} gateway - The Gateway instance\n   * @param {PeerConfig} config - The peer configuration\n   * @return {Contrakt} The Contract instance\n   */\n  static getContract(\n    gateway: Gateway,\n    config: PeerConfig,\n    contractName?: string\n  ): Contrakt {\n    const log = this.log.for(this.getContract);\n    const network = this.getNetwork(gateway, config.channel);\n    let contract: Contrakt;\n    try {\n      log.debug(\n        `Retrieving chaincode ${config.chaincodeName} contract ${contractName || config.contractName} from network ${config.channel}`\n      );\n      contractName = contractName ? contractName : config.contractName;\n      contract = network.getContract(config.chaincodeName, contractName);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return contract;\n  }\n\n  /**\n   * @description Gets a Network instance from a Gateway\n   * @summary Connects to a specific channel on the Fabric network\n   * @param {Gateway} gateway - The Gateway instance\n   * @param {string} channelName - The name of the channel to connect to\n   * @return {Network} The Network instance\n   */\n  static getNetwork(gateway: Gateway, channelName: string): Network {\n    const log = Logging.for(this.getNetwork);\n    let network: Network;\n    try {\n      log.debug(`Connecting to channel ${channelName}`);\n      network = gateway.getNetwork(channelName);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    return network;\n  }\n\n  /**\n   * @description Gets a Gateway instance for connecting to the Fabric network\n   * @summary Creates a Gateway using the provided configuration and client\n   * @param {PeerConfig} config - The peer configuration\n   * @param {Client} [client] - Optional gRPC client, will be created if not provided\n   * @return {Promise<Gateway>} Promise resolving to the Gateway instance\n   */\n  static async getGateway(\n    ctx: Context<FabricClientFlags>,\n    config: PeerConfig,\n    client?: Client\n  ) {\n    return (await this.getConnection(\n      client || (await this.getClient(config)),\n      config,\n      ctx\n    )) as Gateway;\n  }\n\n  /**\n   * @description Creates a gRPC client for connecting to a Fabric peer\n   * @summary Initializes a client with TLS credentials for secure communication\n   * @param {PeerConfig} config - The peer configuration\n   * @return {Client} Promise resolving to the gRPC client\n   */\n  static getClient(config: PeerConfig): Client {\n    const log = this.log.for(this.getClient);\n    log.debug(`generating TLS credentials for msp ${config.mspId}`);\n    let pathOrCert: string | Buffer = config.tlsCert as string | Buffer;\n\n    if (typeof pathOrCert === \"string\") {\n      if (\n        pathOrCert.match(\n          /-----BEGIN (CERTIFICATE|KEY|PRIVATE KEY)-----.+?-----END \\1-----$/gms\n        )\n      ) {\n        pathOrCert = Buffer.from(pathOrCert, \"utf8\");\n      } else {\n        try {\n          pathOrCert = Buffer.from(fs.readFileSync(pathOrCert, \"utf8\"));\n        } catch (e: unknown) {\n          throw new InternalError(\n            `Failed to read the tls certificate from ${pathOrCert}: ${e}`\n          );\n        }\n      }\n    }\n\n    const tlsCredentials = grpc.credentials.createSsl(pathOrCert);\n    log.debug(`generating Gateway Client for url ${config.peerEndpoint}`);\n    return new Client(config.peerEndpoint, tlsCredentials, {\n      \"grpc.max_receive_message_length\": (config.sizeLimit || 15) * 1024 * 1024,\n      \"grpc.max_send_message_length\": (config.sizeLimit || 15) * 1024 * 1024,\n    });\n  }\n\n  /**\n   * @description Establishes a connection to the Fabric network\n   * @summary Creates a Gateway connection with identity and signer\n   * @param {Client} client - The gRPC client\n   * @param {PeerConfig} config - The peer configuration\n   * @return {Promise<Gateway>} Promise resolving to the connected Gateway\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant FabricAdapter\n   *   participant Identity\n   *   participant Signer\n   *   participant Gateway\n   *\n   *   Caller->>FabricAdapter: getConnection(client, config)\n   *   FabricAdapter->>Identity: getIdentity(mspId, certDirectoryPath)\n   *   Identity-->>FabricAdapter: identity\n   *   FabricAdapter->>Signer: getSigner(keyDirectoryPath)\n   *   Signer-->>FabricAdapter: signer\n   *   FabricAdapter->>FabricAdapter: Create ConnectOptions\n   *   FabricAdapter->>Gateway: connect(options)\n   *   Gateway-->>FabricAdapter: gateway\n   *   FabricAdapter-->>Caller: gateway\n   */\n  static async getConnection(\n    client: Client,\n    config: PeerConfig,\n    ctx: Context<FabricClientFlags>\n  ) {\n    const log = Logging.for(this.getConnection);\n    log.debug(\n      `Retrieving Peer Identity for ${config.mspId} under ${config.certCertOrDirectoryPath}`\n    );\n    const identity = await getIdentity(\n      config.mspId,\n      config.certCertOrDirectoryPath as any\n    );\n    try {\n      log.debug(\n        `preparing transaction signer for ${CryptoUtils.fabricIdFromCertificate(identity.credentials.toString())}`\n      );\n    } catch (e: unknown) {\n      log.error(`Failed to extract Fabric ID from certificate`, e as Error);\n    }\n\n    let signer: Signer;\n    const close = () => {};\n    if (!config.hsm) {\n      signer = await getSigner(config.keyCertOrDirectoryPath as any);\n    } else {\n      // const hsm = new HSMSignerFactoryCustom(config.hsm.library);\n      // const identifier = hsm.getSKIFromCertificatePath(\n      //   config.certCertOrDirectoryPath as any\n      // );\n      // const pkcs11Signer = hsm.newSigner({\n      //   label: config.hsm.tokenLabel as string,\n      //   pin: String(config.hsm.pin) as string,\n      //   identifier: identifier,\n      //   // userType: 1 /*CKU_USER */,\n      // });\n      // signer = pkcs11Signer.signer;\n      // close = pkcs11Signer.close;\n      throw new UnsupportedError(\"HSM NOT IMPLEMENTED\");\n    }\n\n    const options = {\n      client,\n      identity: identity,\n      signer: signer,\n      // Default timeouts for different gRPC calls\n      evaluateOptions: () => {\n        return { deadline: Date.now() + 1000 * ctx.get(\"evaluateTimeout\") }; // defaults to 5 seconds\n      },\n      endorseOptions: () => {\n        return { deadline: Date.now() + 1000 * ctx.get(\"endorseTimeout\") }; // defaults to 15 seconds\n      },\n      submitOptions: () => {\n        return { deadline: Date.now() + 1000 * ctx.get(\"submitTimeout\") }; // defaults to 5 seconds\n      },\n      commitStatusOptions: () => {\n        return { deadline: Date.now() + 1000 * ctx.get(\"commitTimeout\") }; // defaults to 1 minute\n      },\n    } as ConnectOptions;\n\n    log.debug(`Connecting to ${config.mspId}`);\n    const gateway = connect(options);\n\n    // TODO: replace?\n    if (config.hsm) {\n      gateway.close = new Proxy(gateway.close, {\n        apply(target: () => void, thisArg: any, argArray: any[]): any {\n          Reflect.apply(target, thisArg, argArray);\n          close();\n        },\n      });\n    }\n\n    return gateway;\n  }\n\n  /**\n   * @description Creates a new Dispatch instance for the Fabric client.\n   * @summary This function is responsible for creating a new FabricClientDispatch instance that can be used to interact with the Fabric network.\n   * @returns {Dispatch} A new Dispatch instance configured for the Fabric client.\n   * @remarks The Dispatch instance is used to encapsulate the logic for interacting with the Fabric network, such as submitting transactions or querying data.\n   * @example\n   * const fabricDispatch = fabricClientAdapter.Dispatch();\n   * fabricDispatch.submitTransaction('createProduct', { name: 'Product A', price: 100 });\n   */\n  override Dispatch(): FabricClientDispatch {\n    return new FabricClientAdapter[\"_baseDispatch\"](this.client);\n  }\n\n  /**\n   * @description Parses an error into a BaseError\n   * @summary Converts any error into a standardized BaseError using the parent class implementation\n   * @param {Error | string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error\n   */\n  protected static parseError<E extends BaseError>(\n    err: Error | string | GatewayError\n  ): E {\n    // if (\n    //   MISSING_PRIVATE_DATA_REGEX.test(\n    //     typeof err === \"string\" ? err : err.message\n    //   )\n    // )\n    //   return new UnauthorizedPrivateDataAccess(err) as E;\n\n    let msg = typeof err === \"string\" ? err : err.message;\n    if (err instanceof GatewayError && err.details.length && err.code === 10) {\n      msg = `${err.details[0].message}`;\n    }\n\n    if (\n      err instanceof EndorseError &&\n      err.details.length &&\n      err.code === 10 &&\n      err.details[0].message?.includes(UnsupportedError.name)\n    ) {\n      msg = `${err.details[0].message}`;\n    }\n\n    if (msg.includes(\"MVCC_READ_CONFLICT\"))\n      return new MvccReadConflictError(err) as E;\n\n    if (msg.includes(\"DEADLINE_EXCEEDED\"))\n      return new TransactionTimeoutError(err) as E;\n\n    if (msg.includes(\"ENDORSEMENT_POLICY_FAILURE\"))\n      return new EndorsementPolicyError(err) as E;\n\n    if (msg.includes(\"PHANTOM_READ_CONFLICT\"))\n      return new PhantomReadConflictError(err) as E;\n\n    if (err instanceof Error && (err as any).code) {\n      switch ((err as any).code) {\n        case 9:\n          return new EndorsementError(err) as E;\n      }\n    }\n\n    if (msg.includes(ValidationError.name))\n      return new ValidationError(err) as E;\n    if (msg.includes(NotFoundError.name)) return new NotFoundError(err) as E;\n    if (msg.includes(ConflictError.name)) return new ConflictError(err) as E;\n    if (msg.includes(BadRequestError.name))\n      return new BadRequestError(err) as E;\n    if (msg.includes(QueryError.name)) return new QueryError(err) as E;\n    if (msg.includes(PagingError.name)) return new PagingError(err) as E;\n    if (msg.includes(UnsupportedError.name))\n      return new UnsupportedError(err) as E;\n    if (msg.includes(MigrationError.name)) return new MigrationError(err) as E;\n    if (msg.includes(ObserverError.name)) return new ObserverError(err) as E;\n    if (msg.includes(AuthorizationError.name))\n      return new AuthorizationError(err) as E;\n    if (msg.includes(ForbiddenError.name)) return new ForbiddenError(err) as E;\n    if (msg.includes(ConnectionError.name))\n      return new ConnectionError(err) as E;\n    if (msg.includes(SerializationError.name))\n      return new SerializationError(err) as E;\n    return new InternalError(err) as E;\n  }\n}\n\nFabricClientAdapter.decoration();\nAdapter.setCurrent(FabricFlavour);\n","import {\n  Adapter,\n  ContextualArgs,\n  Dispatch,\n  EventIds,\n  UnsupportedError,\n  Context,\n  MaybeContextualArg,\n  PersistenceKeys,\n} from \"@decaf-ts/core\";\nimport { PeerConfig } from \"../shared/types\";\nimport { Client } from \"@grpc/grpc-js\";\nimport { FabricClientAdapter } from \"./FabricClientAdapter\";\nimport {\n  BulkCrudOperationKeys,\n  InternalError,\n  OperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport {\n  ChaincodeEvent,\n  CloseableAsyncIterable,\n} from \"@hyperledger/fabric-gateway\";\nimport { parseEventName } from \"../shared/events\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { Constructor } from \"@decaf-ts/decoration\";\nimport { FabricClientFlags } from \"./types\";\n\n/**\n * @description Event dispatcher for Hyperledger Fabric chaincode events\n * @summary Listens for and processes events emitted by Fabric chaincode, dispatching them to registered observers\n * @template PeerConfig - Configuration type for connecting to a Fabric peer\n * @param client - gRPC client for connecting to the Fabric network\n * @class FabricClientDispatch\n * @example\n * ```typescript\n * // Create a new FabricDispatch instance\n * const client = await FabricAdapter.getClient(peerConfig);\n * const dispatch = new FabricDispatch(client);\n *\n * // Configure the dispatch with peer configuration\n * dispatch.configure(peerConfig);\n *\n * // Register an observer for a specific table and event\n * dispatch.observe('users', 'create', (id) => {\n *   console.log(`User created: ${id}`);\n * });\n *\n * // Start listening for events\n * await dispatch.start();\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant FabricDispatch\n *   participant Gateway\n *   participant Network\n *   participant Chaincode\n *\n *   Client->>FabricDispatch: new FabricDispatch(client)\n *   Client->>FabricDispatch: configure(peerConfig)\n *   Client->>FabricDispatch: observe(table, event, callback)\n *   Client->>FabricDispatch: start()\n *   FabricDispatch->>FabricDispatch: initialize()\n *   FabricDispatch->>Gateway: getGateway(config, client)\n *   Gateway->>Network: getNetwork(channel)\n *   Network->>Network: getChaincodeEvents(chaincodeName)\n *   FabricDispatch->>FabricDispatch: handleEvents()\n *   loop For each event\n *     Chaincode-->>FabricDispatch: ChaincodeEvent\n *     FabricDispatch->>FabricDispatch: parseEventName(eventName)\n *     FabricDispatch->>FabricDispatch: parsePayload(payload)\n *     FabricDispatch->>FabricDispatch: updateObservers(table, event, id)\n *     FabricDispatch-->>Client: callback(id)\n *   end\n */\nexport class FabricClientDispatch extends Dispatch<FabricClientAdapter> {\n  /**\n   * @description Event listening stack for chaincode events\n   */\n  private listeningStack?: CloseableAsyncIterable<ChaincodeEvent>;\n\n  /**\n   * @description Text decoder for converting event payloads from bytes to strings\n   */\n  private decoder = new TextDecoder(\"utf8\");\n\n  /**\n   * @description Creates a new FabricDispatch instance\n   * @summary Initializes a dispatcher for Fabric chaincode events\n   * @param {Client} client - gRPC client for connecting to the Fabric network\n   */\n  constructor(protected client: Client) {\n    super();\n  }\n\n  /**\n   * @description Closes the event listening connection\n   * @summary Stops listening for chaincode events and releases resources\n   * @return {Promise<void>} Promise that resolves when the connection is closed\n   */\n  override async close(\n    ...ctxArgs: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<void> {\n    const { log, ctxArgs: loggedArgs } = (\n      await this.logCtx(ctxArgs, PersistenceKeys.SHUTDOWN, true)\n    ).for(this.close);\n    try {\n      await super.close(...loggedArgs);\n    } catch (e: unknown) {\n      log.error(`Failed to close Fabric proxies event listener`, e as Error);\n    }\n    if (this.listeningStack) {\n      try {\n        await this.listeningStack.close();\n      } catch (e: unknown) {\n        log.error(`Failed to close Fabric event listener`, e as Error);\n      } finally {\n        this.listeningStack = undefined;\n      }\n    }\n  }\n\n  /**\n   * @description Parses event payload from binary format\n   * @summary Converts a Uint8Array containing JSON to an object with an id property\n   * @param {Uint8Array} jsonBytes - The binary payload from the chaincode event\n   * @return {{ id: string }} The parsed payload containing the record ID\n   */\n  private parsePayload(jsonBytes: Uint8Array): { id: string; result?: any } {\n    const json = this.decoder.decode(jsonBytes);\n    return JSON.parse(json);\n  }\n\n  /**\n   * @description Starts observing an adapter\n   * @summary Connects this dispatch to an adapter to monitor its operations\n   * @param {Adapter<any, any, any, any>} observer - The adapter to observe\n   * @return {void}\n   */\n  override observe(observer: Adapter<any, any, any, any>): () => void {\n    if (!(observer instanceof FabricClientAdapter))\n      throw new UnsupportedError(\n        \"Only FabricClientAdapter can be observed by dispatch\"\n      );\n    super.observe(observer as FabricClientAdapter);\n    return () => this.unObserve(observer);\n  }\n\n  /**\n   * @description Updates observers about a database event\n   * @summary Notifies observers about a change in the database\n   * @param {string} table - The name of the table where the change occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {any} payload - The event payload\n   * @return {Promise<void>} A promise that resolves when all observers have been notified\n   */\n  override async updateObservers(\n    model: Constructor<any> | string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: ContextualArgs<Context<FabricClientFlags>>\n  ): Promise<void> {\n    const { log, ctxArgs } = Adapter.logCtx<Context<FabricClientFlags>>(\n      this.updateObservers,\n      event,\n      false,\n      ...args\n    );\n    if (!this.adapter) {\n      log.verbose(\n        `No adapter observed for dispatch; skipping observer update for ${typeof model === \"string\" ? model : Model.tableName(model)}:${event}`\n      );\n      return;\n    }\n    try {\n      await this.adapter.refresh(model, event, id, ...ctxArgs);\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to refresh dispatch: ${e}`);\n    }\n  }\n\n  /**\n   * @description Processes incoming chaincode events\n   * @summary Listens for events from the chaincode and dispatches them to registered observers\n   * @return {Promise<void>} Promise that resolves when event handling stops\n   * @mermaid\n   * sequenceDiagram\n   *   participant FabricDispatch\n   *   participant EventStack\n   *   participant EventParser\n   *   participant Observers\n   *\n   *   FabricDispatch->>FabricDispatch: handleEvents()\n   *   FabricDispatch->>EventStack: for await (const evt of listeningStack)\n   *   EventStack-->>FabricDispatch: ChaincodeEvent\n   *   FabricDispatch->>EventParser: parseEventName(evt.eventName)\n   *   EventParser-->>FabricDispatch: { table, event, owner }\n   *   FabricDispatch->>FabricDispatch: Check if event is for this MSP\n   *   FabricDispatch->>FabricDispatch: parsePayload(evt.payload)\n   *   FabricDispatch->>Observers: updateObservers(table, event, payload.id)\n   *   Observers-->>FabricDispatch: Callbacks executed\n   */\n  protected async handleEvents(\n    ctxArg?: Context<FabricClientFlags>\n  ): Promise<void> {\n    if (!this.listeningStack)\n      throw new InternalError(\n        `Event stack not initialized. Ensure that \"startListening\" is called before attempting this operation.`\n      );\n\n    if (!this.adapter || !this.adapter.config)\n      throw new InternalError(`No adapter found. should be impossible`);\n\n    const ctx =\n      ctxArg ||\n      (await this.adapter.context(\n        OperationKeys.READ,\n        {\n          correlationId: this.adapter.config.chaincodeName,\n        },\n        (this.models && this.models[0]) || (Model as unknown as Constructor)\n      ));\n    const log = this.log.for(this.handleEvents);\n\n    log.info(\n      `Listening for incoming events on chaincode \"${this.adapter.config.chaincodeName}\" on channel \"${this.adapter.config.channel}\"...`\n    );\n\n    try {\n      for await (const evt of this.listeningStack) {\n        const { table, event, owner } = parseEventName(evt.eventName);\n        if (\n          this.adapter.config?.mspEventOnly &&\n          owner &&\n          owner !== this.adapter.config?.mspId\n        )\n          continue;\n        const payload: { id: string; result?: any } = this.parsePayload(\n          evt.payload\n        );\n        try {\n          const targetModel = table\n            ? Model.get(table)\n            : Model.get(this.models[0].name);\n          const modelRef = targetModel ?? (table || this.models[0]?.name);\n          const observerArgs = payload.result ? [payload.result, ctx] : [ctx];\n          await this.updateObservers(\n            modelRef as Constructor | string,\n            event,\n            payload.id as string,\n            ...(observerArgs as ContextualArgs<any>)\n          );\n        } catch (e: unknown) {\n          log.error(\n            `Failed update observables for table ${table} event ${event} id: ${payload.id}: ${e}`\n          );\n        }\n      }\n    } catch (e: any) {\n      log.error(\n        `Failed to read event for chaincode \"${this.adapter.config.chaincodeName}\" on channel \"${this.adapter.config.channel}\": ${e}`\n      );\n      await this.close(ctx);\n    }\n  }\n\n  /**\n   * @description Initializes the event listener\n   * @summary Sets up event dispatching for the observed adapter. When\n   * `syntheticEvents` is true (the default) no gateway connection is opened;\n   * instead every CRUD operation is wrapped with a Proxy that fires\n   * `updateObservers` for **all** models. When `syntheticEvents` is false the\n   * existing gateway-based chaincode-event subscription is established and the\n   * local Proxy fallback is limited to fully-segregated (transient) models only.\n   * @return {Promise<void>} Promise that resolves when initialization is complete\n   */\n  protected override async initialize(): Promise<void> {\n    if (!this.adapter)\n      throw new InternalError(`No adapter or config observed for dispatch`);\n\n    const syntheticEvents = this.adapter.config.syntheticEvents !== false;\n\n    if (!syntheticEvents) {\n      // Gateway-based chaincode-event subscription (non-synthetic path)\n      const context = await this.adapter.context(\n        \"dispatch\",\n        {\n          correlationId: this.adapter.config.chaincodeName,\n        },\n        Model as any\n      );\n      const { ctx } = this.logCtx([context], this.initialize);\n      const gateway = await FabricClientAdapter.getGateway(\n        ctx,\n        this.adapter.config as PeerConfig,\n        this.client\n      );\n      const network = gateway.getNetwork(this.adapter.config.channel);\n      if (!this.adapter)\n        throw new InternalError(`No adapter observed for dispatch`);\n      this.listeningStack = await network.getChaincodeEvents(\n        this.adapter.config.chaincodeName\n      );\n      this.handleEvents(ctx);\n    }\n\n    // Proxy CRUD methods.\n    // • syntheticEvents = true  → notify for ALL models (replaces gateway events entirely)\n    // • syntheticEvents = false → notify only for fully-segregated (transient) models\n    //   (the gateway subscription handles public models)\n    (\n      [\n        OperationKeys.CREATE,\n        OperationKeys.UPDATE,\n        OperationKeys.DELETE,\n        BulkCrudOperationKeys.CREATE_ALL,\n        BulkCrudOperationKeys.UPDATE_ALL,\n        BulkCrudOperationKeys.DELETE_ALL,\n      ] as (keyof Adapter<any, any, any, any>)[]\n    ).forEach((toWrap) => {\n      if (!this.adapter)\n        throw new InternalError(\n          `No adapter provided for the fallback of fully segregated models`\n        );\n      if (!this.adapter[toWrap])\n        throw new InternalError(\n          `Method ${toWrap} not found in ${this.adapter.alias} adapter to bind Observables Dispatch`\n        );\n\n      let descriptor = Object.getOwnPropertyDescriptor(this.adapter, toWrap);\n      let proto: any = this.adapter;\n      while (!descriptor && proto !== Object.prototype) {\n        proto = Object.getPrototypeOf(proto);\n        descriptor = Object.getOwnPropertyDescriptor(proto, toWrap);\n      }\n\n      if (!descriptor || !descriptor.writable) {\n        this.log.error(\n          `Could not find method ${toWrap} to bind Observables Dispatch`\n        );\n        return;\n      }\n      function bulkToSingle(method: string) {\n        switch (method) {\n          case BulkCrudOperationKeys.CREATE_ALL:\n            return OperationKeys.CREATE;\n          case BulkCrudOperationKeys.UPDATE_ALL:\n            return OperationKeys.UPDATE;\n          case BulkCrudOperationKeys.DELETE_ALL:\n            return OperationKeys.DELETE;\n          default:\n            return method;\n        }\n      }\n\n      // @ts-expect-error because there are read only properties\n      this.adapter[toWrap] = new Proxy(this.adapter[toWrap], {\n        apply: async (\n          target: any,\n          thisArg: FabricClientAdapter,\n          argArray: any[]\n        ) => {\n          // Run the original method unchanged so transient data is preserved\n          const result = await target.apply(thisArg, argArray);\n\n          const clazz: Constructor<any> = argArray[0];\n          // When syntheticEvents is false, public models emit a chaincode event\n          // on the contract side; skip the local fallback to avoid\n          // double-notification. When syntheticEvents is true we handle all models.\n          if (!syntheticEvents && !Model.isTransient(clazz)) return result;\n\n          // Context is always the last element of argArray\n          const { log, ctxArgs, ctx } = thisArg[\"logCtx\"](\n            argArray.slice(argArray.length - 1),\n            target\n          );\n          const ids = argArray[1];\n          const resultArgs: any[] = [clazz, bulkToSingle(toWrap), ids];\n\n          if (ctx.getOrUndefined(\"observeFullResult\")) {\n            resultArgs.push(result);\n          }\n          this.updateObservers(\n            ...(resultArgs as Parameters<typeof this.updateObservers>),\n            ...ctxArgs\n          ).catch((e: unknown) =>\n            log.error(\n              `Failed to dispatch observer refresh for ${toWrap} on ${clazz.name || clazz} for ${ids}: ${e}`\n            )\n          );\n          return result;\n        },\n      });\n    });\n  }\n}\n\nif (FabricClientAdapter)\n  FabricClientAdapter[\"_baseDispatch\"] = FabricClientDispatch;\n","import { Metadata } from \"@decaf-ts/decoration\";\n\nexport const VERSION = \"##VERSION##\";\nexport const PACKAGE_NAME = \"##PACKAGE##\";\n\nMetadata.registerLibrary(PACKAGE_NAME, VERSION);\n"],"names":["ensureDirectoryExistence","filePath","fs","require","path","dirname","existsSync","mkdirSync","generateModelIndexes","m","generateIndexes","generateModelDesignDocs","accum","views","generateViews","storage","forEach","doc","_id","readModelFile","file","exports","join","process","cwd","parentPath","name","values","Object","filter","e","Model","async","readModelFolders","folders","result","folder","files","readdirSync","withFileTypes","recursive","f","isFile","endsWith","push","writeIndexes","indexes","p","collection","index","resolve","writeFileSync","JSON","stringify","undefined","writeDesignDocs","designDocs","length","docId","replace","payload","_rev","collectionFor","collectionName","policy","requiredPeerCount","maxPeerCount","blockToLive","memberOnlyRead","memberOnlyWrite","privateCollectionFor","mspId","c","endorsementPolicy","signaturePolicy","sharedCollectionFor","mspIds","map","extractCollections","overrides","mirror","privateCols","sharedCols","collectionsFor","resolveCollection","arg","InternalError","privateDefaults","assign","sharedDefaults","mirrorMeta","mirroredAt","privates","flat","resolved","resolver","some","includes","shared","writeCollections","cols","fileName","writeCollectionDesignDocs","docs","FabricClientPaginator","Paginator","constructor","adapter","query","size","clazz","super","prepare","rawStatement","UnsupportedError","page","args","isSerializedPage","obj","Array","isArray","data","FabricClientRepository","Repository","force","this","_overrides","ignoreValidation","ignoreHandlers","allowRawStatements","forcePrepareSimpleQueries","forcePrepareComplexQueries","allowGenerationOverride","rebuildWithTransient","override","flags","for","ObserverHandler","paginateBy","key","order","ref","offset","limit","log","ctxArgs","logCtx","PreparedStatementKeys","PAGE_BY","verbose","tableName","class","statement","bookmark","listBy","LIST_BY","findBy","value","FIND_BY","findOneBy","FIND_ONE_BY","find","OrderDirection","ASC","FIND","direction","PAGE","ctx","PersistenceKeys","STATEMENT","callArgs","slice","parse","decode","evaluateTransaction","hydrated","r","CouchDBKeys","TABLE","d","applyAfterRead","getOrUndefined","enforceDBDecorators","OperationKeys","READ","AFTER","Promise","all","entry","countOf","COUNT_OF","stmtArgs","maxOf","MAX_OF","minOf","MIN_OF","avgOf","AVG_OF","sumOf","SUM_OF","distinctOf","DISTINCT_OF","groupOf","GROUP_OF","healthcheck","create","model","debug","ensureLegacyMirrorFlag","prepared","record","id","transient","revert","update","createAllPrefix","models","CREATE","get","ignoreValidate","ON","ignoredProps","errors","hasErrors","errorMessages","reduceErrorsToPrint","ValidationError","createAll","ids","payloads","transients","created","i","readAll","keys","records","updateAll","updated","u","accumulate","legacy","ERC20Token","BaseModel","__decorate","pk","type","String","prototype","column","required","table","ERC20Wallet","Allowance","ClientSerializer","JSONSerializer","preSerialize","modelName","toSerialize","metadata","Metadata","SerializationError","ModelKeys","ANCHOR","deserialize","str","deserialization","className","Error","build","serialize","FabricERC20ClientRepository","serializer","decoder","TextDecoder","updateObservers","event","observerHandler","count","parsedId","Sequence","parseValue","sequenceFor","tokenName","symbol","decimals","Number","totalSupply","total","balanceOf","owner","balance","transfer","to","transferred","submitTransaction","toString","transferFrom","from","contextArgs","Context","approve","spender","approved","allowance","initialize","token","initiliazed","checkInitialized","mint","amount","burn","burnFrom","account","clientAccountBalance","serializedAccountBalance","clientAccountID","extractIds","composed","pkProps","extractId","composeAttributeValue","IdentityCredentials","description","FabricModelKeys","IdentityType","FabricFlavour","Identity","X509","oneToOne","Cascade","CASCADE","delete","CoreUtils","logger","MiniLogger","contentOfLoadFile","contentOrPath","fileReader","Uint8Array","match","readFile","promises","normalizeImport","import","getCAUser","userName","privateKey","certificate","options","stringFormat","user","User","config","hsm","software","lib","library","slot","label","tokenLabel","pin","cryptoSuite","getCryptoSuite","setCryptoSuite","enrollmentKey","getHSMEnrollmentKey","getSoftwareEnrollmentKey","setEnrollment","newCryptoSuite","createKeyFromRaw","ski","keyIdHex","trim","Buffer","getCertificateSKI","getKey","isPrivate","x509","X509Certificate","jwk","publicKey","export","format","prefix","x","y","crypto","createHash","concat","digest","getIdentity","certDirectoryPath","identityFileReader","certPath","getFirstDirFileName","credentials","dirPath","readdir","getFirstDirFileNameContent","getFileContent","getSigner","keyDirectoryPath","signerFileReader","keyPath","privateKeyPem","extractPrivateKey","getOwnPropertySymbols","k","signers","newPrivateKeySigner","pem","libName","subtle","globalThis","window","Crypto","webcrypto","str2ab","buf","ArrayBuffer","bufView","strLen","charCodeAt","replaceAll","decoded","binaryDer","importKey","namedCurve","getAkiAndSerialFromCert","cert","x509Certificate","X509Cert","akiExt","extensions","aki","toUpperCase","startsWith","serial","serialNumber","cryptoProvider","set","BASE_ALPHABET","CRYPTO","BaseEncoder","alphabet","baseMap","j","charAt","xc","base","leader","factor","Math","iFactor","encode","source","isView","buffer","byteOffset","byteLength","zeroes","pbegin","pend","b58","carry","it1","it2","repeat","decodeUnsafe","psz","b256","it3","it4","vch","CryptoUtils","b58encoder","BASE58","fabricIdFromCertificate","subject","issuer","stringToArrayBuffer","extractKey","usages","RegExp","extractPublicKey","sign","buff","hash","b","padStart","verify","signature","encrypt","getSubtleCrypto","isBrowser","decrypt","getMaster","textEncoder","TextEncoder","genGenesis","randomUUID","importedKey","KEY_ALGORYTHM","iv","getDerivationKey","salt","saltBuffer","saltHashed","params","HASH","iterations","ITERATIONS","derivation","deriveBits","KEYLENGTH","ivlen","keylen","derivedKey","importedEncryptionKey","ALGORYTHM","encryptPin","text","keyObject","textBuffer","encryptedText","decryptPin","textDecoder","decryptedText","OverflowError","msg","BalanceError","AllowanceError","RegistrationError","AuthorizationError","MissingContextError","UnauthorizedPrivateDataAccess","BaseError","NotInitializedError","MissingPKCSS11Lib","EndorsementError","message","MvccReadConflictError","PhantomReadConflictError","EndorsementPolicyError","TransactionLimitsError","code","TransactionTimeoutError","TransactionBufferSizeError","HFCAIdentityType","HFCAIdentityAttributes","FabricEnrollmentService","LoggedClass","caConfig","caName","caCert","caKey","url","CA","ca","tls","trustedRoots","root","FabricCAServices","Client","client","Certificate","certificateService","newCertificateService","Affiliations","affiliationService","newAffiliationService","Identities","identityService","newIdentityService","getCertificates","request","doMap","response","certs","PEM","getIdentities","identitiesService","getAll","identities","parseError","regexp","exec","ConflictError","getAffiliations","a","read","enrollmentId","getOne","NotFoundError","success","register","isSuperUser","affiliation","userRole","attrs","maxEnrollments","registration","password","props","enrollmentID","enrollmentSecret","info","identityFromEnrollment","enrollment","rootCertificate","Logging","clientId","now","Date","toBytes","createdOn","updatedOn","enroll","identity","registerAndEnroll","revoke","reason","RegistrationRequestBuilder","errs","role","setAffiliation","addAttr","attr","setAttrs","setEnrollmentID","setEnrollmentSecret","setMaxEnrollments","setRole","minlength","min","ERC20Events","FabricBaseModel","createdAt","updatedAt","version","uses","FabricIdentifiedBaseModel","createdBy","updatedBy","isShared","segregate","isTransient","decoratedProperties","getAttributes","transientProps","DBKeys","TRANSIENT","privateProperties","PRIVATE","sharedProperties","SHARED","public","transientKeys","privateKeys","sharedKeys","isPublic","bind","mirrored","FABRIC","MIRROR","ownerOf","meta","OWNED_BY","sharedKey","constr","privateMeta","sharedMeta","collections","extractMspId","getMSPID","Owner","target","propertyKey","descriptor","originalMethod","acountId","clientIdentity","getID","select","tokens","execute","apply","ownedByOnCreate","context","stub","creator","getCreator","mspid","setOwnedByKeyValue","defineProperty","enumerable","writable","configurable","ownedBy","attribute","generated","readonly","onCreate","propMetadata","Decoration","define","decorator","transactionIdOnCreate","getTxID","transactionId","onUpdate","TRANSACTION_ID","evalMirrorMetadata","createMirrorHandler","fabricCtx","sourceModel","put","repo","mirrorCollection","updateMirrorHandler","applyUpdateValidation","mergeForUpdate","deleteMirrorHandler","pkProp","segregated","mirrorWriteGuard","msp","condition","readMirrorHandler","matches","readFrom","mspIdOrCondition","isConditionOnly","Boolean","cond","onRead","priority","onDelete","ModelCollection","orgName","toPascalCase","NamespaceCollection","namespace","ImplicitPrivateCollection","SEGREGATED_COLLECTION_EXTRACTION_PRIORITY","applySegregationFlags","isFullySegregated","hasPublicProperties","markFullySegregated","applyMirrorFlags","attributes","transientMeta","extractSegregatedCollections","dataArray","collectionResolver","keyArray","pkKey","pkSeqName","sequenceName","idValue","canBuildPerInstance","setSequenceSegregation","propSeqName","segregatedDataOnCreate","_k","keyStrings","writeTo","segregatedDataOnRead","segregatedDataOnUpdate","oldModel","segregatedDataOnDelete","innerSegregated","segregatedDec","Set","add","constrMeta","constrCollections","updatedTransientMeta","decs","properties","groupName","extractGroupName","dataGroupName","earlyExtractionMeta","earlyExtractionGroupSort","group","prop","on","DBOperations","ALL","privateData","sharedData","sortKeysOnlyRecursive","sort","reduce","acc","DeterministicSerializer","error","self","o","call","relations","generateFabricEventName","parseEventName","parts","split","sub","safeParseInt","string","digitRegex","test","parsedint","parseInt","isNaN","SimpleDeterministicSerializer","putAnchor","preSerialization","FabricIdentityService","ClientBasedService","rootClient","_user","certificates","affiliations","getUser","cfg","INITIALIZATION","getName","updateIdentity","identityRequest","caUserIdentity","reenrollUser","createUser","getMspid","enrollmentAttrs","optional","reenroll","renewedIdentity","revokeOptions","revokeRequest","CA_ROLE","DefaultFabricClientFlags","evaluateTimeout","endorseTimeout","submitTimeout","commitTimeout","allowManualEndorsingOrgs","allowGatewayOverride","encryptTransient","syntheticEvents","escapeRegExp","nextLexicographicString","chars","codePointAt","fromCodePoint","prefixRange","start","end","FabricClientStatement","Statement","squash","squashed","method","executePrepared","argz","forModel","fromSelector","alias","QUERY","isSimpleQuery","QueryClause","whereCondition","parsed","prepareCondition","selectSelector","SELECT","AND","toLowerCase","orderBySelectors","ORDER_BY","toCamelCase","processRecord","pkAttr","ID","keyArgs","SEPARATOR","raw","rawInput","aggregator","aggregateInfo","aggregate","executeAggregate","results","processed","applyAfterHandlersToResult","aggregateQuery","buildAggregateQuery","selectors","selector","fields","parseCondition","Condition","and","eq","selectorKeys","CouchDBGroupOperator","indexOf","val","OR","s","entries","warn","selectorKey","rec","CouchDBOperator","BIGGER","limitSelector","CouchDBQueryLimit","offsetSelector","skip","merge","op","obj1","obj2","attr1","operator","comparison","Operator","STARTS_WITH","QueryError","range","BIGGER_EQ","SMALLER","ENDS_WITH","REGEXP","BETWEEN","max","opBetween","translateOperators","SMALLER_EQ","GroupOperator","NOT","op1","op2","avgSelector","sumInfo","createAggregateDescriptor","countInfo","createAggregateQuery","kind","sumDescriptor","countDescriptor","countDistinctSelector","countDistinct","aggregatorUsed","countSelector","minSelector","maxSelector","sumSelector","distinctSelector","aggregatorChecks","metas","findViewMetadata","viewName","generateViewName","ddoc","generateDesignDocName","returnDocs","view","getFabricAdapter","isViewAggregate","handleAverage","fabricAdapter","viewInfo","processViewResponse","sumDesc","countDesc","sumResponse","countResponse","sum","rows","row","FabricClientAdapter","Adapter","operation","mergedFlags","silly","pop","toOverrides","newCtx","parentContext","childContexts","currentOp","currentModel","repository","createPrefix","updateAllPrefix","shift","hasTransient","needsFullPayload","shouldForceGatewayHydration","transientPayload","BulkCrudOperationKeys","CREATE_ALL","getEndorsingOrganizations","res","shouldRefreshAfterWrite","READ_ALL","UPDATE_ALL","deleteAll","shouldHydrate","DELETE_ALL","METADATA","mirrorMsp","msps","merged","endorsingOrgs","endorsingOrganizations","shouldRebuildWithTransient","v","childRebuild","getFromChildren","resolvedOp","resolveOperation","hasId","direct","deserialized","updatePrefix","UPDATE","DELETE","docsOnly","transactionResult","parseRecord","isModel","el","getClient","_client","Gateway","getGateway","getContractName","Contract","contractName","getContract","transaction","api","submit","transientData","gateway","contract","evaluate","proposalOptions","arguments","close","shouldUseLegacyGateway","prepareLegacyArgs","buildLegacyTransient","resolveLegacyMspCount","configured","legacyMspCount","isFinite","floor","pickLegacyCandidates","candidates","available","picked","idx","random","selection","splice","buildLegacyPeerConfigs","peers","peerEndpoint","peerHostAlias","tlsCert","endorsers","org","extras","mspMap","legacyCount","selections","choice","endpoint","submitLegacyWithExplicitEndorsers","fcn","transientMap","peerConfigs","normalizeLegacyPeers","identityMaterial","resolveLegacyIdentityMaterial","wallet","Wallets","newInMemoryWallet","identityLabel","connectionProfile","buildLegacyConnectionProfile","LegacyGateway","connect","discovery","enabled","asLocalhost","shouldTreatPeersAsLocalhost","tlsInfo","network","getNetwork","channel","chaincodeName","createTransaction","setTransient","peer","getChannel","getEndorser","endorser","setEndorsingPeers","disconnect","deduped","Map","addPeer","has","readPemInput","certCertOrDirectoryPath","keyCertOrDirectoryPath","peerEntries","channelPeers","orgs","tlsPem","hostname","extractHost","ensureGrpcUrl","tlsCACerts","grpcOptions","hostnameOverride","endorsingPeer","chaincodeQuery","ledgerQuery","eventSource","organization","organizations","orderers","channels","every","isLocalEndpoint","host","sanitized","isBuffer","trimmed","stats","stat","catch","isDirectory","readFsFile","err","legacyArgs","shutdown","channelName","getConnection","pathOrCert","readFileSync","tlsCredentials","grpc","createSsl","sizeLimit","signer","evaluateOptions","deadline","endorseOptions","submitOptions","commitStatusOptions","Proxy","thisArg","argArray","Reflect","Dispatch","GatewayError","details","EndorseError","BadRequestError","PagingError","MigrationError","ObserverError","ForbiddenError","ConnectionError","final","D","_a","decoration","setCurrent","FabricClientDispatch","loggedArgs","SHUTDOWN","listeningStack","parsePayload","jsonBytes","json","observe","observer","unObserve","refresh","handleEvents","ctxArg","correlationId","evt","eventName","mspEventOnly","targetModel","modelRef","observerArgs","getChaincodeEvents","toWrap","getOwnPropertyDescriptor","proto","getPrototypeOf","bulkToSingle","resultArgs","VERSION","PACKAGE_NAME","registerLibrary"],"mappings":"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"}
|