@decaf-ts/fabric-weaver
Version:
template for ts projects
186 lines • 36.3 kB
JavaScript
import path from "path";
import fs from "fs";
import { Logging } from "@decaf-ts/logging";
import { FabricPeerConfigBuilder } from "../../fabric/peer/fabric-peer-config-builder";
import { FabricPeerNodeCommandBuilder } from "../../fabric/peer/fabric-peer-node-command-builder";
import { PeerChannelCommands, PeerLifecycleChaincodeCommands, PeerNodeCommands, } from "../../fabric/constants/fabric-peer";
import { FabricPeerChannelCommandBuilder } from "../../fabric/peer/fabric-peer-channel-command-builder";
import { FabricPeerLifecycleChaincodeCommandBuilder } from "../../fabric/peer/fabric-peer-lifecycle-chaincode-command-builder";
import { execSync } from "child_process";
export function issuePeer(log, cpath, gossip, tls, authTimeWindow, keepAlive, gateway, general, bccsp, msp, clientConnectionTimeout, delivery, profile, handlers, discovery, limits, msgSize, chaincode, state, blockchain, enableLedgerHistoryDatabase, pvtData, ledgerSnapshosRootDir, operation, metrics, vm) {
const logger = Logging.for(issuePeer);
log.debug(`Issuing Peer...`);
log.debug(`Writing configuration to ${cpath}`);
const builder = new FabricPeerConfigBuilder(logger);
builder
.setGossip(gossip)
.setTLS(tls)
.setLedgerSnapshotsRootDir(ledgerSnapshosRootDir)
.setOperations(operation)
.setMetrics(metrics)
.enableLedgerHistoryDatabase(enableLedgerHistoryDatabase)
.setLedgerPvtDataStore(pvtData)
.setHandlers(handlers)
.setDiscovery(discovery)
.setLimits(limits)
.setMessageSize(msgSize)
.setChaincode(chaincode)
.setLedgerState(state)
.setLegerBlockchain(blockchain)
.setAuthentication(authTimeWindow)
.setKeepAlice(keepAlive)
.setGateway(gateway)
.setGeneral(general)
.setBCCSP(bccsp)
.setMspConfig(msp)
.setConnTimeoutClient(clientConnectionTimeout)
.setDeliveryClient(delivery)
.setProfile(profile)
.setVMOptions(vm)
.save(cpath);
}
export async function startPeer(logger) {
const log = logger.for(startPeer);
log.debug(`Starting Peer`);
const builder = new FabricPeerNodeCommandBuilder(log);
builder.setCommand(PeerNodeCommands.START).execute();
}
export async function bootPeer(log, cpath, gossip, tls, authTimeWindow, keepAlive, gateway, general, bccsp, msp, clientConnectionTimeout, delivery, profile, handlers, discovery, limits, msgSize, chaincode, state, blockchain, enableLedgerHistoryDatabase, pvtData, ledgerSnapshosRootDir, operation, metrics, vm) {
const logger = Logging.for(bootPeer);
log.debug(`Booting Peer...`);
if (!hasPeerInitialized(cpath))
issuePeer(logger, cpath, gossip, tls, authTimeWindow, keepAlive, gateway, general, bccsp, msp, clientConnectionTimeout, delivery, profile, handlers, discovery, limits, msgSize, chaincode, state, blockchain, enableLedgerHistoryDatabase, pvtData, ledgerSnapshosRootDir, operation, metrics, vm);
startPeer(logger);
}
export function hasPeerInitialized(fileLocation) {
const log = Logging.for(hasPeerInitialized);
const defaultFileLocation = path.join(__dirname, "../../../peer/core.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, "core.yaml");
log.debug(`Using provided file location: ${fileLocation}`);
}
const booted = fs.existsSync(fileLocation);
log.debug(`Peer has been booted: ${booted}`);
return booted;
}
export function peerFetchGenesisBlock(logger, channelID, ordererAddress, blockNumber, outputFile, tlsEnabled, tlsCACertFile) {
const log = Logging.for(peerFetchGenesisBlock);
log.debug(`Fetching Genesis Block`);
const builder = new FabricPeerChannelCommandBuilder(logger);
builder
.enableTLS(tlsEnabled)
.setCommand(PeerChannelCommands.FETCH)
.setBlockReference(blockNumber)
.setDestination(outputFile)
.setOrderer(ordererAddress)
.setChannelID(channelID)
.setTLSCAFile(tlsCACertFile)
.execute();
}
export async function peerJoinChannel(logger, blockPath) {
const log = Logging.for(peerJoinChannel);
log.debug(`Joining Channel`);
const builder = new FabricPeerChannelCommandBuilder(logger);
builder
.setCommand(PeerChannelCommands.JOIN)
.setBlockPath(blockPath)
.execute();
}
export function packageChaincode(logger, outputFile, contractPath, lang, contractName, contractVersion) {
const log = Logging.for(packageChaincode);
log.debug(`Packaging Chaincode`);
const builder = new FabricPeerLifecycleChaincodeCommandBuilder(logger);
builder
.setCommand(PeerLifecycleChaincodeCommands.PACKAGE)
.setDestination(outputFile)
.setContractPath(contractPath)
.setLang(lang)
.setLabel(`${contractName}_${contractVersion}`)
.execute();
}
export function installChaincode(logger, contractLocation) {
const log = Logging.for(installChaincode);
log.debug(`Installing Chaincode`);
const builder = new FabricPeerLifecycleChaincodeCommandBuilder(logger);
builder
.setCommand(PeerLifecycleChaincodeCommands.INSTALL)
.setDestination(contractLocation)
.execute();
}
export function approveChaincode(logger, ordererAddress, channelID, chaincodeName, version, sequence, enableTLS, tlsCACertFile, collectionConfigPath, ordererTLSHostnameOverride) {
const log = Logging.for(installChaincode);
log.debug(`Approve Chaincode`);
const builder = new FabricPeerLifecycleChaincodeCommandBuilder(logger);
const id = execSync(builder.setCommand(PeerLifecycleChaincodeCommands.QUERYINSTALLED).build());
log.debug(`Using id: ${id}`);
builder
.setCommand(PeerLifecycleChaincodeCommands.APPROVEFORMYORG)
.setOrdererAddress(ordererAddress)
.setChannelID(channelID)
.setContractName(chaincodeName)
.setVersion(version)
.setSequence(sequence)
.enableTLS(enableTLS)
.setTLSCAFile(tlsCACertFile)
.setOrdererTLSHostnameOverride(ordererTLSHostnameOverride)
.setCollectionsConfigPath(collectionConfigPath)
.setPackageID(id
.toString()
.split(",")[0]
.split("\n")[1]
.split(":")
.slice(1)
.map((s) => s.trim())
.join(":"))
.execute();
}
export async function commitChainCode(logger, ordererAddress, channelID, chaincodeName, version, sequence, enableTLS, tlsCACertFile, collectionConfigPath, ordererTLSHostnameOverride, peerAddresses, peerTLSRoots) {
const log = Logging.for(commitChainCode);
log.info(`Commiting chaincode`);
const checkChaincodeReadiness = function (logger, channelID, chaincodeName, version, sequence, enableTLS, tlsCACertFile) {
const verificationBuilder = new FabricPeerLifecycleChaincodeCommandBuilder(logger);
const approvalData = execSync(verificationBuilder
.setCommand(PeerLifecycleChaincodeCommands.CHECKCOMMITREADINESS)
.setChannelID(channelID)
.setContractName(chaincodeName)
.setVersion(version)
.setSequence(sequence)
.enableTLS(enableTLS)
.setTLSCAFile(tlsCACertFile)
.setOutput("json")
.build()).toString();
const approvalJSON = JSON.parse(approvalData);
log.info(JSON.stringify(approvalJSON, null, 2));
return (Object.keys(approvalJSON.approvals).filter((key) => approvalJSON.approvals[key] == true).length >
Object.keys(approvalJSON.approvals).length / 2);
};
const commitWhenReady = function (logger, ordererAddress, channelID, chaincodeName, version, sequence, enableTLS, tlsCACertFile, collectionConfigPath, ordererTLSHostnameOverride, peerAddresses, peerTLSRoots) {
if (!checkChaincodeReadiness(logger, channelID, chaincodeName, version, sequence, enableTLS, tlsCACertFile)) {
log.info("Chaincode not ready, waiting...");
return setTimeout(() => {
commitWhenReady(logger, ordererAddress, channelID, chaincodeName, version, sequence, enableTLS, tlsCACertFile, collectionConfigPath, ordererTLSHostnameOverride, peerAddresses, peerTLSRoots);
}, 30000);
}
new FabricPeerLifecycleChaincodeCommandBuilder(logger)
.setCommand(PeerLifecycleChaincodeCommands.COMMIT)
.setOrdererAddress(ordererAddress)
.setChannelID(channelID)
.setContractName(chaincodeName)
.setVersion(version)
.setSequence(sequence)
.enableTLS(enableTLS)
.setTLSCAFile(tlsCACertFile)
.setCollectionsConfigPath(collectionConfigPath)
.setOrdererTLSHostnameOverride(ordererTLSHostnameOverride)
.setPeerAddresses(peerAddresses)
.setPeerTLSRoots(peerTLSRoots)
.execute();
};
commitWhenReady(logger, ordererAddress, channelID, chaincodeName, version, sequence, enableTLS, tlsCACertFile, collectionConfigPath, ordererTLSHostnameOverride, peerAddresses, peerTLSRoots);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"peer.js","sourceRoot":"","sources":["../../../../src/core/scripts/peer.ts"],"names":[],"mappings":"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","sourcesContent":["import path from \"path\";\nimport fs from \"fs\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\nimport { FabricPeerConfigBuilder } from \"../../fabric/peer/fabric-peer-config-builder\";\nimport {\n  BCCSPConfig,\n  ChaincodeConfig,\n  DeliveryClientConfig,\n  DiscoveryConfig,\n  GatewayConfig,\n  GeneralConfig,\n  GossipConfig,\n  HandlersConfig,\n  KeepAliveConfig,\n  LedgerStateConfig,\n  LimitsConfig,\n  MSGSizeConfig,\n  MSPConfig,\n  PrivateDataStoreConfig,\n  ProfileConfig,\n  TLSConfig,\n  VMConfig,\n} from \"../../fabric/interfaces/fabric/peer-config\";\nimport {\n  MetricsConfig,\n  OperationsConfig,\n} from \"../../fabric/interfaces/fabric/general-configs\";\nimport { FabricPeerNodeCommandBuilder } from \"../../fabric/peer/fabric-peer-node-command-builder\";\nimport {\n  PeerChannelCommands,\n  PeerLifecycleChaincodeCommands,\n  PeerNodeCommands,\n} from \"../../fabric/constants/fabric-peer\";\nimport { FabricPeerChannelCommandBuilder } from \"../../fabric/peer/fabric-peer-channel-command-builder\";\nimport { FabricPeerLifecycleChaincodeCommandBuilder } from \"../../fabric/peer/fabric-peer-lifecycle-chaincode-command-builder\";\nimport { execSync } from \"child_process\";\n\nexport function issuePeer(\n  log: Logger,\n  cpath: string,\n  gossip?: GossipConfig,\n  tls?: TLSConfig,\n  authTimeWindow?: string,\n  keepAlive?: KeepAliveConfig,\n  gateway?: GatewayConfig,\n  general?: GeneralConfig,\n  bccsp?: BCCSPConfig,\n  msp?: MSPConfig,\n  clientConnectionTimeout?: string,\n  delivery?: DeliveryClientConfig,\n  profile?: ProfileConfig,\n  handlers?: HandlersConfig,\n  discovery?: DiscoveryConfig,\n  limits?: LimitsConfig,\n  msgSize?: MSGSizeConfig,\n  chaincode?: ChaincodeConfig,\n  state?: LedgerStateConfig,\n  blockchain?: any,\n  enableLedgerHistoryDatabase?: boolean,\n  pvtData?: PrivateDataStoreConfig,\n  ledgerSnapshosRootDir?: string,\n  operation?: OperationsConfig,\n  metrics?: MetricsConfig,\n  vm?: VMConfig\n) {\n  const logger = Logging.for(issuePeer);\n  log.debug(`Issuing Peer...`);\n  log.debug(`Writing configuration to ${cpath}`);\n\n  const builder = new FabricPeerConfigBuilder(logger);\n\n  builder\n    .setGossip(gossip)\n    .setTLS(tls)\n    .setLedgerSnapshotsRootDir(ledgerSnapshosRootDir)\n    .setOperations(operation)\n    .setMetrics(metrics)\n    .enableLedgerHistoryDatabase(enableLedgerHistoryDatabase)\n    .setLedgerPvtDataStore(pvtData)\n    .setHandlers(handlers)\n    .setDiscovery(discovery)\n    .setLimits(limits)\n    .setMessageSize(msgSize)\n    .setChaincode(chaincode)\n    .setLedgerState(state)\n    .setLegerBlockchain(blockchain)\n    .setAuthentication(authTimeWindow)\n    .setKeepAlice(keepAlive)\n    .setGateway(gateway)\n    .setGeneral(general)\n    .setBCCSP(bccsp)\n    .setMspConfig(msp)\n    .setConnTimeoutClient(clientConnectionTimeout)\n    .setDeliveryClient(delivery)\n    .setProfile(profile)\n    .setVMOptions(vm)\n    .save(cpath);\n}\n\nexport async function startPeer(logger: Logger) {\n  const log: Logger = logger.for(startPeer);\n  log.debug(`Starting Peer`);\n\n  const builder = new FabricPeerNodeCommandBuilder(log);\n\n  builder.setCommand(PeerNodeCommands.START).execute();\n}\n\nexport async function bootPeer(\n  log: Logger,\n  cpath: string,\n  gossip?: GossipConfig,\n  tls?: TLSConfig,\n  authTimeWindow?: string,\n  keepAlive?: KeepAliveConfig,\n  gateway?: GatewayConfig,\n  general?: GeneralConfig,\n  bccsp?: BCCSPConfig,\n  msp?: MSPConfig,\n  clientConnectionTimeout?: string,\n  delivery?: DeliveryClientConfig,\n  profile?: ProfileConfig,\n  handlers?: HandlersConfig,\n  discovery?: DiscoveryConfig,\n  limits?: LimitsConfig,\n  msgSize?: MSGSizeConfig,\n  chaincode?: ChaincodeConfig,\n  state?: LedgerStateConfig,\n  blockchain?: any,\n  enableLedgerHistoryDatabase?: boolean,\n  pvtData?: PrivateDataStoreConfig,\n  ledgerSnapshosRootDir?: string,\n  operation?: OperationsConfig,\n  metrics?: MetricsConfig,\n  vm?: VMConfig\n) {\n  const logger = Logging.for(bootPeer);\n  log.debug(`Booting Peer...`);\n\n  if (!hasPeerInitialized(cpath))\n    issuePeer(\n      logger,\n      cpath,\n      gossip,\n      tls,\n      authTimeWindow,\n      keepAlive,\n      gateway,\n      general,\n      bccsp,\n      msp,\n      clientConnectionTimeout,\n      delivery,\n      profile,\n      handlers,\n      discovery,\n      limits,\n      msgSize,\n      chaincode,\n      state,\n      blockchain,\n      enableLedgerHistoryDatabase,\n      pvtData,\n      ledgerSnapshosRootDir,\n      operation,\n      metrics,\n      vm\n    );\n\n  startPeer(logger);\n}\n\nexport function hasPeerInitialized(fileLocation?: string): boolean {\n  const log: Logger = Logging.for(hasPeerInitialized);\n\n  const defaultFileLocation = path.join(__dirname, \"../../../peer/core.yaml\");\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, \"core.yaml\");\n    log.debug(`Using provided file location: ${fileLocation}`);\n  }\n\n  const booted = fs.existsSync(fileLocation);\n\n  log.debug(`Peer has been booted: ${booted}`);\n\n  return booted;\n}\n\nexport function peerFetchGenesisBlock(\n  logger?: Logger,\n  channelID?: string,\n  ordererAddress?: string,\n  blockNumber?: string,\n  outputFile?: string,\n  tlsEnabled?: boolean,\n  tlsCACertFile?: string\n) {\n  const log: Logger = Logging.for(peerFetchGenesisBlock);\n  log.debug(`Fetching Genesis Block`);\n\n  const builder = new FabricPeerChannelCommandBuilder(logger);\n\n  builder\n    .enableTLS(tlsEnabled)\n    .setCommand(PeerChannelCommands.FETCH)\n    .setBlockReference(blockNumber)\n    .setDestination(outputFile)\n    .setOrderer(ordererAddress)\n    .setChannelID(channelID)\n    .setTLSCAFile(tlsCACertFile)\n    .execute();\n}\n\nexport async function peerJoinChannel(logger?: Logger, blockPath?: string) {\n  const log: Logger = Logging.for(peerJoinChannel);\n  log.debug(`Joining Channel`);\n\n  const builder = new FabricPeerChannelCommandBuilder(logger);\n\n  builder\n    .setCommand(PeerChannelCommands.JOIN)\n    .setBlockPath(blockPath)\n    .execute();\n}\n\nexport function packageChaincode(\n  logger?: Logger,\n  outputFile?: string,\n  contractPath?: string,\n  lang?: string,\n  contractName?: string,\n  contractVersion?: string\n) {\n  const log: Logger = Logging.for(packageChaincode);\n  log.debug(`Packaging Chaincode`);\n\n  const builder = new FabricPeerLifecycleChaincodeCommandBuilder(logger);\n\n  builder\n    .setCommand(PeerLifecycleChaincodeCommands.PACKAGE)\n    .setDestination(outputFile)\n    .setContractPath(contractPath)\n    .setLang(lang)\n    .setLabel(`${contractName}_${contractVersion}`)\n    .execute();\n}\n\nexport function installChaincode(logger: Logger, contractLocation?: string) {\n  const log: Logger = Logging.for(installChaincode);\n  log.debug(`Installing Chaincode`);\n\n  const builder = new FabricPeerLifecycleChaincodeCommandBuilder(logger);\n\n  builder\n    .setCommand(PeerLifecycleChaincodeCommands.INSTALL)\n    .setDestination(contractLocation)\n    .execute();\n}\n\nexport function approveChaincode(\n  logger: Logger,\n  ordererAddress?: string,\n  channelID?: string,\n  chaincodeName?: string,\n  version?: string,\n  sequence?: string,\n  enableTLS?: boolean,\n  tlsCACertFile?: string,\n  collectionConfigPath?: string,\n  ordererTLSHostnameOverride?: string\n) {\n  const log: Logger = Logging.for(installChaincode);\n  log.debug(`Approve Chaincode`);\n\n  const builder = new FabricPeerLifecycleChaincodeCommandBuilder(logger);\n\n  const id = execSync(\n    builder.setCommand(PeerLifecycleChaincodeCommands.QUERYINSTALLED).build()\n  );\n\n  log.debug(`Using id: ${id}`);\n\n  builder\n    .setCommand(PeerLifecycleChaincodeCommands.APPROVEFORMYORG)\n    .setOrdererAddress(ordererAddress)\n    .setChannelID(channelID)\n    .setContractName(chaincodeName)\n    .setVersion(version)\n    .setSequence(sequence)\n    .enableTLS(enableTLS)\n    .setTLSCAFile(tlsCACertFile)\n    .setOrdererTLSHostnameOverride(ordererTLSHostnameOverride)\n    .setCollectionsConfigPath(collectionConfigPath)\n    .setPackageID(\n      id\n        .toString()\n        .split(\",\")[0]\n        .split(\"\\n\")[1]\n        .split(\":\")\n        .slice(1)\n        .map((s) => s.trim())\n        .join(\":\")\n    )\n    .execute();\n}\n\nexport async function commitChainCode(\n  logger: Logger,\n  ordererAddress?: string,\n  channelID?: string,\n  chaincodeName?: string,\n  version?: string,\n  sequence?: string,\n  enableTLS?: boolean,\n  tlsCACertFile?: string,\n  collectionConfigPath?: string,\n  ordererTLSHostnameOverride?: string,\n  peerAddresses?: string[],\n  peerTLSRoots?: string[]\n) {\n  const log: Logger = Logging.for(commitChainCode);\n  log.info(`Commiting chaincode`);\n\n  const checkChaincodeReadiness = function (\n    logger: Logger,\n    channelID?: string,\n    chaincodeName?: string,\n    version?: string,\n    sequence?: string,\n    enableTLS?: boolean,\n    tlsCACertFile?: string\n  ) {\n    const verificationBuilder = new FabricPeerLifecycleChaincodeCommandBuilder(\n      logger\n    );\n\n    const approvalData = execSync(\n      verificationBuilder\n        .setCommand(PeerLifecycleChaincodeCommands.CHECKCOMMITREADINESS)\n        .setChannelID(channelID)\n        .setContractName(chaincodeName)\n        .setVersion(version)\n        .setSequence(sequence)\n        .enableTLS(enableTLS)\n        .setTLSCAFile(tlsCACertFile)\n        .setOutput(\"json\")\n        .build()\n    ).toString();\n\n    const approvalJSON = JSON.parse(approvalData);\n\n    log.info(JSON.stringify(approvalJSON, null, 2));\n\n    return (\n      Object.keys(approvalJSON.approvals).filter(\n        (key) => approvalJSON.approvals[key] == true\n      ).length >\n      Object.keys(approvalJSON.approvals).length / 2\n    );\n  };\n\n  const commitWhenReady = function (\n    logger: Logger,\n    ordererAddress?: string,\n    channelID?: string,\n    chaincodeName?: string,\n    version?: string,\n    sequence?: string,\n    enableTLS?: boolean,\n    tlsCACertFile?: string,\n    collectionConfigPath?: string,\n    ordererTLSHostnameOverride?: string,\n    peerAddresses?: string[],\n    peerTLSRoots?: string[]\n  ) {\n    if (\n      !checkChaincodeReadiness(\n        logger,\n        channelID,\n        chaincodeName,\n        version,\n        sequence,\n        enableTLS,\n        tlsCACertFile\n      )\n    ) {\n      log.info(\"Chaincode not ready, waiting...\");\n      return setTimeout(() => {\n        commitWhenReady(\n          logger,\n          ordererAddress,\n          channelID,\n          chaincodeName,\n          version,\n          sequence,\n          enableTLS,\n          tlsCACertFile,\n          collectionConfigPath,\n          ordererTLSHostnameOverride,\n          peerAddresses,\n          peerTLSRoots\n        );\n      }, 30000);\n    }\n\n    new FabricPeerLifecycleChaincodeCommandBuilder(logger)\n      .setCommand(PeerLifecycleChaincodeCommands.COMMIT)\n      .setOrdererAddress(ordererAddress)\n      .setChannelID(channelID)\n      .setContractName(chaincodeName)\n      .setVersion(version)\n      .setSequence(sequence)\n      .enableTLS(enableTLS)\n      .setTLSCAFile(tlsCACertFile)\n      .setCollectionsConfigPath(collectionConfigPath)\n      .setOrdererTLSHostnameOverride(ordererTLSHostnameOverride)\n      .setPeerAddresses(peerAddresses)\n      .setPeerTLSRoots(peerTLSRoots)\n      .execute();\n  };\n\n  commitWhenReady(\n    logger,\n    ordererAddress,\n    channelID,\n    chaincodeName,\n    version,\n    sequence,\n    enableTLS,\n    tlsCACertFile,\n    collectionConfigPath,\n    ordererTLSHostnameOverride,\n    peerAddresses,\n    peerTLSRoots\n  );\n}\n"]}