UNPKG

@decaf-ts/fabric-weaver

Version:
59 lines 11.8 kB
import { Logging } from "@decaf-ts/logging"; import { OrdererCommand } from "../../fabric/constants/fabric-orderer"; import { FabricOrdererCommandBuilder } from "../../fabric/orderer/fabric-orderer-command-builder"; import path from "path"; import fs from "fs"; import { FabricOrdererConfigBuilder } from "../../fabric/orderer/fabric-orderer-config-builder"; export function issueOrderer(log, cpath, consensus, channelParticipation, adminCfg, tls, port, address, keepAlive, msgSize, cluster, boot, msp, profile, metrics, operations, Kafka, fileLedgerLocation, authWindow, bccsp, debug) { log.info("Issuing Orderer"); const builder = new FabricOrdererConfigBuilder(log); builder .setConsensus(consensus) .setKafka(Kafka) .setFileLedgerLocation(fileLedgerLocation) .setAuthWindow(authWindow) .setBCCSP(bccsp) .setDebug(debug) .setCluster(cluster) .setBootstrap(boot) .setLocalMSP(msp) .setProfile(profile) .setMetrics(metrics) .setOperations(operations) .setChannelParticipation(channelParticipation) .setAdmin(adminCfg) .setTLS(tls) .setPort(port) .setListenAddress(address) .setKeepAlive(keepAlive) .setMSGSize(msgSize) .save(cpath); } export async function startOrderer() { const log = Logging.for(startOrderer); log.debug(`Starting Orderer`); const builder = new FabricOrdererCommandBuilder(log); builder.setCommand(OrdererCommand.START).execute(); } export async function bootOrderer(log, cpath, consensus, channelParticipation, adminCfg, tls, port, address, keepAlive, msgSize, cluster, boot, msp, profile, metrics, operations, Kafka, fileLedgerLocation, authWindow, bccsp, debug) { if (!hasOrdererInitialized()) issueOrderer(log, cpath, consensus, channelParticipation, adminCfg, tls, port, address, keepAlive, msgSize, cluster, boot, msp, profile, metrics, operations, Kafka, fileLedgerLocation, authWindow, bccsp, debug); startOrderer(); } export function hasOrdererInitialized(fileLocation) { const log = Logging.for(hasOrdererInitialized); const defaultFileLocation = path.join(__dirname, "../../../orderer/orderer.yaml"); if (!fileLocation) { log.debug(`No file location provided, using default file location: ${defaultFileLocation}`); fileLocation = defaultFileLocation; } else { if (!fileLocation.endsWith(".yaml")) fileLocation = path.join(fileLocation, "orderer.yaml"); log.debug(`Using provided file location: ${fileLocation}`); } const booted = fs.existsSync(fileLocation); log.debug(`Orderer has been booted: ${booted}`); return booted; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orderer.js","sourceRoot":"","sources":["../../../../src/core/scripts/orderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger, Logging } from \"@decaf-ts/logging\";\nimport { OrdererCommand } from \"../../fabric/constants/fabric-orderer\";\nimport { FabricOrdererCommandBuilder } from \"../../fabric/orderer/fabric-orderer-command-builder\";\nimport path from \"path\";\nimport fs from \"fs\";\nimport { FabricOrdererConfigBuilder } from \"../../fabric/orderer/fabric-orderer-config-builder\";\nimport {\n  AdminConfig,\n  BCCSPConfig,\n  BootstrapConfig,\n  ChannelParticipationConfig,\n  ClusterConfig,\n  ConsensusConfig,\n  DebugConfig,\n  KafkaConfig,\n  KeepAliveConfig,\n  MetricsConfig,\n  MSGSizeConfig,\n  MSPConfig,\n  OperationsConfig,\n  ProfileConfig,\n  TLSConfig,\n} from \"../../fabric/interfaces/fabric/orderer-config\";\n\nexport function issueOrderer(\n  log: Logger,\n  cpath?: string,\n  consensus?: ConsensusConfig,\n  channelParticipation?: ChannelParticipationConfig,\n  adminCfg?: AdminConfig,\n  tls?: TLSConfig,\n  port?: number,\n  address?: string,\n  keepAlive?: KeepAliveConfig,\n  msgSize?: MSGSizeConfig,\n  cluster?: ClusterConfig,\n  boot?: BootstrapConfig,\n  msp?: MSPConfig,\n  profile?: ProfileConfig,\n  metrics?: MetricsConfig,\n  operations?: OperationsConfig,\n  Kafka?: KafkaConfig,\n  fileLedgerLocation?: string,\n  authWindow?: string,\n  bccsp?: BCCSPConfig,\n  debug?: DebugConfig\n) {\n  log.info(\"Issuing Orderer\");\n\n  const builder = new FabricOrdererConfigBuilder(log);\n  builder\n    .setConsensus(consensus)\n    .setKafka(Kafka)\n    .setFileLedgerLocation(fileLedgerLocation)\n    .setAuthWindow(authWindow)\n    .setBCCSP(bccsp)\n    .setDebug(debug)\n    .setCluster(cluster)\n    .setBootstrap(boot)\n    .setLocalMSP(msp)\n    .setProfile(profile)\n    .setMetrics(metrics)\n    .setOperations(operations)\n    .setChannelParticipation(channelParticipation)\n    .setAdmin(adminCfg)\n    .setTLS(tls)\n    .setPort(port)\n    .setListenAddress(address)\n    .setKeepAlive(keepAlive)\n    .setMSGSize(msgSize)\n    .save(cpath);\n}\n\nexport async function startOrderer() {\n  const log: Logger = Logging.for(startOrderer);\n  log.debug(`Starting Orderer`);\n  const builder = new FabricOrdererCommandBuilder(log);\n\n  builder.setCommand(OrdererCommand.START).execute();\n}\n\nexport async function bootOrderer(\n  log: Logger,\n  cpath?: string,\n  consensus?: ConsensusConfig,\n  channelParticipation?: ChannelParticipationConfig,\n  adminCfg?: AdminConfig,\n  tls?: TLSConfig,\n  port?: number,\n  address?: string,\n  keepAlive?: KeepAliveConfig,\n  msgSize?: MSGSizeConfig,\n  cluster?: ClusterConfig,\n  boot?: BootstrapConfig,\n  msp?: MSPConfig,\n  profile?: ProfileConfig,\n  metrics?: MetricsConfig,\n  operations?: OperationsConfig,\n  Kafka?: KafkaConfig,\n  fileLedgerLocation?: string,\n  authWindow?: string,\n  bccsp?: BCCSPConfig,\n  debug?: DebugConfig\n) {\n  if (!hasOrdererInitialized())\n    issueOrderer(\n      log,\n      cpath,\n      consensus,\n      channelParticipation,\n      adminCfg,\n      tls,\n      port,\n      address,\n      keepAlive,\n      msgSize,\n      cluster,\n      boot,\n      msp,\n      profile,\n      metrics,\n      operations,\n      Kafka,\n      fileLedgerLocation,\n      authWindow,\n      bccsp,\n      debug\n    );\n  startOrderer();\n}\n\nexport function hasOrdererInitialized(fileLocation?: string): boolean {\n  const log: Logger = Logging.for(hasOrdererInitialized);\n\n  const defaultFileLocation = path.join(\n    __dirname,\n    \"../../../orderer/orderer.yaml\"\n  );\n\n  if (!fileLocation) {\n    log.debug(\n      `No file location provided, using default file location: ${defaultFileLocation}`\n    );\n    fileLocation = defaultFileLocation;\n  } else {\n    if (!fileLocation.endsWith(\".yaml\"))\n      fileLocation = path.join(fileLocation, \"orderer.yaml\");\n    log.debug(`Using provided file location: ${fileLocation}`);\n  }\n\n  const booted = fs.existsSync(fileLocation);\n\n  log.debug(`Orderer has been booted: ${booted}`);\n\n  return booted;\n}\n"]}