@decaf-ts/fabric-weaver
Version:
template for ts projects
116 lines • 13 kB
JavaScript
import { Logging } from "@decaf-ts/logging";
import { FabricBinaries } from "../constants/fabric-binaries";
import { PeerChaincodeCommands, PeerCommands } from "../constants/fabric-peer";
import { runCommand } from "../../utils/child-process";
export class FabricPeerChaincodeCommandBuilder {
constructor(logger) {
this.binName = FabricBinaries.PEER;
this.baseCommand = PeerCommands.CHAINCODE;
this.command = PeerChaincodeCommands.PACKAGE;
this.args = [];
if (!logger)
this.log = Logging.for(FabricPeerChaincodeCommandBuilder);
else
this.log = logger.for(FabricPeerChaincodeCommandBuilder.name);
}
setCommand(command) {
if (command !== undefined) {
this.log.debug(`Setting command to ${command}`);
this.command = command;
}
return this;
}
// setBlockPath(blockPath?: string): this {
// if (blockPath !== undefined) {
// this.log.debug(`Setting blockpath to ${blockPath}`);
// this.args.push(`--blockpath ${blockPath}`);
// }
// return this;
// }
// setBlockReference(blockRef?: string): this {
// if (blockRef !== undefined) {
// this.log.debug(`Setting block reference to ${blockRef}`);
// this.blockReference = blockRef;
// }
// return this;
// }
setlocation(location) {
if (location !== undefined) {
this.log.debug(`Setting contract location to ${location}`);
this.location = location;
}
return this;
}
// setChannelID(channelID?: string): this {
// if (channelID !== undefined) {
// this.log.debug(`Setting channel ID to ${channelID}`);
// this.args.push(`--channelID ${channelID}`);
// }
// return this;
// }
// setOrderer(orderer?: string): this {
// if (orderer !== undefined) {
// this.log.debug(`Setting orderer to ${orderer}`);
// this.args.push(`--orderer ${orderer}`);
// }
// return this;
// }
// enableTLS(enable?: boolean): this {
// if (enable !== undefined && enable === true) {
// this.log.debug(`Setting TLS enabled: ${enable}`);
// this.args.push(`--tls`);
// }
// return this;
// }
// setTLSCAFile(caFile?: string): this {
// if (caFile !== undefined) {
// this.log.debug(`Setting TLS CA file: ${caFile}`);
// this.args.push(`--cafile ${caFile}`);
// }
// return this;
// }
build() {
const command = [
this.getBinary(),
this.getBaseCommand(),
this.getCommand(),
this.location,
...[...new Set(this.args)],
]
.filter((item) => item !== undefined && item !== null && item !== "")
.join(" ");
this.log.debug(`Built command: ${command}`);
return command;
}
getBaseCommand() {
return this.baseCommand;
}
getCommand() {
return this.command;
}
getBinary() {
return this.binName;
}
getArgs() {
return [...new Set(this.args)];
}
async execute() {
const bin = this.getBinary();
const argz = [
this.getBaseCommand(),
this.getCommand(),
this.location,
...this.getArgs(),
].filter((item) => item !== undefined && item !== null && item !== "");
try {
// const regex = /\[\s*INFO\s*\] Listening on http/;
// can be used as a promise but to lock the logs running as execsync
await runCommand(bin, argz);
}
catch (error) {
this.log.error(`Error: Failed to execute the command: ${error}`);
process.exit(1);
}
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fabric-peer-chaincode-command-builder.js","sourceRoot":"","sources":["../../../../src/fabric/peer/fabric-peer-chaincode-command-builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger, Logging } from \"@decaf-ts/logging\";\nimport { FabricBinaries } from \"../constants/fabric-binaries\";\nimport { PeerChaincodeCommands, PeerCommands } from \"../constants/fabric-peer\";\nimport { runCommand } from \"../../utils/child-process\";\n\nexport class FabricPeerChaincodeCommandBuilder {\n  private log: Logger;\n\n  private binName: FabricBinaries = FabricBinaries.PEER;\n  private baseCommand = PeerCommands.CHAINCODE;\n\n  private command = PeerChaincodeCommands.PACKAGE;\n\n  private location?: string;\n\n  private args: string[] = [];\n\n  constructor(logger?: Logger) {\n    if (!logger) this.log = Logging.for(FabricPeerChaincodeCommandBuilder);\n    else this.log = logger.for(FabricPeerChaincodeCommandBuilder.name);\n  }\n\n  setCommand(command?: PeerChaincodeCommands): this {\n    if (command !== undefined) {\n      this.log.debug(`Setting command to ${command}`);\n      this.command = command;\n    }\n    return this;\n  }\n\n  //   setBlockPath(blockPath?: string): this {\n  //     if (blockPath !== undefined) {\n  //       this.log.debug(`Setting blockpath to ${blockPath}`);\n  //       this.args.push(`--blockpath ${blockPath}`);\n  //     }\n  //     return this;\n  //   }\n\n  //   setBlockReference(blockRef?: string): this {\n  //     if (blockRef !== undefined) {\n  //       this.log.debug(`Setting block reference to ${blockRef}`);\n  //       this.blockReference = blockRef;\n  //     }\n  //     return this;\n  //   }\n\n  setlocation(location?: string): this {\n    if (location !== undefined) {\n      this.log.debug(`Setting contract location to ${location}`);\n      this.location = location;\n    }\n    return this;\n  }\n\n  //   setChannelID(channelID?: string): this {\n  //     if (channelID !== undefined) {\n  //       this.log.debug(`Setting channel ID to ${channelID}`);\n  //       this.args.push(`--channelID ${channelID}`);\n  //     }\n  //     return this;\n  //   }\n\n  //   setOrderer(orderer?: string): this {\n  //     if (orderer !== undefined) {\n  //       this.log.debug(`Setting orderer to ${orderer}`);\n  //       this.args.push(`--orderer ${orderer}`);\n  //     }\n  //     return this;\n  //   }\n\n  //   enableTLS(enable?: boolean): this {\n  //     if (enable !== undefined && enable === true) {\n  //       this.log.debug(`Setting TLS enabled: ${enable}`);\n  //       this.args.push(`--tls`);\n  //     }\n  //     return this;\n  //   }\n\n  //   setTLSCAFile(caFile?: string): this {\n  //     if (caFile !== undefined) {\n  //       this.log.debug(`Setting TLS CA file: ${caFile}`);\n  //       this.args.push(`--cafile ${caFile}`);\n  //     }\n\n  //     return this;\n  //   }\n\n  build(): string {\n    const command: string = [\n      this.getBinary(),\n      this.getBaseCommand(),\n      this.getCommand(),\n      this.location,\n      ...[...new Set(this.args)],\n    ]\n      .filter((item) => item !== undefined && item !== null && item !== \"\")\n      .join(\" \");\n\n    this.log.debug(`Built command: ${command}`);\n    return command;\n  }\n\n  getBaseCommand(): string {\n    return this.baseCommand;\n  }\n\n  getCommand(): string {\n    return this.command;\n  }\n\n  getBinary(): string {\n    return this.binName;\n  }\n\n  getArgs(): string[] {\n    return [...new Set(this.args)];\n  }\n\n  async execute(): Promise<void> {\n    const bin = this.getBinary();\n    const argz = [\n      this.getBaseCommand(),\n      this.getCommand(),\n      this.location,\n      ...this.getArgs(),\n    ].filter(\n      (item) => item !== undefined && item !== null && item !== \"\"\n    ) as string[];\n\n    try {\n      // const regex = /\\[\\s*INFO\\s*\\] Listening on http/;\n      // can be used as a promise but to lock the logs running as execsync\n      await runCommand(bin, argz);\n    } catch (error: unknown) {\n      this.log.error(`Error: Failed to execute the command: ${error}`);\n      process.exit(1);\n    }\n  }\n}\n"]}