@decaf-ts/for-fabric 0.4.5 → 0.4.7

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.
@@ -3684,7 +3684,7 @@
3684
3684
  }
3685
3685
  }
3686
3686
  if (FabricClientAdapter) FabricClientAdapter["_baseDispatch"] = FabricClientDispatch;
3687
- const VERSION = "0.4.5";
3687
+ const VERSION = "0.4.7";
3688
3688
  const PACKAGE_NAME = "@decaf-ts/for-fabric";
3689
3689
  decoration.Metadata.registerLibrary(PACKAGE_NAME, VERSION);
3690
3690
  exports.AllowanceError = AllowanceError;
@@ -3871,7 +3871,7 @@ class FabricClientDispatch extends Dispatch {
3871
3871
 
3872
3872
  if (FabricClientAdapter) FabricClientAdapter["_baseDispatch"] = FabricClientDispatch;
3873
3873
 
3874
- const VERSION = "0.4.5";
3874
+ const VERSION = "0.4.7";
3875
3875
 
3876
3876
  const PACKAGE_NAME = "@decaf-ts/for-fabric";
3877
3877
 
@@ -11,7 +11,6 @@ const fs_1 = __importDefault(require("fs"));
11
11
  const path_1 = __importDefault(require("path"));
12
12
  const rollup_1 = require("rollup");
13
13
  const plugin_replace_1 = __importDefault(require("@rollup/plugin-replace"));
14
- const plugin_typescript_1 = __importDefault(require("@rollup/plugin-typescript"));
15
14
  const db_decorators_1 = require("@decaf-ts/db-decorators");
16
15
  const indexes_1 = require("./client/indexes/index.cjs");
17
16
  const decorator_validation_1 = require("@decaf-ts/decorator-validation");
@@ -20,6 +19,28 @@ require("./shared/overrides/index.cjs");
20
19
  const typescript_1 = __importDefault(require("typescript"));
21
20
  const index_1 = require("./client/collections/index.cjs");
22
21
  const logger = logging_1.Logging.for("fabric");
22
+ function resolveBundledJsImports() {
23
+ return {
24
+ name: "resolve-bundled-js-imports",
25
+ resolveId(source, importer) {
26
+ if (!importer || !source.startsWith(".")) {
27
+ return null;
28
+ }
29
+ const resolvedPath = path_1.default.resolve(path_1.default.dirname(importer), source);
30
+ const candidates = [
31
+ resolvedPath,
32
+ `${resolvedPath}.js`,
33
+ path_1.default.join(resolvedPath, "index.js"),
34
+ ];
35
+ for (const candidate of candidates) {
36
+ if (fs_1.default.existsSync(candidate) && fs_1.default.statSync(candidate).isFile()) {
37
+ return candidate;
38
+ }
39
+ }
40
+ return null;
41
+ },
42
+ };
43
+ }
23
44
  const compileCommand = new commander_1.Command()
24
45
  .name("compile-contract")
25
46
  .description("Creates a global contract")
@@ -64,33 +85,70 @@ const compileCommand = new commander_1.Command()
64
85
  (0, child_process_1.execSync)(`rm -rf ${output}`);
65
86
  if (bundle) {
66
87
  log.info(`bundling contract from ${input}`);
67
- const bundle = await (0, rollup_1.rollup)({
68
- input: `${input}/index.ts`,
69
- plugins: [
70
- (0, plugin_replace_1.default)({
71
- preventAssignment: true,
72
- delimiters: ["", ""],
73
- values: { "##VERSION##": version, "##PACKAGE##": pkg.name },
74
- }),
75
- (0, plugin_typescript_1.default)({
76
- tsconfig: tsConfigFile,
77
- compilerOptions: {
78
- outDir: output,
79
- sourceMap: sourcemaps,
80
- inlineSources: sourcemaps,
81
- },
82
- module: "esnext",
83
- declaration: false,
84
- }),
85
- ],
86
- });
87
- log.info(`withing contract to ${output} with name ${(0, logging_1.toPascalCase)(name)}.js`);
88
- await bundle.write({
89
- file: `${output}/${(0, logging_1.toPascalCase)(name)}.js`,
90
- format: "umd",
91
- name: `${(0, logging_1.toPascalCase)(name)}.js`,
92
- sourcemap: sourcemaps,
93
- });
88
+ const tempBundleDir = fs_1.default.mkdtempSync(path_1.default.join(process.cwd(), ".contract-bundle-"));
89
+ try {
90
+ const inputEntry = path_1.default.resolve(process.cwd(), input, "index.ts");
91
+ const configFile = typescript_1.default.readConfigFile(tsConfigFile, typescript_1.default.sys.readFile);
92
+ if (configFile.error) {
93
+ throw new db_decorators_1.InternalError(typescript_1.default.flattenDiagnosticMessageText(configFile.error.messageText, "\n"));
94
+ }
95
+ const parsedConfig = typescript_1.default.parseJsonConfigFileContent(configFile.config, typescript_1.default.sys, path_1.default.dirname(tsConfigFile), undefined, tsConfigFile);
96
+ if (parsedConfig.errors.length) {
97
+ throw new db_decorators_1.InternalError(parsedConfig.errors
98
+ .map((error) => typescript_1.default.flattenDiagnosticMessageText(error.messageText, "\n"))
99
+ .join("\n"));
100
+ }
101
+ const tempCompilerOptions = {
102
+ ...parsedConfig.options,
103
+ outDir: tempBundleDir,
104
+ module: typescript_1.default.ModuleKind.ESNext,
105
+ declaration: false,
106
+ sourceMap: false,
107
+ inlineSources: false,
108
+ };
109
+ const bundledEntryPoint = typescript_1.default
110
+ .getOutputFileNames({
111
+ ...parsedConfig,
112
+ options: tempCompilerOptions,
113
+ }, inputEntry, !typescript_1.default.sys.useCaseSensitiveFileNames)
114
+ .find((fileName) => fileName.endsWith(".js"));
115
+ if (!bundledEntryPoint) {
116
+ throw new db_decorators_1.InternalError(`Failed to determine the emitted bundle entry for ${inputEntry}`);
117
+ }
118
+ (0, cli_utils_1.compileWithTsconfigOverrides)(tsConfigFile, tempCompilerOptions);
119
+ const bundledContract = await (0, rollup_1.rollup)({
120
+ input: bundledEntryPoint,
121
+ plugins: [
122
+ resolveBundledJsImports(),
123
+ (0, plugin_replace_1.default)({
124
+ preventAssignment: true,
125
+ delimiters: ["", ""],
126
+ values: { "##VERSION##": version, "##PACKAGE##": pkg.name },
127
+ }),
128
+ ],
129
+ });
130
+ log.info(`withing contract to ${output} with name ${(0, logging_1.toPascalCase)(name)}.js`);
131
+ await bundledContract.write({
132
+ file: `${output}/${(0, logging_1.toPascalCase)(name)}.js`,
133
+ format: "umd",
134
+ name: `${(0, logging_1.toPascalCase)(name)}.js`,
135
+ sourcemap: sourcemaps ? "inline" : false,
136
+ sourcemapPathTransform: (relativeSourcePath, sourcemapPath) => {
137
+ const absoluteSourcePath = path_1.default.resolve(path_1.default.dirname(sourcemapPath), relativeSourcePath);
138
+ if (absoluteSourcePath.startsWith(tempBundleDir)) {
139
+ return path_1.default.posix.join(".bundle", path_1.default
140
+ .relative(tempBundleDir, absoluteSourcePath)
141
+ .split(path_1.default.sep)
142
+ .join("/"));
143
+ }
144
+ return relativeSourcePath;
145
+ },
146
+ });
147
+ await bundledContract.close();
148
+ }
149
+ finally {
150
+ fs_1.default.rmSync(tempBundleDir, { recursive: true, force: true });
151
+ }
94
152
  }
95
153
  else {
96
154
  (0, cli_utils_1.compileWithTsconfigOverrides)(tsConfigFile, {
@@ -418,4 +476,4 @@ fabricCmd.addCommand(extractCollections);
418
476
  function fabric() {
419
477
  return fabricCmd;
420
478
  }
421
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli-module.js","sourceRoot":"","sources":["../src/cli-module.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from \"commander\";\nimport { Logging, toPascalCase } from \"@decaf-ts/logging\";\nimport { execSync } from \"child_process\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { rollup } from \"rollup\";\nimport replace from \"@rollup/plugin-replace\";\nimport typescript from \"@rollup/plugin-typescript\";\nimport { InternalError, SerializationError } from \"@decaf-ts/db-decorators\";\nimport {\n  generateModelDesignDocs,\n  generateModelIndexes,\n  readModelFile,\n  readModelFolders,\n  writeDesignDocs,\n  writeIndexes,\n} from \"./client/indexes\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport {\n  approveContract,\n  ensureInfrastructureBooted,\n  installContract,\n  packageContract,\n  commitChaincode,\n  getContractStartCommand,\n  compileWithTsconfigOverrides,\n} from \"./cli-utils\";\nimport \"./shared/overrides\";\nimport ts from \"typescript\";\nimport {\n  extractCollections as exCollections,\n  PrivateCollection,\n  writeCollections,\n  writeCollectionDesignDocs,\n} from \"./client/collections/index\";\nimport { CouchDBDesignDoc, CreateIndexRequest } from \"@decaf-ts/for-couchdb\";\n\nconst logger = Logging.for(\"fabric\");\n\nconst compileCommand = new Command()\n  .name(\"compile-contract\")\n  .description(\"Creates a global contract\")\n  .option(\"--dev\", \"compiles contracts without minification\", false)\n  .option(\"--debug\", \"makes attaching debugger possible\", false)\n  .option(\n    \"--ccaas\",\n    \"Ajusts the package commands to be deployed as ccaas\",\n    false\n  )\n  .option(\"--name <String>\", \"contract name\", \"global-contract\")\n  .option(\"--bundle\", \"Bundles with rollup instead of using tsc\", false)\n  .option(\n    \"--ts-config-file <string>\",\n    \"relative path to the ts config file based on cwd or absolute path\",\n    \"./tsconfig.json\"\n  )\n  .option(\n    \"--description <String>\",\n    \"contract description\",\n    \"Global contract implementation\"\n  )\n  .option(\"--strip-contract-name\", \"strip contract name from output\", false)\n  .option(\"--input <String>\", \"input folder for contracts\", \"lib/contracts\")\n  .option(\"--output <String>\", \"output folder for contracts\", \"./contracts\")\n  .option(\"--sourcemaps\", \"includes sourcemaps in the compiled output\", false)\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    let {\n      // eslint-disable-next-line prefer-const\n      dev,\n      // eslint-disable-next-line prefer-const\n      debug,\n      // eslint-disable-next-line prefer-const\n      name,\n      // eslint-disable-next-line prefer-const\n      description,\n      output,\n      // eslint-disable-next-line prefer-const\n      input,\n      // eslint-disable-next-line prefer-const\n      stripContractName,\n      // eslint-disable-next-line prefer-const\n      ccaas,\n      // eslint-disable-next-line prefer-const\n      bundle,\n\n      tsConfigFile,\n      sourcemaps,\n    } = options;\n    const log = logger.for(\"compile-contract\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    tsConfigFile = path.isAbsolute(tsConfigFile)\n      ? tsConfigFile\n      : path.join(process.cwd(), tsConfigFile);\n\n    output = stripContractName ? output : path.join(output, name);\n    log.info(`Deleting existing output folder (if exists) under ${output}`);\n    execSync(`rm -rf ${output}`);\n    if (bundle) {\n      log.info(`bundling contract from ${input}`);\n      const bundle = await rollup({\n        input: `${input}/index.ts`,\n        plugins: [\n          replace({\n            preventAssignment: true,\n            delimiters: [\"\", \"\"],\n            values: { \"##VERSION##\": version, \"##PACKAGE##\": pkg.name },\n          }),\n          typescript({\n            tsconfig: tsConfigFile,\n            compilerOptions: {\n              outDir: output,\n              sourceMap: sourcemaps,\n              inlineSources: sourcemaps,\n            },\n            module: \"esnext\",\n            declaration: false,\n          }),\n        ],\n      });\n      log.info(\n        `withing contract to ${output} with name ${toPascalCase(name)}.js`\n      );\n      await bundle.write({\n        file: `${output}/${toPascalCase(name)}.js`,\n        format: \"umd\",\n        name: `${toPascalCase(name)}.js`,\n        sourcemap: sourcemaps,\n      });\n    } else {\n      compileWithTsconfigOverrides(tsConfigFile, {\n        outDir: output,\n        module: ts.ModuleKind.ESNext,\n        declaration: false,\n        sourceMap: sourcemaps,\n        inlineSources: sourcemaps,\n      });\n    }\n\n    const scripts = {\n      start: getContractStartCommand(debug, ccaas),\n      \"start:dev\": \"fabric-chaincode-node start --tls.enabled false\",\n      \"start:watch\": 'nodemon --exec \"npm run start:dev\"',\n      build: 'echo \"No need to build the chaincode\"',\n      lint: \"eslint . --fix --ext .js\",\n    };\n\n    const contractPackage = pkg;\n\n    contractPackage.name = name;\n    contractPackage.description = description;\n    contractPackage.scripts = scripts;\n\n    delete contractPackage.type;\n    delete contractPackage.types;\n    delete contractPackage.exports;\n    contractPackage.main = bundle\n      ? `${toPascalCase(name)}.js`\n      : `${input}/index.js`;\n\n    fs.writeFileSync(\n      path.join(output, \"package.json\"),\n      JSON.stringify(contractPackage)\n    );\n\n    log.info(`Installing and shrinkwrapping dependencies`);\n    execSync(`npm install`, { cwd: output });\n    execSync(`npm shrinkwrap`, { cwd: output });\n    execSync(\"rm -rf node_modules\", { cwd: output });\n    log.info(`deleting temp folders`);\n    execSync(`rm -rf ./lib && rm -rf ./dist`, { cwd: output });\n    log.info(\n      `Contract ${name} compiled successfully! in ${path.resolve(output)}`\n    );\n    if (dev) {\n      log.info(`dev mode enabled. installing dependencies for debugging`);\n      execSync(`npm install`, {\n        cwd: output,\n        env: { ...process.env, NODE_ENV: \"production\" },\n      });\n    }\n  });\n\nconst extractIndexes = new Command()\n  .command(\"extract-indexes\")\n  .option(\"--file [String]\", \"the model file\")\n  .option(\"--folder [String]\", \"the model folder\")\n  .option(\"--outDir <String>\", \"the outdir. should match your contract folder\")\n  .description(\n    \"Creates a the JSON index files to be submitted to along with the contract\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"extract-indexes\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    // eslint-disable-next-line prefer-const\n    let { file, folder, outDir } = options;\n\n    const models: any[] = [];\n    if (file) {\n      models.push(...readModelFile(file));\n    }\n\n    if (folder) {\n      log.info(`Loading models from ${folder}...`);\n      models.push(...(await readModelFolders(folder)));\n    }\n    const result: Record<string, any> = {};\n    const designDocs: Record<string, any> = {};\n\n    if (!file && !folder)\n      throw new InternalError(`Must pass a file or a folder`);\n\n    for (const m of models) {\n      log.verbose(`Extracting indexes for table ${Model.tableName(m)}`);\n      const indexes = generateModelIndexes(m);\n      indexes.forEach((index) => {\n        if (index.name) {\n          result[index.name] = index;\n        }\n      });\n      generateModelDesignDocs(m, designDocs);\n    }\n    const indexesToWrite = Object.values(result);\n    const docsToWrite = Object.values(designDocs);\n    log.verbose(`Found ${indexesToWrite.length} indexes to create`);\n    log.verbose(`Found ${docsToWrite.length} design docs to create`);\n    log.debug(`Indexes: ${JSON.stringify(result)}`);\n    log.debug(`DesignDocs: ${JSON.stringify(designDocs)}`);\n    writeIndexes(indexesToWrite, outDir);\n    writeDesignDocs(docsToWrite, outDir);\n  });\n\nconst extractCollections = new Command()\n  .command(\"extract-collections\")\n  .option(\"--file [String]\", \"the model file\")\n  .option(\"--folder [String]\", \"the model folder\")\n  .option(\"--outDir <String>\", \"the outdir. should match your contract folder\")\n  .option(\"--mspIds <String>\", \"single mspId or stringified array\")\n  .option(\"--mainMspId <String>\", \"single mspId\")\n  .option(\n    \"--overrides [String]\",\n    \"stringified override object {requiredPeerCount: number, maxPeerCount: number, blockToLive: number, memberOnlyRead: number, memberOnlyWrite: number, endorsementPolicy:  {}}\"\n  )\n  .description(\n    \"Creates a the JSON index files to be submitted to along with the contract\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"extract-collections\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    // eslint-disable-next-line prefer-const\n    let { file, folder, outDir, mspIds, mainMspId } = options;\n\n    try {\n      try {\n        mspIds = mspIds ? JSON.parse(mspIds) : undefined;\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: unknown) {\n        //  do nothing\n      }\n    } catch (e: unknown) {\n      throw new SerializationError(`Unable to extract mspids:  ${e}`);\n    }\n\n    const models: any[] = [];\n    if (file) {\n      models.push(...readModelFile(file));\n    }\n\n    if (folder) {\n      log.info(`Loading models from ${folder}...`);\n      models.push(...(await readModelFolders(folder)));\n    }\n\n    if (!file && !folder)\n      throw new InternalError(`Must pass a file or a folder`);\n\n    const injectableModels = models.filter(\n      (model) =>\n        Model.isShared(model) ||\n        Model.isPrivate(model) ||\n        !!Model.mirroredAt(model)\n    );\n    if (!injectableModels.length) {\n      log.info(\n        `No shared, private, or mirrored models found to extract collections`\n      );\n      return;\n    }\n\n    async function getCols(mspIdsList?: string[]) {\n      const cols: {\n        indexes: CreateIndexRequest[];\n        designDocs: CouchDBDesignDoc[];\n        mirror?: PrivateCollection;\n        collections: PrivateCollection[];\n      }[] = await Promise.all(\n        injectableModels.map(async (clazz) => {\n          const tableName = Model.tableName(clazz);\n          const mirrorMeta = Model.mirroredAt(clazz);\n\n          console.log(tableName);\n          const collections: Record<string, any> = {};\n          for (const msp of mspIdsList || mspIds || []) {\n            collections[msp] = await exCollections(\n              clazz,\n              [msp, mainMspId],\n              {},\n              // {\n              //   sharedCols: Object.assign({}, overrides.sharedCols),\n              //   privateCols: Object.assign({}, overrides.privateCols),\n              // },\n              !!mirrorMeta\n            );\n          }\n\n          let mirrorCollection: PrivateCollection | undefined = undefined;\n\n          if (mirrorMeta) {\n            collections[mainMspId] = collections[mainMspId] || {};\n            Object.keys(collections).forEach((msp: string) => {\n              collections[mainMspId].privates = collections[\n                msp\n              ].privates?.filter((p: any) => {\n                if (p.name !== (mirrorMeta.resolver as string)) return true;\n                mirrorCollection = p as any;\n                return false;\n              });\n            });\n          }\n\n          const privatesCount = Object.values(collections)\n            .map((c) => c.privates)\n            .flat().length;\n          if (privatesCount)\n            log\n              .for(Model.tableName(clazz))\n              .info(`Found ${privatesCount} private collections to create`);\n          const sharedCount = Object.values(collections)\n            .map((c) => c.shared)\n            .flat().length;\n\n          log\n            .for(Model.tableName(clazz))\n            .info(`Found ${sharedCount} shared collections to create`);\n          if (mirrorCollection)\n            log\n              .for(Model.tableName(clazz))\n              .info(\n                `Found one mirror collection ${mirrorMeta?.resolver as string}`\n              );\n\n          const colList = Object.values(collections)\n            .map((c) => [...(c.privates || []), ...(c.shared || [])])\n            .flat();\n          let indexes: CreateIndexRequest[] = [];\n          let designDocs: CouchDBDesignDoc[] = [];\n          if (colList.length) {\n            log\n              .for(Model.tableName(clazz))\n              .verbose(`generating indexes for collections`);\n            indexes = generateModelIndexes(clazz);\n            log\n              .for(Model.tableName(clazz))\n              .info(`found ${indexes.length} indexes`);\n            designDocs = generateModelDesignDocs(clazz);\n            log\n              .for(Model.tableName(clazz))\n              .info(`found ${designDocs.length} design docs`);\n          }\n          return {\n            indexes,\n            designDocs,\n            collections: colList,\n            mirror: mirrorCollection,\n          };\n        })\n      );\n      return cols;\n    }\n\n    const cols = await getCols();\n    const onlyMirror = await getCols([mainMspId]);\n\n    const collectionsTo = [\n      ...onlyMirror.filter((c) => c.mirror).map((c) => c.mirror),\n      ...cols.map((c) => c.collections).flat(),\n      ...cols.filter((c) => c.mirror).map((c) => c.mirror),\n    ] as PrivateCollection[];\n\n    const uniqueByCollection = [\n      ...new Map(\n        collectionsTo.map((item: PrivateCollection) => [item.name, item])\n      ).values(),\n    ];\n\n    if (uniqueByCollection.length) {\n      writeCollections(uniqueByCollection, outDir);\n      const metaCollectionsConfig = path.join(\n        outDir,\n        \"META-INF\",\n        \"collections_config.json\"\n      );\n      const contractCollectionsConfig = path.join(\n        outDir,\n        \"collections_config.json\"\n      );\n      fs.copyFileSync(metaCollectionsConfig, contractCollectionsConfig);\n      log.info(\n        `Stored ${collectionsTo.length} collections to ${metaCollectionsConfig}`\n      );\n      log.info(\n        `Copied collections_config to ${contractCollectionsConfig} alongside the package.json`\n      );\n\n      cols.forEach((c) => {\n        const { indexes, designDocs, collections, mirror } = c;\n        const toIndex: PrivateCollection[] = [...collections, mirror].filter(\n          Boolean\n        ) as PrivateCollection[];\n        toIndex.forEach((i) => {\n          writeIndexes(indexes, outDir, i.name);\n          writeCollectionDesignDocs(designDocs || [], outDir, i.name);\n          log.info(\n            `Stored ${indexes?.length || 0} indexes and ${designDocs?.length || 0} design docs to collection ${i.name}`\n          );\n        });\n      });\n    }\n  });\n\nconst ensureInfra = new Command()\n  .name(\"await-infra\")\n  .description(\"waits for the infrastructure to be up and running\")\n  .option(\n    \"--container <String>\",\n    \"docker container name to test (usually last peer)\",\n    \"boot-org-c-peer-0\"\n  )\n  .option(\"--timeout <String>\", \"timeout between tests in milliseconds\", \"5000\")\n  .option(\"--attempts <String>\", \"number of attempts before giving up\", \"10\")\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"await-infra\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n    // eslint-disable-next-line prefer-const\n    let { container, timeout, attempts } = options;\n    timeout = parseInt(timeout) || 5000;\n    attempts = parseInt(attempts) || 10;\n\n    await ensureInfrastructureBooted(\"boot-org-c-peer-0\", timeout, attempts);\n\n    log.info(\n      `Infrastructure booted successfully (according to container ${container})!`\n    );\n  });\n\nconst deployContract = new Command()\n  .name(\"deploy-contract\")\n  .description(\"deploys the selected contract\")\n  .option(\"--name <String>\", \"Contract Name (and folder)\")\n  .option(\"--input <String>\", \"input folder\")\n  .option(\n    \"--collections-config <String>\",\n    \"path to collections_config.json to configure private collections\"\n  )\n  .option(\n    \"--incrementVersion <String>\",\n    \"(true | false) if should use version or sequence to update contracts\",\n    false\n  )\n  .option(\n    \"--trackerFolder <String>\",\n    \"contract version tracker folder (should be deleted on infrastructure:down)\",\n    path.join(process.cwd(), \"tests\", \"integration\", \"chaincodeTrackers\")\n  )\n  .option(\n    \"--peers <String>\",\n    \"comma separated peer ids\",\n    \"org-a-peer-0,org-b-peer-0,org-c-peer-0\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"deploy-contract\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    const {\n      name,\n      input,\n      peers,\n      trackerFolder,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      incrementVersion,\n      collectionsConfig,\n    } = options;\n    const peerIds = peers.split(\",\");\n\n    const countPath = path.resolve(path.join(trackerFolder, `${name}.count`));\n\n    let sequence: number;\n\n    try {\n      sequence = parseInt(fs.readFileSync(countPath).toString(\"utf-8\"));\n      if (isNaN(sequence)) sequence = 1;\n      else sequence += 1;\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      sequence = 1;\n    }\n    //\n    // if (incrementVersion) {\n    //   version = version + `-${sequence}`;\n    //   // sequence = 1;\n    // }\n\n    try {\n      for (const peer of peerIds) {\n        packageContract(peer, input, name, version);\n        installContract(peer, name);\n        approveContract(\n          peer,\n          name,\n          peer === \"org-a-peer-0\"\n            ? \"tls-ca-cert.pem\"\n            : \"orderer-tls-ca-cert.pem\",\n          sequence,\n          version,\n          collectionsConfig\n        );\n      }\n      fs.writeFileSync(countPath, sequence.toString());\n    } catch (err: any) {\n      log.error(\"Error deploying contract:\", err);\n    }\n    commitChaincode(name, sequence, version, collectionsConfig);\n  });\n\nconst getCryptoMaterial = new Command()\n  .name(\"get-crypto-material\")\n  .description(\"copies the crypto material to the selected folder\")\n  .option(\"--folder <String>\", \"output folder\", \"docker/docker-data\")\n  .option(\"--org [String]\", \"the org/peer to extract from\", \"org-a\")\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"get-crypto-material\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n    const { folder, org } = options;\n    execSync(`docker cp ${org}:/weaver/client/. ${folder}`, {\n      cwd: process.cwd(),\n    });\n  });\n\nconst fabricCmd = new Command()\n  .name(\"for-fabric\")\n  .command(\"fabric\")\n  .description(\n    \"exposes several commands to help manage the fabric infrastructure\"\n  );\n\nfabricCmd.addCommand(compileCommand);\nfabricCmd.addCommand(extractIndexes);\nfabricCmd.addCommand(ensureInfra);\nfabricCmd.addCommand(deployContract);\nfabricCmd.addCommand(getCryptoMaterial);\nfabricCmd.addCommand(extractCollections);\n\nexport default function fabric() {\n  return fabricCmd;\n}\n"]}
479
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli-module.js","sourceRoot":"","sources":["../src/cli-module.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from \"commander\";\nimport { Logging, toPascalCase } from \"@decaf-ts/logging\";\nimport { execSync } from \"child_process\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { Plugin, rollup } from \"rollup\";\nimport replace from \"@rollup/plugin-replace\";\nimport { InternalError, SerializationError } from \"@decaf-ts/db-decorators\";\nimport {\n  generateModelDesignDocs,\n  generateModelIndexes,\n  readModelFile,\n  readModelFolders,\n  writeDesignDocs,\n  writeIndexes,\n} from \"./client/indexes\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport {\n  approveContract,\n  ensureInfrastructureBooted,\n  installContract,\n  packageContract,\n  commitChaincode,\n  getContractStartCommand,\n  compileWithTsconfigOverrides,\n} from \"./cli-utils\";\nimport \"./shared/overrides\";\nimport ts from \"typescript\";\nimport {\n  extractCollections as exCollections,\n  PrivateCollection,\n  writeCollections,\n  writeCollectionDesignDocs,\n} from \"./client/collections/index\";\nimport { CouchDBDesignDoc, CreateIndexRequest } from \"@decaf-ts/for-couchdb\";\n\nconst logger = Logging.for(\"fabric\");\n\nfunction resolveBundledJsImports(): Plugin {\n  return {\n    name: \"resolve-bundled-js-imports\",\n    resolveId(source, importer) {\n      if (!importer || !source.startsWith(\".\")) {\n        return null;\n      }\n\n      const resolvedPath = path.resolve(path.dirname(importer), source);\n      const candidates = [\n        resolvedPath,\n        `${resolvedPath}.js`,\n        path.join(resolvedPath, \"index.js\"),\n      ];\n\n      for (const candidate of candidates) {\n        if (fs.existsSync(candidate) && fs.statSync(candidate).isFile()) {\n          return candidate;\n        }\n      }\n\n      return null;\n    },\n  };\n}\n\nconst compileCommand = new Command()\n  .name(\"compile-contract\")\n  .description(\"Creates a global contract\")\n  .option(\"--dev\", \"compiles contracts without minification\", false)\n  .option(\"--debug\", \"makes attaching debugger possible\", false)\n  .option(\n    \"--ccaas\",\n    \"Ajusts the package commands to be deployed as ccaas\",\n    false\n  )\n  .option(\"--name <String>\", \"contract name\", \"global-contract\")\n  .option(\"--bundle\", \"Bundles with rollup instead of using tsc\", false)\n  .option(\n    \"--ts-config-file <string>\",\n    \"relative path to the ts config file based on cwd or absolute path\",\n    \"./tsconfig.json\"\n  )\n  .option(\n    \"--description <String>\",\n    \"contract description\",\n    \"Global contract implementation\"\n  )\n  .option(\"--strip-contract-name\", \"strip contract name from output\", false)\n  .option(\"--input <String>\", \"input folder for contracts\", \"lib/contracts\")\n  .option(\"--output <String>\", \"output folder for contracts\", \"./contracts\")\n  .option(\"--sourcemaps\", \"includes sourcemaps in the compiled output\", false)\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    let {\n      // eslint-disable-next-line prefer-const\n      dev,\n      // eslint-disable-next-line prefer-const\n      debug,\n      // eslint-disable-next-line prefer-const\n      name,\n      // eslint-disable-next-line prefer-const\n      description,\n      output,\n      // eslint-disable-next-line prefer-const\n      input,\n      // eslint-disable-next-line prefer-const\n      stripContractName,\n      // eslint-disable-next-line prefer-const\n      ccaas,\n      // eslint-disable-next-line prefer-const\n      bundle,\n\n      tsConfigFile,\n      sourcemaps,\n    } = options;\n    const log = logger.for(\"compile-contract\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    tsConfigFile = path.isAbsolute(tsConfigFile)\n      ? tsConfigFile\n      : path.join(process.cwd(), tsConfigFile);\n\n    output = stripContractName ? output : path.join(output, name);\n    log.info(`Deleting existing output folder (if exists) under ${output}`);\n    execSync(`rm -rf ${output}`);\n    if (bundle) {\n      log.info(`bundling contract from ${input}`);\n      const tempBundleDir = fs.mkdtempSync(\n        path.join(process.cwd(), \".contract-bundle-\")\n      );\n      try {\n        const inputEntry = path.resolve(process.cwd(), input, \"index.ts\");\n        const configFile = ts.readConfigFile(tsConfigFile, ts.sys.readFile);\n        if (configFile.error) {\n          throw new InternalError(\n            ts.flattenDiagnosticMessageText(configFile.error.messageText, \"\\n\")\n          );\n        }\n\n        const parsedConfig = ts.parseJsonConfigFileContent(\n          configFile.config,\n          ts.sys,\n          path.dirname(tsConfigFile),\n          undefined,\n          tsConfigFile\n        );\n        if (parsedConfig.errors.length) {\n          throw new InternalError(\n            parsedConfig.errors\n              .map((error) =>\n                ts.flattenDiagnosticMessageText(error.messageText, \"\\n\")\n              )\n              .join(\"\\n\")\n          );\n        }\n\n        const tempCompilerOptions: ts.CompilerOptions = {\n          ...parsedConfig.options,\n          outDir: tempBundleDir,\n          module: ts.ModuleKind.ESNext,\n          declaration: false,\n          sourceMap: false,\n          inlineSources: false,\n        };\n        const bundledEntryPoint = ts\n          .getOutputFileNames(\n            {\n              ...parsedConfig,\n              options: tempCompilerOptions,\n            },\n            inputEntry,\n            !ts.sys.useCaseSensitiveFileNames\n          )\n          .find((fileName) => fileName.endsWith(\".js\"));\n\n        if (!bundledEntryPoint) {\n          throw new InternalError(\n            `Failed to determine the emitted bundle entry for ${inputEntry}`\n          );\n        }\n\n        compileWithTsconfigOverrides(tsConfigFile, tempCompilerOptions);\n        const bundledContract = await rollup({\n          input: bundledEntryPoint,\n          plugins: [\n            resolveBundledJsImports(),\n            replace({\n              preventAssignment: true,\n              delimiters: [\"\", \"\"],\n              values: { \"##VERSION##\": version, \"##PACKAGE##\": pkg.name },\n            }),\n          ],\n        });\n        log.info(\n          `withing contract to ${output} with name ${toPascalCase(name)}.js`\n        );\n        await bundledContract.write({\n          file: `${output}/${toPascalCase(name)}.js`,\n          format: \"umd\",\n          name: `${toPascalCase(name)}.js`,\n          sourcemap: sourcemaps ? \"inline\" : false,\n          sourcemapPathTransform: (relativeSourcePath, sourcemapPath) => {\n            const absoluteSourcePath = path.resolve(\n              path.dirname(sourcemapPath),\n              relativeSourcePath\n            );\n\n            if (absoluteSourcePath.startsWith(tempBundleDir)) {\n              return path.posix.join(\n                \".bundle\",\n                path\n                  .relative(tempBundleDir, absoluteSourcePath)\n                  .split(path.sep)\n                  .join(\"/\")\n              );\n            }\n\n            return relativeSourcePath;\n          },\n        });\n        await bundledContract.close();\n      } finally {\n        fs.rmSync(tempBundleDir, { recursive: true, force: true });\n      }\n    } else {\n      compileWithTsconfigOverrides(tsConfigFile, {\n        outDir: output,\n        module: ts.ModuleKind.ESNext,\n        declaration: false,\n        sourceMap: sourcemaps,\n        inlineSources: sourcemaps,\n      });\n    }\n\n    const scripts = {\n      start: getContractStartCommand(debug, ccaas),\n      \"start:dev\": \"fabric-chaincode-node start --tls.enabled false\",\n      \"start:watch\": 'nodemon --exec \"npm run start:dev\"',\n      build: 'echo \"No need to build the chaincode\"',\n      lint: \"eslint . --fix --ext .js\",\n    };\n\n    const contractPackage = pkg;\n\n    contractPackage.name = name;\n    contractPackage.description = description;\n    contractPackage.scripts = scripts;\n\n    delete contractPackage.type;\n    delete contractPackage.types;\n    delete contractPackage.exports;\n    contractPackage.main = bundle\n      ? `${toPascalCase(name)}.js`\n      : `${input}/index.js`;\n\n    fs.writeFileSync(\n      path.join(output, \"package.json\"),\n      JSON.stringify(contractPackage)\n    );\n\n    log.info(`Installing and shrinkwrapping dependencies`);\n    execSync(`npm install`, { cwd: output });\n    execSync(`npm shrinkwrap`, { cwd: output });\n    execSync(\"rm -rf node_modules\", { cwd: output });\n    log.info(`deleting temp folders`);\n    execSync(`rm -rf ./lib && rm -rf ./dist`, { cwd: output });\n    log.info(\n      `Contract ${name} compiled successfully! in ${path.resolve(output)}`\n    );\n    if (dev) {\n      log.info(`dev mode enabled. installing dependencies for debugging`);\n      execSync(`npm install`, {\n        cwd: output,\n        env: { ...process.env, NODE_ENV: \"production\" },\n      });\n    }\n  });\n\nconst extractIndexes = new Command()\n  .command(\"extract-indexes\")\n  .option(\"--file [String]\", \"the model file\")\n  .option(\"--folder [String]\", \"the model folder\")\n  .option(\"--outDir <String>\", \"the outdir. should match your contract folder\")\n  .description(\n    \"Creates a the JSON index files to be submitted to along with the contract\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"extract-indexes\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    // eslint-disable-next-line prefer-const\n    let { file, folder, outDir } = options;\n\n    const models: any[] = [];\n    if (file) {\n      models.push(...readModelFile(file));\n    }\n\n    if (folder) {\n      log.info(`Loading models from ${folder}...`);\n      models.push(...(await readModelFolders(folder)));\n    }\n    const result: Record<string, any> = {};\n    const designDocs: Record<string, any> = {};\n\n    if (!file && !folder)\n      throw new InternalError(`Must pass a file or a folder`);\n\n    for (const m of models) {\n      log.verbose(`Extracting indexes for table ${Model.tableName(m)}`);\n      const indexes = generateModelIndexes(m);\n      indexes.forEach((index) => {\n        if (index.name) {\n          result[index.name] = index;\n        }\n      });\n      generateModelDesignDocs(m, designDocs);\n    }\n    const indexesToWrite = Object.values(result);\n    const docsToWrite = Object.values(designDocs);\n    log.verbose(`Found ${indexesToWrite.length} indexes to create`);\n    log.verbose(`Found ${docsToWrite.length} design docs to create`);\n    log.debug(`Indexes: ${JSON.stringify(result)}`);\n    log.debug(`DesignDocs: ${JSON.stringify(designDocs)}`);\n    writeIndexes(indexesToWrite, outDir);\n    writeDesignDocs(docsToWrite, outDir);\n  });\n\nconst extractCollections = new Command()\n  .command(\"extract-collections\")\n  .option(\"--file [String]\", \"the model file\")\n  .option(\"--folder [String]\", \"the model folder\")\n  .option(\"--outDir <String>\", \"the outdir. should match your contract folder\")\n  .option(\"--mspIds <String>\", \"single mspId or stringified array\")\n  .option(\"--mainMspId <String>\", \"single mspId\")\n  .option(\n    \"--overrides [String]\",\n    \"stringified override object {requiredPeerCount: number, maxPeerCount: number, blockToLive: number, memberOnlyRead: number, memberOnlyWrite: number, endorsementPolicy:  {}}\"\n  )\n  .description(\n    \"Creates a the JSON index files to be submitted to along with the contract\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"extract-collections\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    // eslint-disable-next-line prefer-const\n    let { file, folder, outDir, mspIds, mainMspId } = options;\n\n    try {\n      try {\n        mspIds = mspIds ? JSON.parse(mspIds) : undefined;\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: unknown) {\n        //  do nothing\n      }\n    } catch (e: unknown) {\n      throw new SerializationError(`Unable to extract mspids:  ${e}`);\n    }\n\n    const models: any[] = [];\n    if (file) {\n      models.push(...readModelFile(file));\n    }\n\n    if (folder) {\n      log.info(`Loading models from ${folder}...`);\n      models.push(...(await readModelFolders(folder)));\n    }\n\n    if (!file && !folder)\n      throw new InternalError(`Must pass a file or a folder`);\n\n    const injectableModels = models.filter(\n      (model) =>\n        Model.isShared(model) ||\n        Model.isPrivate(model) ||\n        !!Model.mirroredAt(model)\n    );\n    if (!injectableModels.length) {\n      log.info(\n        `No shared, private, or mirrored models found to extract collections`\n      );\n      return;\n    }\n\n    async function getCols(mspIdsList?: string[]) {\n      const cols: {\n        indexes: CreateIndexRequest[];\n        designDocs: CouchDBDesignDoc[];\n        mirror?: PrivateCollection;\n        collections: PrivateCollection[];\n      }[] = await Promise.all(\n        injectableModels.map(async (clazz) => {\n          const tableName = Model.tableName(clazz);\n          const mirrorMeta = Model.mirroredAt(clazz);\n\n          console.log(tableName);\n          const collections: Record<string, any> = {};\n          for (const msp of mspIdsList || mspIds || []) {\n            collections[msp] = await exCollections(\n              clazz,\n              [msp, mainMspId],\n              {},\n              // {\n              //   sharedCols: Object.assign({}, overrides.sharedCols),\n              //   privateCols: Object.assign({}, overrides.privateCols),\n              // },\n              !!mirrorMeta\n            );\n          }\n\n          let mirrorCollection: PrivateCollection | undefined = undefined;\n\n          if (mirrorMeta) {\n            collections[mainMspId] = collections[mainMspId] || {};\n            Object.keys(collections).forEach((msp: string) => {\n              collections[mainMspId].privates = collections[\n                msp\n              ].privates?.filter((p: any) => {\n                if (p.name !== (mirrorMeta.resolver as string)) return true;\n                mirrorCollection = p as any;\n                return false;\n              });\n            });\n          }\n\n          const privatesCount = Object.values(collections)\n            .map((c) => c.privates)\n            .flat().length;\n          if (privatesCount)\n            log\n              .for(Model.tableName(clazz))\n              .info(`Found ${privatesCount} private collections to create`);\n          const sharedCount = Object.values(collections)\n            .map((c) => c.shared)\n            .flat().length;\n\n          log\n            .for(Model.tableName(clazz))\n            .info(`Found ${sharedCount} shared collections to create`);\n          if (mirrorCollection)\n            log\n              .for(Model.tableName(clazz))\n              .info(\n                `Found one mirror collection ${mirrorMeta?.resolver as string}`\n              );\n\n          const colList = Object.values(collections)\n            .map((c) => [...(c.privates || []), ...(c.shared || [])])\n            .flat();\n          let indexes: CreateIndexRequest[] = [];\n          let designDocs: CouchDBDesignDoc[] = [];\n          if (colList.length) {\n            log\n              .for(Model.tableName(clazz))\n              .verbose(`generating indexes for collections`);\n            indexes = generateModelIndexes(clazz);\n            log\n              .for(Model.tableName(clazz))\n              .info(`found ${indexes.length} indexes`);\n            designDocs = generateModelDesignDocs(clazz);\n            log\n              .for(Model.tableName(clazz))\n              .info(`found ${designDocs.length} design docs`);\n          }\n          return {\n            indexes,\n            designDocs,\n            collections: colList,\n            mirror: mirrorCollection,\n          };\n        })\n      );\n      return cols;\n    }\n\n    const cols = await getCols();\n    const onlyMirror = await getCols([mainMspId]);\n\n    const collectionsTo = [\n      ...onlyMirror.filter((c) => c.mirror).map((c) => c.mirror),\n      ...cols.map((c) => c.collections).flat(),\n      ...cols.filter((c) => c.mirror).map((c) => c.mirror),\n    ] as PrivateCollection[];\n\n    const uniqueByCollection = [\n      ...new Map(\n        collectionsTo.map((item: PrivateCollection) => [item.name, item])\n      ).values(),\n    ];\n\n    if (uniqueByCollection.length) {\n      writeCollections(uniqueByCollection, outDir);\n      const metaCollectionsConfig = path.join(\n        outDir,\n        \"META-INF\",\n        \"collections_config.json\"\n      );\n      const contractCollectionsConfig = path.join(\n        outDir,\n        \"collections_config.json\"\n      );\n      fs.copyFileSync(metaCollectionsConfig, contractCollectionsConfig);\n      log.info(\n        `Stored ${collectionsTo.length} collections to ${metaCollectionsConfig}`\n      );\n      log.info(\n        `Copied collections_config to ${contractCollectionsConfig} alongside the package.json`\n      );\n\n      cols.forEach((c) => {\n        const { indexes, designDocs, collections, mirror } = c;\n        const toIndex: PrivateCollection[] = [...collections, mirror].filter(\n          Boolean\n        ) as PrivateCollection[];\n        toIndex.forEach((i) => {\n          writeIndexes(indexes, outDir, i.name);\n          writeCollectionDesignDocs(designDocs || [], outDir, i.name);\n          log.info(\n            `Stored ${indexes?.length || 0} indexes and ${designDocs?.length || 0} design docs to collection ${i.name}`\n          );\n        });\n      });\n    }\n  });\n\nconst ensureInfra = new Command()\n  .name(\"await-infra\")\n  .description(\"waits for the infrastructure to be up and running\")\n  .option(\n    \"--container <String>\",\n    \"docker container name to test (usually last peer)\",\n    \"boot-org-c-peer-0\"\n  )\n  .option(\"--timeout <String>\", \"timeout between tests in milliseconds\", \"5000\")\n  .option(\"--attempts <String>\", \"number of attempts before giving up\", \"10\")\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"await-infra\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n    // eslint-disable-next-line prefer-const\n    let { container, timeout, attempts } = options;\n    timeout = parseInt(timeout) || 5000;\n    attempts = parseInt(attempts) || 10;\n\n    await ensureInfrastructureBooted(\"boot-org-c-peer-0\", timeout, attempts);\n\n    log.info(\n      `Infrastructure booted successfully (according to container ${container})!`\n    );\n  });\n\nconst deployContract = new Command()\n  .name(\"deploy-contract\")\n  .description(\"deploys the selected contract\")\n  .option(\"--name <String>\", \"Contract Name (and folder)\")\n  .option(\"--input <String>\", \"input folder\")\n  .option(\n    \"--collections-config <String>\",\n    \"path to collections_config.json to configure private collections\"\n  )\n  .option(\n    \"--incrementVersion <String>\",\n    \"(true | false) if should use version or sequence to update contracts\",\n    false\n  )\n  .option(\n    \"--trackerFolder <String>\",\n    \"contract version tracker folder (should be deleted on infrastructure:down)\",\n    path.join(process.cwd(), \"tests\", \"integration\", \"chaincodeTrackers\")\n  )\n  .option(\n    \"--peers <String>\",\n    \"comma separated peer ids\",\n    \"org-a-peer-0,org-b-peer-0,org-c-peer-0\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"deploy-contract\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    const {\n      name,\n      input,\n      peers,\n      trackerFolder,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      incrementVersion,\n      collectionsConfig,\n    } = options;\n    const peerIds = peers.split(\",\");\n\n    const countPath = path.resolve(path.join(trackerFolder, `${name}.count`));\n\n    let sequence: number;\n\n    try {\n      sequence = parseInt(fs.readFileSync(countPath).toString(\"utf-8\"));\n      if (isNaN(sequence)) sequence = 1;\n      else sequence += 1;\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      sequence = 1;\n    }\n    //\n    // if (incrementVersion) {\n    //   version = version + `-${sequence}`;\n    //   // sequence = 1;\n    // }\n\n    try {\n      for (const peer of peerIds) {\n        packageContract(peer, input, name, version);\n        installContract(peer, name);\n        approveContract(\n          peer,\n          name,\n          peer === \"org-a-peer-0\"\n            ? \"tls-ca-cert.pem\"\n            : \"orderer-tls-ca-cert.pem\",\n          sequence,\n          version,\n          collectionsConfig\n        );\n      }\n      fs.writeFileSync(countPath, sequence.toString());\n    } catch (err: any) {\n      log.error(\"Error deploying contract:\", err);\n    }\n    commitChaincode(name, sequence, version, collectionsConfig);\n  });\n\nconst getCryptoMaterial = new Command()\n  .name(\"get-crypto-material\")\n  .description(\"copies the crypto material to the selected folder\")\n  .option(\"--folder <String>\", \"output folder\", \"docker/docker-data\")\n  .option(\"--org [String]\", \"the org/peer to extract from\", \"org-a\")\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"get-crypto-material\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n    const { folder, org } = options;\n    execSync(`docker cp ${org}:/weaver/client/. ${folder}`, {\n      cwd: process.cwd(),\n    });\n  });\n\nconst fabricCmd = new Command()\n  .name(\"for-fabric\")\n  .command(\"fabric\")\n  .description(\n    \"exposes several commands to help manage the fabric infrastructure\"\n  );\n\nfabricCmd.addCommand(compileCommand);\nfabricCmd.addCommand(extractIndexes);\nfabricCmd.addCommand(ensureInfra);\nfabricCmd.addCommand(deployContract);\nfabricCmd.addCommand(getCryptoMaterial);\nfabricCmd.addCommand(extractCollections);\n\nexport default function fabric() {\n  return fabricCmd;\n}\n"]}
@@ -5,7 +5,6 @@ import fs from "fs";
5
5
  import path from "path";
6
6
  import { rollup } from "rollup";
7
7
  import replace from "@rollup/plugin-replace";
8
- import typescript from "@rollup/plugin-typescript";
9
8
  import { InternalError, SerializationError } from "@decaf-ts/db-decorators";
10
9
  import { generateModelDesignDocs, generateModelIndexes, readModelFile, readModelFolders, writeDesignDocs, writeIndexes, } from "./client/indexes/index.js";
11
10
  import { Model } from "@decaf-ts/decorator-validation";
@@ -14,6 +13,28 @@ import "./shared/overrides/index.js";
14
13
  import ts from "typescript";
15
14
  import { extractCollections as exCollections, writeCollections, writeCollectionDesignDocs, } from "./client/collections/index.js";
16
15
  const logger = Logging.for("fabric");
16
+ function resolveBundledJsImports() {
17
+ return {
18
+ name: "resolve-bundled-js-imports",
19
+ resolveId(source, importer) {
20
+ if (!importer || !source.startsWith(".")) {
21
+ return null;
22
+ }
23
+ const resolvedPath = path.resolve(path.dirname(importer), source);
24
+ const candidates = [
25
+ resolvedPath,
26
+ `${resolvedPath}.js`,
27
+ path.join(resolvedPath, "index.js"),
28
+ ];
29
+ for (const candidate of candidates) {
30
+ if (fs.existsSync(candidate) && fs.statSync(candidate).isFile()) {
31
+ return candidate;
32
+ }
33
+ }
34
+ return null;
35
+ },
36
+ };
37
+ }
17
38
  const compileCommand = new Command()
18
39
  .name("compile-contract")
19
40
  .description("Creates a global contract")
@@ -58,33 +79,70 @@ const compileCommand = new Command()
58
79
  execSync(`rm -rf ${output}`);
59
80
  if (bundle) {
60
81
  log.info(`bundling contract from ${input}`);
61
- const bundle = await rollup({
62
- input: `${input}/index.ts`,
63
- plugins: [
64
- replace({
65
- preventAssignment: true,
66
- delimiters: ["", ""],
67
- values: { "##VERSION##": version, "##PACKAGE##": pkg.name },
68
- }),
69
- typescript({
70
- tsconfig: tsConfigFile,
71
- compilerOptions: {
72
- outDir: output,
73
- sourceMap: sourcemaps,
74
- inlineSources: sourcemaps,
75
- },
76
- module: "esnext",
77
- declaration: false,
78
- }),
79
- ],
80
- });
81
- log.info(`withing contract to ${output} with name ${toPascalCase(name)}.js`);
82
- await bundle.write({
83
- file: `${output}/${toPascalCase(name)}.js`,
84
- format: "umd",
85
- name: `${toPascalCase(name)}.js`,
86
- sourcemap: sourcemaps,
87
- });
82
+ const tempBundleDir = fs.mkdtempSync(path.join(process.cwd(), ".contract-bundle-"));
83
+ try {
84
+ const inputEntry = path.resolve(process.cwd(), input, "index.ts");
85
+ const configFile = ts.readConfigFile(tsConfigFile, ts.sys.readFile);
86
+ if (configFile.error) {
87
+ throw new InternalError(ts.flattenDiagnosticMessageText(configFile.error.messageText, "\n"));
88
+ }
89
+ const parsedConfig = ts.parseJsonConfigFileContent(configFile.config, ts.sys, path.dirname(tsConfigFile), undefined, tsConfigFile);
90
+ if (parsedConfig.errors.length) {
91
+ throw new InternalError(parsedConfig.errors
92
+ .map((error) => ts.flattenDiagnosticMessageText(error.messageText, "\n"))
93
+ .join("\n"));
94
+ }
95
+ const tempCompilerOptions = {
96
+ ...parsedConfig.options,
97
+ outDir: tempBundleDir,
98
+ module: ts.ModuleKind.ESNext,
99
+ declaration: false,
100
+ sourceMap: false,
101
+ inlineSources: false,
102
+ };
103
+ const bundledEntryPoint = ts
104
+ .getOutputFileNames({
105
+ ...parsedConfig,
106
+ options: tempCompilerOptions,
107
+ }, inputEntry, !ts.sys.useCaseSensitiveFileNames)
108
+ .find((fileName) => fileName.endsWith(".js"));
109
+ if (!bundledEntryPoint) {
110
+ throw new InternalError(`Failed to determine the emitted bundle entry for ${inputEntry}`);
111
+ }
112
+ compileWithTsconfigOverrides(tsConfigFile, tempCompilerOptions);
113
+ const bundledContract = await rollup({
114
+ input: bundledEntryPoint,
115
+ plugins: [
116
+ resolveBundledJsImports(),
117
+ replace({
118
+ preventAssignment: true,
119
+ delimiters: ["", ""],
120
+ values: { "##VERSION##": version, "##PACKAGE##": pkg.name },
121
+ }),
122
+ ],
123
+ });
124
+ log.info(`withing contract to ${output} with name ${toPascalCase(name)}.js`);
125
+ await bundledContract.write({
126
+ file: `${output}/${toPascalCase(name)}.js`,
127
+ format: "umd",
128
+ name: `${toPascalCase(name)}.js`,
129
+ sourcemap: sourcemaps ? "inline" : false,
130
+ sourcemapPathTransform: (relativeSourcePath, sourcemapPath) => {
131
+ const absoluteSourcePath = path.resolve(path.dirname(sourcemapPath), relativeSourcePath);
132
+ if (absoluteSourcePath.startsWith(tempBundleDir)) {
133
+ return path.posix.join(".bundle", path
134
+ .relative(tempBundleDir, absoluteSourcePath)
135
+ .split(path.sep)
136
+ .join("/"));
137
+ }
138
+ return relativeSourcePath;
139
+ },
140
+ });
141
+ await bundledContract.close();
142
+ }
143
+ finally {
144
+ fs.rmSync(tempBundleDir, { recursive: true, force: true });
145
+ }
88
146
  }
89
147
  else {
90
148
  compileWithTsconfigOverrides(tsConfigFile, {
@@ -412,4 +470,4 @@ fabricCmd.addCommand(extractCollections);
412
470
  export default function fabric() {
413
471
  return fabricCmd;
414
472
  }
415
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli-module.js","sourceRoot":"","sources":["../../src/cli-module.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from \"commander\";\nimport { Logging, toPascalCase } from \"@decaf-ts/logging\";\nimport { execSync } from \"child_process\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { rollup } from \"rollup\";\nimport replace from \"@rollup/plugin-replace\";\nimport typescript from \"@rollup/plugin-typescript\";\nimport { InternalError, SerializationError } from \"@decaf-ts/db-decorators\";\nimport {\n  generateModelDesignDocs,\n  generateModelIndexes,\n  readModelFile,\n  readModelFolders,\n  writeDesignDocs,\n  writeIndexes,\n} from \"./client/indexes\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport {\n  approveContract,\n  ensureInfrastructureBooted,\n  installContract,\n  packageContract,\n  commitChaincode,\n  getContractStartCommand,\n  compileWithTsconfigOverrides,\n} from \"./cli-utils\";\nimport \"./shared/overrides\";\nimport ts from \"typescript\";\nimport {\n  extractCollections as exCollections,\n  PrivateCollection,\n  writeCollections,\n  writeCollectionDesignDocs,\n} from \"./client/collections/index\";\nimport { CouchDBDesignDoc, CreateIndexRequest } from \"@decaf-ts/for-couchdb\";\n\nconst logger = Logging.for(\"fabric\");\n\nconst compileCommand = new Command()\n  .name(\"compile-contract\")\n  .description(\"Creates a global contract\")\n  .option(\"--dev\", \"compiles contracts without minification\", false)\n  .option(\"--debug\", \"makes attaching debugger possible\", false)\n  .option(\n    \"--ccaas\",\n    \"Ajusts the package commands to be deployed as ccaas\",\n    false\n  )\n  .option(\"--name <String>\", \"contract name\", \"global-contract\")\n  .option(\"--bundle\", \"Bundles with rollup instead of using tsc\", false)\n  .option(\n    \"--ts-config-file <string>\",\n    \"relative path to the ts config file based on cwd or absolute path\",\n    \"./tsconfig.json\"\n  )\n  .option(\n    \"--description <String>\",\n    \"contract description\",\n    \"Global contract implementation\"\n  )\n  .option(\"--strip-contract-name\", \"strip contract name from output\", false)\n  .option(\"--input <String>\", \"input folder for contracts\", \"lib/contracts\")\n  .option(\"--output <String>\", \"output folder for contracts\", \"./contracts\")\n  .option(\"--sourcemaps\", \"includes sourcemaps in the compiled output\", false)\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    let {\n      // eslint-disable-next-line prefer-const\n      dev,\n      // eslint-disable-next-line prefer-const\n      debug,\n      // eslint-disable-next-line prefer-const\n      name,\n      // eslint-disable-next-line prefer-const\n      description,\n      output,\n      // eslint-disable-next-line prefer-const\n      input,\n      // eslint-disable-next-line prefer-const\n      stripContractName,\n      // eslint-disable-next-line prefer-const\n      ccaas,\n      // eslint-disable-next-line prefer-const\n      bundle,\n\n      tsConfigFile,\n      sourcemaps,\n    } = options;\n    const log = logger.for(\"compile-contract\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    tsConfigFile = path.isAbsolute(tsConfigFile)\n      ? tsConfigFile\n      : path.join(process.cwd(), tsConfigFile);\n\n    output = stripContractName ? output : path.join(output, name);\n    log.info(`Deleting existing output folder (if exists) under ${output}`);\n    execSync(`rm -rf ${output}`);\n    if (bundle) {\n      log.info(`bundling contract from ${input}`);\n      const bundle = await rollup({\n        input: `${input}/index.ts`,\n        plugins: [\n          replace({\n            preventAssignment: true,\n            delimiters: [\"\", \"\"],\n            values: { \"##VERSION##\": version, \"##PACKAGE##\": pkg.name },\n          }),\n          typescript({\n            tsconfig: tsConfigFile,\n            compilerOptions: {\n              outDir: output,\n              sourceMap: sourcemaps,\n              inlineSources: sourcemaps,\n            },\n            module: \"esnext\",\n            declaration: false,\n          }),\n        ],\n      });\n      log.info(\n        `withing contract to ${output} with name ${toPascalCase(name)}.js`\n      );\n      await bundle.write({\n        file: `${output}/${toPascalCase(name)}.js`,\n        format: \"umd\",\n        name: `${toPascalCase(name)}.js`,\n        sourcemap: sourcemaps,\n      });\n    } else {\n      compileWithTsconfigOverrides(tsConfigFile, {\n        outDir: output,\n        module: ts.ModuleKind.ESNext,\n        declaration: false,\n        sourceMap: sourcemaps,\n        inlineSources: sourcemaps,\n      });\n    }\n\n    const scripts = {\n      start: getContractStartCommand(debug, ccaas),\n      \"start:dev\": \"fabric-chaincode-node start --tls.enabled false\",\n      \"start:watch\": 'nodemon --exec \"npm run start:dev\"',\n      build: 'echo \"No need to build the chaincode\"',\n      lint: \"eslint . --fix --ext .js\",\n    };\n\n    const contractPackage = pkg;\n\n    contractPackage.name = name;\n    contractPackage.description = description;\n    contractPackage.scripts = scripts;\n\n    delete contractPackage.type;\n    delete contractPackage.types;\n    delete contractPackage.exports;\n    contractPackage.main = bundle\n      ? `${toPascalCase(name)}.js`\n      : `${input}/index.js`;\n\n    fs.writeFileSync(\n      path.join(output, \"package.json\"),\n      JSON.stringify(contractPackage)\n    );\n\n    log.info(`Installing and shrinkwrapping dependencies`);\n    execSync(`npm install`, { cwd: output });\n    execSync(`npm shrinkwrap`, { cwd: output });\n    execSync(\"rm -rf node_modules\", { cwd: output });\n    log.info(`deleting temp folders`);\n    execSync(`rm -rf ./lib && rm -rf ./dist`, { cwd: output });\n    log.info(\n      `Contract ${name} compiled successfully! in ${path.resolve(output)}`\n    );\n    if (dev) {\n      log.info(`dev mode enabled. installing dependencies for debugging`);\n      execSync(`npm install`, {\n        cwd: output,\n        env: { ...process.env, NODE_ENV: \"production\" },\n      });\n    }\n  });\n\nconst extractIndexes = new Command()\n  .command(\"extract-indexes\")\n  .option(\"--file [String]\", \"the model file\")\n  .option(\"--folder [String]\", \"the model folder\")\n  .option(\"--outDir <String>\", \"the outdir. should match your contract folder\")\n  .description(\n    \"Creates a the JSON index files to be submitted to along with the contract\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"extract-indexes\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    // eslint-disable-next-line prefer-const\n    let { file, folder, outDir } = options;\n\n    const models: any[] = [];\n    if (file) {\n      models.push(...readModelFile(file));\n    }\n\n    if (folder) {\n      log.info(`Loading models from ${folder}...`);\n      models.push(...(await readModelFolders(folder)));\n    }\n    const result: Record<string, any> = {};\n    const designDocs: Record<string, any> = {};\n\n    if (!file && !folder)\n      throw new InternalError(`Must pass a file or a folder`);\n\n    for (const m of models) {\n      log.verbose(`Extracting indexes for table ${Model.tableName(m)}`);\n      const indexes = generateModelIndexes(m);\n      indexes.forEach((index) => {\n        if (index.name) {\n          result[index.name] = index;\n        }\n      });\n      generateModelDesignDocs(m, designDocs);\n    }\n    const indexesToWrite = Object.values(result);\n    const docsToWrite = Object.values(designDocs);\n    log.verbose(`Found ${indexesToWrite.length} indexes to create`);\n    log.verbose(`Found ${docsToWrite.length} design docs to create`);\n    log.debug(`Indexes: ${JSON.stringify(result)}`);\n    log.debug(`DesignDocs: ${JSON.stringify(designDocs)}`);\n    writeIndexes(indexesToWrite, outDir);\n    writeDesignDocs(docsToWrite, outDir);\n  });\n\nconst extractCollections = new Command()\n  .command(\"extract-collections\")\n  .option(\"--file [String]\", \"the model file\")\n  .option(\"--folder [String]\", \"the model folder\")\n  .option(\"--outDir <String>\", \"the outdir. should match your contract folder\")\n  .option(\"--mspIds <String>\", \"single mspId or stringified array\")\n  .option(\"--mainMspId <String>\", \"single mspId\")\n  .option(\n    \"--overrides [String]\",\n    \"stringified override object {requiredPeerCount: number, maxPeerCount: number, blockToLive: number, memberOnlyRead: number, memberOnlyWrite: number, endorsementPolicy:  {}}\"\n  )\n  .description(\n    \"Creates a the JSON index files to be submitted to along with the contract\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"extract-collections\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    // eslint-disable-next-line prefer-const\n    let { file, folder, outDir, mspIds, mainMspId } = options;\n\n    try {\n      try {\n        mspIds = mspIds ? JSON.parse(mspIds) : undefined;\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: unknown) {\n        //  do nothing\n      }\n    } catch (e: unknown) {\n      throw new SerializationError(`Unable to extract mspids:  ${e}`);\n    }\n\n    const models: any[] = [];\n    if (file) {\n      models.push(...readModelFile(file));\n    }\n\n    if (folder) {\n      log.info(`Loading models from ${folder}...`);\n      models.push(...(await readModelFolders(folder)));\n    }\n\n    if (!file && !folder)\n      throw new InternalError(`Must pass a file or a folder`);\n\n    const injectableModels = models.filter(\n      (model) =>\n        Model.isShared(model) ||\n        Model.isPrivate(model) ||\n        !!Model.mirroredAt(model)\n    );\n    if (!injectableModels.length) {\n      log.info(\n        `No shared, private, or mirrored models found to extract collections`\n      );\n      return;\n    }\n\n    async function getCols(mspIdsList?: string[]) {\n      const cols: {\n        indexes: CreateIndexRequest[];\n        designDocs: CouchDBDesignDoc[];\n        mirror?: PrivateCollection;\n        collections: PrivateCollection[];\n      }[] = await Promise.all(\n        injectableModels.map(async (clazz) => {\n          const tableName = Model.tableName(clazz);\n          const mirrorMeta = Model.mirroredAt(clazz);\n\n          console.log(tableName);\n          const collections: Record<string, any> = {};\n          for (const msp of mspIdsList || mspIds || []) {\n            collections[msp] = await exCollections(\n              clazz,\n              [msp, mainMspId],\n              {},\n              // {\n              //   sharedCols: Object.assign({}, overrides.sharedCols),\n              //   privateCols: Object.assign({}, overrides.privateCols),\n              // },\n              !!mirrorMeta\n            );\n          }\n\n          let mirrorCollection: PrivateCollection | undefined = undefined;\n\n          if (mirrorMeta) {\n            collections[mainMspId] = collections[mainMspId] || {};\n            Object.keys(collections).forEach((msp: string) => {\n              collections[mainMspId].privates = collections[\n                msp\n              ].privates?.filter((p: any) => {\n                if (p.name !== (mirrorMeta.resolver as string)) return true;\n                mirrorCollection = p as any;\n                return false;\n              });\n            });\n          }\n\n          const privatesCount = Object.values(collections)\n            .map((c) => c.privates)\n            .flat().length;\n          if (privatesCount)\n            log\n              .for(Model.tableName(clazz))\n              .info(`Found ${privatesCount} private collections to create`);\n          const sharedCount = Object.values(collections)\n            .map((c) => c.shared)\n            .flat().length;\n\n          log\n            .for(Model.tableName(clazz))\n            .info(`Found ${sharedCount} shared collections to create`);\n          if (mirrorCollection)\n            log\n              .for(Model.tableName(clazz))\n              .info(\n                `Found one mirror collection ${mirrorMeta?.resolver as string}`\n              );\n\n          const colList = Object.values(collections)\n            .map((c) => [...(c.privates || []), ...(c.shared || [])])\n            .flat();\n          let indexes: CreateIndexRequest[] = [];\n          let designDocs: CouchDBDesignDoc[] = [];\n          if (colList.length) {\n            log\n              .for(Model.tableName(clazz))\n              .verbose(`generating indexes for collections`);\n            indexes = generateModelIndexes(clazz);\n            log\n              .for(Model.tableName(clazz))\n              .info(`found ${indexes.length} indexes`);\n            designDocs = generateModelDesignDocs(clazz);\n            log\n              .for(Model.tableName(clazz))\n              .info(`found ${designDocs.length} design docs`);\n          }\n          return {\n            indexes,\n            designDocs,\n            collections: colList,\n            mirror: mirrorCollection,\n          };\n        })\n      );\n      return cols;\n    }\n\n    const cols = await getCols();\n    const onlyMirror = await getCols([mainMspId]);\n\n    const collectionsTo = [\n      ...onlyMirror.filter((c) => c.mirror).map((c) => c.mirror),\n      ...cols.map((c) => c.collections).flat(),\n      ...cols.filter((c) => c.mirror).map((c) => c.mirror),\n    ] as PrivateCollection[];\n\n    const uniqueByCollection = [\n      ...new Map(\n        collectionsTo.map((item: PrivateCollection) => [item.name, item])\n      ).values(),\n    ];\n\n    if (uniqueByCollection.length) {\n      writeCollections(uniqueByCollection, outDir);\n      const metaCollectionsConfig = path.join(\n        outDir,\n        \"META-INF\",\n        \"collections_config.json\"\n      );\n      const contractCollectionsConfig = path.join(\n        outDir,\n        \"collections_config.json\"\n      );\n      fs.copyFileSync(metaCollectionsConfig, contractCollectionsConfig);\n      log.info(\n        `Stored ${collectionsTo.length} collections to ${metaCollectionsConfig}`\n      );\n      log.info(\n        `Copied collections_config to ${contractCollectionsConfig} alongside the package.json`\n      );\n\n      cols.forEach((c) => {\n        const { indexes, designDocs, collections, mirror } = c;\n        const toIndex: PrivateCollection[] = [...collections, mirror].filter(\n          Boolean\n        ) as PrivateCollection[];\n        toIndex.forEach((i) => {\n          writeIndexes(indexes, outDir, i.name);\n          writeCollectionDesignDocs(designDocs || [], outDir, i.name);\n          log.info(\n            `Stored ${indexes?.length || 0} indexes and ${designDocs?.length || 0} design docs to collection ${i.name}`\n          );\n        });\n      });\n    }\n  });\n\nconst ensureInfra = new Command()\n  .name(\"await-infra\")\n  .description(\"waits for the infrastructure to be up and running\")\n  .option(\n    \"--container <String>\",\n    \"docker container name to test (usually last peer)\",\n    \"boot-org-c-peer-0\"\n  )\n  .option(\"--timeout <String>\", \"timeout between tests in milliseconds\", \"5000\")\n  .option(\"--attempts <String>\", \"number of attempts before giving up\", \"10\")\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"await-infra\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n    // eslint-disable-next-line prefer-const\n    let { container, timeout, attempts } = options;\n    timeout = parseInt(timeout) || 5000;\n    attempts = parseInt(attempts) || 10;\n\n    await ensureInfrastructureBooted(\"boot-org-c-peer-0\", timeout, attempts);\n\n    log.info(\n      `Infrastructure booted successfully (according to container ${container})!`\n    );\n  });\n\nconst deployContract = new Command()\n  .name(\"deploy-contract\")\n  .description(\"deploys the selected contract\")\n  .option(\"--name <String>\", \"Contract Name (and folder)\")\n  .option(\"--input <String>\", \"input folder\")\n  .option(\n    \"--collections-config <String>\",\n    \"path to collections_config.json to configure private collections\"\n  )\n  .option(\n    \"--incrementVersion <String>\",\n    \"(true | false) if should use version or sequence to update contracts\",\n    false\n  )\n  .option(\n    \"--trackerFolder <String>\",\n    \"contract version tracker folder (should be deleted on infrastructure:down)\",\n    path.join(process.cwd(), \"tests\", \"integration\", \"chaincodeTrackers\")\n  )\n  .option(\n    \"--peers <String>\",\n    \"comma separated peer ids\",\n    \"org-a-peer-0,org-b-peer-0,org-c-peer-0\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"deploy-contract\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    const {\n      name,\n      input,\n      peers,\n      trackerFolder,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      incrementVersion,\n      collectionsConfig,\n    } = options;\n    const peerIds = peers.split(\",\");\n\n    const countPath = path.resolve(path.join(trackerFolder, `${name}.count`));\n\n    let sequence: number;\n\n    try {\n      sequence = parseInt(fs.readFileSync(countPath).toString(\"utf-8\"));\n      if (isNaN(sequence)) sequence = 1;\n      else sequence += 1;\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      sequence = 1;\n    }\n    //\n    // if (incrementVersion) {\n    //   version = version + `-${sequence}`;\n    //   // sequence = 1;\n    // }\n\n    try {\n      for (const peer of peerIds) {\n        packageContract(peer, input, name, version);\n        installContract(peer, name);\n        approveContract(\n          peer,\n          name,\n          peer === \"org-a-peer-0\"\n            ? \"tls-ca-cert.pem\"\n            : \"orderer-tls-ca-cert.pem\",\n          sequence,\n          version,\n          collectionsConfig\n        );\n      }\n      fs.writeFileSync(countPath, sequence.toString());\n    } catch (err: any) {\n      log.error(\"Error deploying contract:\", err);\n    }\n    commitChaincode(name, sequence, version, collectionsConfig);\n  });\n\nconst getCryptoMaterial = new Command()\n  .name(\"get-crypto-material\")\n  .description(\"copies the crypto material to the selected folder\")\n  .option(\"--folder <String>\", \"output folder\", \"docker/docker-data\")\n  .option(\"--org [String]\", \"the org/peer to extract from\", \"org-a\")\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"get-crypto-material\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n    const { folder, org } = options;\n    execSync(`docker cp ${org}:/weaver/client/. ${folder}`, {\n      cwd: process.cwd(),\n    });\n  });\n\nconst fabricCmd = new Command()\n  .name(\"for-fabric\")\n  .command(\"fabric\")\n  .description(\n    \"exposes several commands to help manage the fabric infrastructure\"\n  );\n\nfabricCmd.addCommand(compileCommand);\nfabricCmd.addCommand(extractIndexes);\nfabricCmd.addCommand(ensureInfra);\nfabricCmd.addCommand(deployContract);\nfabricCmd.addCommand(getCryptoMaterial);\nfabricCmd.addCommand(extractCollections);\n\nexport default function fabric() {\n  return fabricCmd;\n}\n"]}
473
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli-module.js","sourceRoot":"","sources":["../../src/cli-module.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from \"commander\";\nimport { Logging, toPascalCase } from \"@decaf-ts/logging\";\nimport { execSync } from \"child_process\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { Plugin, rollup } from \"rollup\";\nimport replace from \"@rollup/plugin-replace\";\nimport { InternalError, SerializationError } from \"@decaf-ts/db-decorators\";\nimport {\n  generateModelDesignDocs,\n  generateModelIndexes,\n  readModelFile,\n  readModelFolders,\n  writeDesignDocs,\n  writeIndexes,\n} from \"./client/indexes\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport {\n  approveContract,\n  ensureInfrastructureBooted,\n  installContract,\n  packageContract,\n  commitChaincode,\n  getContractStartCommand,\n  compileWithTsconfigOverrides,\n} from \"./cli-utils\";\nimport \"./shared/overrides\";\nimport ts from \"typescript\";\nimport {\n  extractCollections as exCollections,\n  PrivateCollection,\n  writeCollections,\n  writeCollectionDesignDocs,\n} from \"./client/collections/index\";\nimport { CouchDBDesignDoc, CreateIndexRequest } from \"@decaf-ts/for-couchdb\";\n\nconst logger = Logging.for(\"fabric\");\n\nfunction resolveBundledJsImports(): Plugin {\n  return {\n    name: \"resolve-bundled-js-imports\",\n    resolveId(source, importer) {\n      if (!importer || !source.startsWith(\".\")) {\n        return null;\n      }\n\n      const resolvedPath = path.resolve(path.dirname(importer), source);\n      const candidates = [\n        resolvedPath,\n        `${resolvedPath}.js`,\n        path.join(resolvedPath, \"index.js\"),\n      ];\n\n      for (const candidate of candidates) {\n        if (fs.existsSync(candidate) && fs.statSync(candidate).isFile()) {\n          return candidate;\n        }\n      }\n\n      return null;\n    },\n  };\n}\n\nconst compileCommand = new Command()\n  .name(\"compile-contract\")\n  .description(\"Creates a global contract\")\n  .option(\"--dev\", \"compiles contracts without minification\", false)\n  .option(\"--debug\", \"makes attaching debugger possible\", false)\n  .option(\n    \"--ccaas\",\n    \"Ajusts the package commands to be deployed as ccaas\",\n    false\n  )\n  .option(\"--name <String>\", \"contract name\", \"global-contract\")\n  .option(\"--bundle\", \"Bundles with rollup instead of using tsc\", false)\n  .option(\n    \"--ts-config-file <string>\",\n    \"relative path to the ts config file based on cwd or absolute path\",\n    \"./tsconfig.json\"\n  )\n  .option(\n    \"--description <String>\",\n    \"contract description\",\n    \"Global contract implementation\"\n  )\n  .option(\"--strip-contract-name\", \"strip contract name from output\", false)\n  .option(\"--input <String>\", \"input folder for contracts\", \"lib/contracts\")\n  .option(\"--output <String>\", \"output folder for contracts\", \"./contracts\")\n  .option(\"--sourcemaps\", \"includes sourcemaps in the compiled output\", false)\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    let {\n      // eslint-disable-next-line prefer-const\n      dev,\n      // eslint-disable-next-line prefer-const\n      debug,\n      // eslint-disable-next-line prefer-const\n      name,\n      // eslint-disable-next-line prefer-const\n      description,\n      output,\n      // eslint-disable-next-line prefer-const\n      input,\n      // eslint-disable-next-line prefer-const\n      stripContractName,\n      // eslint-disable-next-line prefer-const\n      ccaas,\n      // eslint-disable-next-line prefer-const\n      bundle,\n\n      tsConfigFile,\n      sourcemaps,\n    } = options;\n    const log = logger.for(\"compile-contract\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    tsConfigFile = path.isAbsolute(tsConfigFile)\n      ? tsConfigFile\n      : path.join(process.cwd(), tsConfigFile);\n\n    output = stripContractName ? output : path.join(output, name);\n    log.info(`Deleting existing output folder (if exists) under ${output}`);\n    execSync(`rm -rf ${output}`);\n    if (bundle) {\n      log.info(`bundling contract from ${input}`);\n      const tempBundleDir = fs.mkdtempSync(\n        path.join(process.cwd(), \".contract-bundle-\")\n      );\n      try {\n        const inputEntry = path.resolve(process.cwd(), input, \"index.ts\");\n        const configFile = ts.readConfigFile(tsConfigFile, ts.sys.readFile);\n        if (configFile.error) {\n          throw new InternalError(\n            ts.flattenDiagnosticMessageText(configFile.error.messageText, \"\\n\")\n          );\n        }\n\n        const parsedConfig = ts.parseJsonConfigFileContent(\n          configFile.config,\n          ts.sys,\n          path.dirname(tsConfigFile),\n          undefined,\n          tsConfigFile\n        );\n        if (parsedConfig.errors.length) {\n          throw new InternalError(\n            parsedConfig.errors\n              .map((error) =>\n                ts.flattenDiagnosticMessageText(error.messageText, \"\\n\")\n              )\n              .join(\"\\n\")\n          );\n        }\n\n        const tempCompilerOptions: ts.CompilerOptions = {\n          ...parsedConfig.options,\n          outDir: tempBundleDir,\n          module: ts.ModuleKind.ESNext,\n          declaration: false,\n          sourceMap: false,\n          inlineSources: false,\n        };\n        const bundledEntryPoint = ts\n          .getOutputFileNames(\n            {\n              ...parsedConfig,\n              options: tempCompilerOptions,\n            },\n            inputEntry,\n            !ts.sys.useCaseSensitiveFileNames\n          )\n          .find((fileName) => fileName.endsWith(\".js\"));\n\n        if (!bundledEntryPoint) {\n          throw new InternalError(\n            `Failed to determine the emitted bundle entry for ${inputEntry}`\n          );\n        }\n\n        compileWithTsconfigOverrides(tsConfigFile, tempCompilerOptions);\n        const bundledContract = await rollup({\n          input: bundledEntryPoint,\n          plugins: [\n            resolveBundledJsImports(),\n            replace({\n              preventAssignment: true,\n              delimiters: [\"\", \"\"],\n              values: { \"##VERSION##\": version, \"##PACKAGE##\": pkg.name },\n            }),\n          ],\n        });\n        log.info(\n          `withing contract to ${output} with name ${toPascalCase(name)}.js`\n        );\n        await bundledContract.write({\n          file: `${output}/${toPascalCase(name)}.js`,\n          format: \"umd\",\n          name: `${toPascalCase(name)}.js`,\n          sourcemap: sourcemaps ? \"inline\" : false,\n          sourcemapPathTransform: (relativeSourcePath, sourcemapPath) => {\n            const absoluteSourcePath = path.resolve(\n              path.dirname(sourcemapPath),\n              relativeSourcePath\n            );\n\n            if (absoluteSourcePath.startsWith(tempBundleDir)) {\n              return path.posix.join(\n                \".bundle\",\n                path\n                  .relative(tempBundleDir, absoluteSourcePath)\n                  .split(path.sep)\n                  .join(\"/\")\n              );\n            }\n\n            return relativeSourcePath;\n          },\n        });\n        await bundledContract.close();\n      } finally {\n        fs.rmSync(tempBundleDir, { recursive: true, force: true });\n      }\n    } else {\n      compileWithTsconfigOverrides(tsConfigFile, {\n        outDir: output,\n        module: ts.ModuleKind.ESNext,\n        declaration: false,\n        sourceMap: sourcemaps,\n        inlineSources: sourcemaps,\n      });\n    }\n\n    const scripts = {\n      start: getContractStartCommand(debug, ccaas),\n      \"start:dev\": \"fabric-chaincode-node start --tls.enabled false\",\n      \"start:watch\": 'nodemon --exec \"npm run start:dev\"',\n      build: 'echo \"No need to build the chaincode\"',\n      lint: \"eslint . --fix --ext .js\",\n    };\n\n    const contractPackage = pkg;\n\n    contractPackage.name = name;\n    contractPackage.description = description;\n    contractPackage.scripts = scripts;\n\n    delete contractPackage.type;\n    delete contractPackage.types;\n    delete contractPackage.exports;\n    contractPackage.main = bundle\n      ? `${toPascalCase(name)}.js`\n      : `${input}/index.js`;\n\n    fs.writeFileSync(\n      path.join(output, \"package.json\"),\n      JSON.stringify(contractPackage)\n    );\n\n    log.info(`Installing and shrinkwrapping dependencies`);\n    execSync(`npm install`, { cwd: output });\n    execSync(`npm shrinkwrap`, { cwd: output });\n    execSync(\"rm -rf node_modules\", { cwd: output });\n    log.info(`deleting temp folders`);\n    execSync(`rm -rf ./lib && rm -rf ./dist`, { cwd: output });\n    log.info(\n      `Contract ${name} compiled successfully! in ${path.resolve(output)}`\n    );\n    if (dev) {\n      log.info(`dev mode enabled. installing dependencies for debugging`);\n      execSync(`npm install`, {\n        cwd: output,\n        env: { ...process.env, NODE_ENV: \"production\" },\n      });\n    }\n  });\n\nconst extractIndexes = new Command()\n  .command(\"extract-indexes\")\n  .option(\"--file [String]\", \"the model file\")\n  .option(\"--folder [String]\", \"the model folder\")\n  .option(\"--outDir <String>\", \"the outdir. should match your contract folder\")\n  .description(\n    \"Creates a the JSON index files to be submitted to along with the contract\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"extract-indexes\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    // eslint-disable-next-line prefer-const\n    let { file, folder, outDir } = options;\n\n    const models: any[] = [];\n    if (file) {\n      models.push(...readModelFile(file));\n    }\n\n    if (folder) {\n      log.info(`Loading models from ${folder}...`);\n      models.push(...(await readModelFolders(folder)));\n    }\n    const result: Record<string, any> = {};\n    const designDocs: Record<string, any> = {};\n\n    if (!file && !folder)\n      throw new InternalError(`Must pass a file or a folder`);\n\n    for (const m of models) {\n      log.verbose(`Extracting indexes for table ${Model.tableName(m)}`);\n      const indexes = generateModelIndexes(m);\n      indexes.forEach((index) => {\n        if (index.name) {\n          result[index.name] = index;\n        }\n      });\n      generateModelDesignDocs(m, designDocs);\n    }\n    const indexesToWrite = Object.values(result);\n    const docsToWrite = Object.values(designDocs);\n    log.verbose(`Found ${indexesToWrite.length} indexes to create`);\n    log.verbose(`Found ${docsToWrite.length} design docs to create`);\n    log.debug(`Indexes: ${JSON.stringify(result)}`);\n    log.debug(`DesignDocs: ${JSON.stringify(designDocs)}`);\n    writeIndexes(indexesToWrite, outDir);\n    writeDesignDocs(docsToWrite, outDir);\n  });\n\nconst extractCollections = new Command()\n  .command(\"extract-collections\")\n  .option(\"--file [String]\", \"the model file\")\n  .option(\"--folder [String]\", \"the model folder\")\n  .option(\"--outDir <String>\", \"the outdir. should match your contract folder\")\n  .option(\"--mspIds <String>\", \"single mspId or stringified array\")\n  .option(\"--mainMspId <String>\", \"single mspId\")\n  .option(\n    \"--overrides [String]\",\n    \"stringified override object {requiredPeerCount: number, maxPeerCount: number, blockToLive: number, memberOnlyRead: number, memberOnlyWrite: number, endorsementPolicy:  {}}\"\n  )\n  .description(\n    \"Creates a the JSON index files to be submitted to along with the contract\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"extract-collections\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    // eslint-disable-next-line prefer-const\n    let { file, folder, outDir, mspIds, mainMspId } = options;\n\n    try {\n      try {\n        mspIds = mspIds ? JSON.parse(mspIds) : undefined;\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: unknown) {\n        //  do nothing\n      }\n    } catch (e: unknown) {\n      throw new SerializationError(`Unable to extract mspids:  ${e}`);\n    }\n\n    const models: any[] = [];\n    if (file) {\n      models.push(...readModelFile(file));\n    }\n\n    if (folder) {\n      log.info(`Loading models from ${folder}...`);\n      models.push(...(await readModelFolders(folder)));\n    }\n\n    if (!file && !folder)\n      throw new InternalError(`Must pass a file or a folder`);\n\n    const injectableModels = models.filter(\n      (model) =>\n        Model.isShared(model) ||\n        Model.isPrivate(model) ||\n        !!Model.mirroredAt(model)\n    );\n    if (!injectableModels.length) {\n      log.info(\n        `No shared, private, or mirrored models found to extract collections`\n      );\n      return;\n    }\n\n    async function getCols(mspIdsList?: string[]) {\n      const cols: {\n        indexes: CreateIndexRequest[];\n        designDocs: CouchDBDesignDoc[];\n        mirror?: PrivateCollection;\n        collections: PrivateCollection[];\n      }[] = await Promise.all(\n        injectableModels.map(async (clazz) => {\n          const tableName = Model.tableName(clazz);\n          const mirrorMeta = Model.mirroredAt(clazz);\n\n          console.log(tableName);\n          const collections: Record<string, any> = {};\n          for (const msp of mspIdsList || mspIds || []) {\n            collections[msp] = await exCollections(\n              clazz,\n              [msp, mainMspId],\n              {},\n              // {\n              //   sharedCols: Object.assign({}, overrides.sharedCols),\n              //   privateCols: Object.assign({}, overrides.privateCols),\n              // },\n              !!mirrorMeta\n            );\n          }\n\n          let mirrorCollection: PrivateCollection | undefined = undefined;\n\n          if (mirrorMeta) {\n            collections[mainMspId] = collections[mainMspId] || {};\n            Object.keys(collections).forEach((msp: string) => {\n              collections[mainMspId].privates = collections[\n                msp\n              ].privates?.filter((p: any) => {\n                if (p.name !== (mirrorMeta.resolver as string)) return true;\n                mirrorCollection = p as any;\n                return false;\n              });\n            });\n          }\n\n          const privatesCount = Object.values(collections)\n            .map((c) => c.privates)\n            .flat().length;\n          if (privatesCount)\n            log\n              .for(Model.tableName(clazz))\n              .info(`Found ${privatesCount} private collections to create`);\n          const sharedCount = Object.values(collections)\n            .map((c) => c.shared)\n            .flat().length;\n\n          log\n            .for(Model.tableName(clazz))\n            .info(`Found ${sharedCount} shared collections to create`);\n          if (mirrorCollection)\n            log\n              .for(Model.tableName(clazz))\n              .info(\n                `Found one mirror collection ${mirrorMeta?.resolver as string}`\n              );\n\n          const colList = Object.values(collections)\n            .map((c) => [...(c.privates || []), ...(c.shared || [])])\n            .flat();\n          let indexes: CreateIndexRequest[] = [];\n          let designDocs: CouchDBDesignDoc[] = [];\n          if (colList.length) {\n            log\n              .for(Model.tableName(clazz))\n              .verbose(`generating indexes for collections`);\n            indexes = generateModelIndexes(clazz);\n            log\n              .for(Model.tableName(clazz))\n              .info(`found ${indexes.length} indexes`);\n            designDocs = generateModelDesignDocs(clazz);\n            log\n              .for(Model.tableName(clazz))\n              .info(`found ${designDocs.length} design docs`);\n          }\n          return {\n            indexes,\n            designDocs,\n            collections: colList,\n            mirror: mirrorCollection,\n          };\n        })\n      );\n      return cols;\n    }\n\n    const cols = await getCols();\n    const onlyMirror = await getCols([mainMspId]);\n\n    const collectionsTo = [\n      ...onlyMirror.filter((c) => c.mirror).map((c) => c.mirror),\n      ...cols.map((c) => c.collections).flat(),\n      ...cols.filter((c) => c.mirror).map((c) => c.mirror),\n    ] as PrivateCollection[];\n\n    const uniqueByCollection = [\n      ...new Map(\n        collectionsTo.map((item: PrivateCollection) => [item.name, item])\n      ).values(),\n    ];\n\n    if (uniqueByCollection.length) {\n      writeCollections(uniqueByCollection, outDir);\n      const metaCollectionsConfig = path.join(\n        outDir,\n        \"META-INF\",\n        \"collections_config.json\"\n      );\n      const contractCollectionsConfig = path.join(\n        outDir,\n        \"collections_config.json\"\n      );\n      fs.copyFileSync(metaCollectionsConfig, contractCollectionsConfig);\n      log.info(\n        `Stored ${collectionsTo.length} collections to ${metaCollectionsConfig}`\n      );\n      log.info(\n        `Copied collections_config to ${contractCollectionsConfig} alongside the package.json`\n      );\n\n      cols.forEach((c) => {\n        const { indexes, designDocs, collections, mirror } = c;\n        const toIndex: PrivateCollection[] = [...collections, mirror].filter(\n          Boolean\n        ) as PrivateCollection[];\n        toIndex.forEach((i) => {\n          writeIndexes(indexes, outDir, i.name);\n          writeCollectionDesignDocs(designDocs || [], outDir, i.name);\n          log.info(\n            `Stored ${indexes?.length || 0} indexes and ${designDocs?.length || 0} design docs to collection ${i.name}`\n          );\n        });\n      });\n    }\n  });\n\nconst ensureInfra = new Command()\n  .name(\"await-infra\")\n  .description(\"waits for the infrastructure to be up and running\")\n  .option(\n    \"--container <String>\",\n    \"docker container name to test (usually last peer)\",\n    \"boot-org-c-peer-0\"\n  )\n  .option(\"--timeout <String>\", \"timeout between tests in milliseconds\", \"5000\")\n  .option(\"--attempts <String>\", \"number of attempts before giving up\", \"10\")\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"await-infra\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n    // eslint-disable-next-line prefer-const\n    let { container, timeout, attempts } = options;\n    timeout = parseInt(timeout) || 5000;\n    attempts = parseInt(attempts) || 10;\n\n    await ensureInfrastructureBooted(\"boot-org-c-peer-0\", timeout, attempts);\n\n    log.info(\n      `Infrastructure booted successfully (according to container ${container})!`\n    );\n  });\n\nconst deployContract = new Command()\n  .name(\"deploy-contract\")\n  .description(\"deploys the selected contract\")\n  .option(\"--name <String>\", \"Contract Name (and folder)\")\n  .option(\"--input <String>\", \"input folder\")\n  .option(\n    \"--collections-config <String>\",\n    \"path to collections_config.json to configure private collections\"\n  )\n  .option(\n    \"--incrementVersion <String>\",\n    \"(true | false) if should use version or sequence to update contracts\",\n    false\n  )\n  .option(\n    \"--trackerFolder <String>\",\n    \"contract version tracker folder (should be deleted on infrastructure:down)\",\n    path.join(process.cwd(), \"tests\", \"integration\", \"chaincodeTrackers\")\n  )\n  .option(\n    \"--peers <String>\",\n    \"comma separated peer ids\",\n    \"org-a-peer-0,org-b-peer-0,org-c-peer-0\"\n  )\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"deploy-contract\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n\n    const {\n      name,\n      input,\n      peers,\n      trackerFolder,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      incrementVersion,\n      collectionsConfig,\n    } = options;\n    const peerIds = peers.split(\",\");\n\n    const countPath = path.resolve(path.join(trackerFolder, `${name}.count`));\n\n    let sequence: number;\n\n    try {\n      sequence = parseInt(fs.readFileSync(countPath).toString(\"utf-8\"));\n      if (isNaN(sequence)) sequence = 1;\n      else sequence += 1;\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      sequence = 1;\n    }\n    //\n    // if (incrementVersion) {\n    //   version = version + `-${sequence}`;\n    //   // sequence = 1;\n    // }\n\n    try {\n      for (const peer of peerIds) {\n        packageContract(peer, input, name, version);\n        installContract(peer, name);\n        approveContract(\n          peer,\n          name,\n          peer === \"org-a-peer-0\"\n            ? \"tls-ca-cert.pem\"\n            : \"orderer-tls-ca-cert.pem\",\n          sequence,\n          version,\n          collectionsConfig\n        );\n      }\n      fs.writeFileSync(countPath, sequence.toString());\n    } catch (err: any) {\n      log.error(\"Error deploying contract:\", err);\n    }\n    commitChaincode(name, sequence, version, collectionsConfig);\n  });\n\nconst getCryptoMaterial = new Command()\n  .name(\"get-crypto-material\")\n  .description(\"copies the crypto material to the selected folder\")\n  .option(\"--folder <String>\", \"output folder\", \"docker/docker-data\")\n  .option(\"--org [String]\", \"the org/peer to extract from\", \"org-a\")\n  .action(async (options: any) => {\n    const pkg = JSON.parse(\n      fs.readFileSync(path.join(process.cwd(), \"package.json\"), \"utf-8\")\n    );\n\n    const version = pkg.version;\n\n    const log = logger.for(\"get-crypto-material\");\n    log.debug(\n      `running with options: ${JSON.stringify(options)} for ${pkg.name} version ${version}`\n    );\n    const { folder, org } = options;\n    execSync(`docker cp ${org}:/weaver/client/. ${folder}`, {\n      cwd: process.cwd(),\n    });\n  });\n\nconst fabricCmd = new Command()\n  .name(\"for-fabric\")\n  .command(\"fabric\")\n  .description(\n    \"exposes several commands to help manage the fabric infrastructure\"\n  );\n\nfabricCmd.addCommand(compileCommand);\nfabricCmd.addCommand(extractIndexes);\nfabricCmd.addCommand(ensureInfra);\nfabricCmd.addCommand(deployContract);\nfabricCmd.addCommand(getCryptoMaterial);\nfabricCmd.addCommand(extractCollections);\n\nexport default function fabric() {\n  return fabricCmd;\n}\n"]}
@@ -1,2 +1,2 @@
1
- export declare const VERSION = "0.4.5";
1
+ export declare const VERSION = "0.4.7";
2
2
  export declare const PACKAGE_NAME = "@decaf-ts/for-fabric";
@@ -1,5 +1,5 @@
1
1
  import { Metadata } from "@decaf-ts/decoration";
2
- export const VERSION = "0.4.5";
2
+ export const VERSION = "0.4.7";
3
3
  export const PACKAGE_NAME = "@decaf-ts/for-fabric";
4
4
  Metadata.registerLibrary(PACKAGE_NAME, VERSION);
5
5
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUVoRCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsYUFBYSxDQUFDO0FBQ3JDLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxhQUFhLENBQUM7QUFFMUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxZQUFZLEVBQUUsT0FBTyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNZXRhZGF0YSB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdGlvblwiO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiIyNWRVJTSU9OIyNcIjtcbmV4cG9ydCBjb25zdCBQQUNLQUdFX05BTUUgPSBcIiMjUEFDS0FHRSMjXCI7XG5cbk1ldGFkYXRhLnJlZ2lzdGVyTGlicmFyeShQQUNLQUdFX05BTUUsIFZFUlNJT04pO1xuIl19
package/lib/version.cjs CHANGED
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.PACKAGE_NAME = exports.VERSION = void 0;
4
4
  const decoration_1 = require("@decaf-ts/decoration");
5
- exports.VERSION = "0.4.5";
5
+ exports.VERSION = "0.4.7";
6
6
  exports.PACKAGE_NAME = "@decaf-ts/for-fabric";
7
7
  decoration_1.Metadata.registerLibrary(exports.PACKAGE_NAME, exports.VERSION);
8
8
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFEQUFnRDtBQUVuQyxRQUFBLE9BQU8sR0FBRyxhQUFhLENBQUM7QUFDeEIsUUFBQSxZQUFZLEdBQUcsYUFBYSxDQUFDO0FBRTFDLHFCQUFRLENBQUMsZUFBZSxDQUFDLG9CQUFZLEVBQUUsZUFBTyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNZXRhZGF0YSB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdGlvblwiO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiIyNWRVJTSU9OIyNcIjtcbmV4cG9ydCBjb25zdCBQQUNLQUdFX05BTUUgPSBcIiMjUEFDS0FHRSMjXCI7XG5cbk1ldGFkYXRhLnJlZ2lzdGVyTGlicmFyeShQQUNLQUdFX05BTUUsIFZFUlNJT04pO1xuIl19
package/lib/version.d.ts CHANGED
@@ -1,2 +1,2 @@
1
- export declare const VERSION = "0.4.5";
1
+ export declare const VERSION = "0.4.7";
2
2
  export declare const PACKAGE_NAME = "@decaf-ts/for-fabric";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@decaf-ts/for-fabric",
3
- "version": "0.4.5",
3
+ "version": "0.4.7",
4
4
  "description": "Abstracts fabric logic",
5
5
  "type": "module",
6
6
  "exports": {
@@ -62,7 +62,7 @@
62
62
  "infrastructure-hsm:down": "docker compose -f ./docker/infrastructure/docker-compose-hsm.yaml down --rmi local -v",
63
63
  "build:contract2": "npx decaf fabric compile-contract --debug --bundle --name ${CONTRACT_NAME:-GlobalContract} --input ./src/contract --output ./docker/infrastructure/chaincode && LEVEL=verbose node ./lib/bin/cli.cjs extract-indexes --folder ./lib/contract --outDir ./docker/infrastructure/chaincode/${CONTRACT_NAME:-GlobalContract}",
64
64
  "update:contract": "npm run build:contract && npm run deploy:contract",
65
- "build:contract": "npx decaf fabric compile-contract --dev --debug --bundle --name ${CONTRACT_NAME:-GlobalContract} --input ./src/contract --output ./docker/infrastructure/chaincode && LEVEL=verbose node ./lib/bin/cli.cjs extract-indexes --folder ./lib/contract --outDir ./docker/infrastructure/chaincode/${CONTRACT_NAME:-GlobalContract}",
65
+ "build:contract": "npx decaf fabric compile-contract --sourcemaps --dev --debug --bundle --name ${CONTRACT_NAME:-GlobalContract} --input ./src/contract --output ./docker/infrastructure/chaincode && LEVEL=verbose node ./lib/bin/cli.cjs extract-indexes --folder ./lib/contract --outDir ./docker/infrastructure/chaincode/${CONTRACT_NAME:-GlobalContract}",
66
66
  "deploy:contract": "npx decaf fabric deploy-contract --name ${CONTRACT_NAME:-GlobalContract} --input ${CONTRACT_NAME:-GlobalContract}",
67
67
  "publish-docs": "docker run -it --rm --user $(id -u):$(id -g) -v \"$(pwd)/workdocs/confluence:/content\" -e ATLASSIAN_API_TOKEN=$(cat .confluence-token) ghcr.io/markdown-confluence/publish:latest",
68
68
  "copy-storage": "sudo cp -R docker/infrastructure/storage docker/docker-data/ && sudo chmod -R 755 docker/docker-data",