mirror of
https://github.com/hyperledger/fabric-samples.git
synced 2026-06-17 07:25:10 +00:00
These samples target Fabric v2.2 but contained references to the latest version of the Fabric documentation, many of which were broken links since the structure and content of the Fabric documentation has changed. This change updates links to the Fabric documentation so that they refer to release-2.2. Signed-off-by: Mark S. Lewis <Mark.S.Lewis@outlook.com>
284 lines
7.8 KiB
Bash
Executable file
284 lines
7.8 KiB
Bash
Executable file
#!/bin/bash
|
|
#
|
|
# Copyright IBM Corp All Rights Reserved
|
|
#
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
#
|
|
|
|
# This script extends the Hyperledger Fabric test network by adding
|
|
# adding a third organization to the network
|
|
#
|
|
|
|
# prepending $PWD/../bin to PATH to ensure we are picking up the correct binaries
|
|
# this may be commented out to resolve installed version of tools if desired
|
|
export PATH=${PWD}/../../bin:${PWD}:$PATH
|
|
export FABRIC_CFG_PATH=${PWD}
|
|
export VERBOSE=false
|
|
|
|
. ../scripts/utils.sh
|
|
|
|
# Print the usage message
|
|
function printHelp () {
|
|
echo "Usage: "
|
|
echo " addOrg3.sh up|down|generate [-c <channel name>] [-t <timeout>] [-d <delay>] [-f <docker-compose-file>] [-s <dbtype>]"
|
|
echo " addOrg3.sh -h|--help (print this message)"
|
|
echo " <mode> - one of 'up', 'down', or 'generate'"
|
|
echo " - 'up' - add org3 to the sample network. You need to bring up the test network and create a channel first."
|
|
echo " - 'down' - bring down the test network and org3 nodes"
|
|
echo " - 'generate' - generate required certificates and org definition"
|
|
echo " -c <channel name> - test network channel name (defaults to \"mychannel\")"
|
|
echo " -ca <use CA> - Use a CA to generate the crypto material"
|
|
echo " -t <timeout> - CLI timeout duration in seconds (defaults to 10)"
|
|
echo " -d <delay> - delay duration in seconds (defaults to 3)"
|
|
echo " -s <dbtype> - the database backend to use: goleveldb (default) or couchdb"
|
|
echo " -i <imagetag> - the tag to be used to launch the network (defaults to \"latest\")"
|
|
echo " -cai <ca_imagetag> - the image tag to be used for CA (defaults to \"${CA_IMAGETAG}\")"
|
|
echo " -verbose - verbose mode"
|
|
echo
|
|
echo "Typically, one would first generate the required certificates and "
|
|
echo "genesis block, then bring up the network. e.g.:"
|
|
echo
|
|
echo " addOrg3.sh generate"
|
|
echo " addOrg3.sh up"
|
|
echo " addOrg3.sh up -c mychannel -s couchdb"
|
|
echo " addOrg3.sh down"
|
|
echo
|
|
echo "Taking all defaults:"
|
|
echo " addOrg3.sh up"
|
|
echo " addOrg3.sh down"
|
|
}
|
|
|
|
# We use the cryptogen tool to generate the cryptographic material
|
|
# (x509 certs) for the new org. After we run the tool, the certs will
|
|
# be put in the organizations folder with org1 and org2
|
|
|
|
# Create Organziation crypto material using cryptogen or CAs
|
|
function generateOrg3() {
|
|
# Create crypto material using cryptogen
|
|
if [ "$CRYPTO" == "cryptogen" ]; then
|
|
which cryptogen
|
|
if [ "$?" -ne 0 ]; then
|
|
fatalln "cryptogen tool not found. exiting"
|
|
fi
|
|
infoln "Generating certificates using cryptogen tool"
|
|
|
|
infoln "Creating Org3 Identities"
|
|
|
|
set -x
|
|
cryptogen generate --config=org3-crypto.yaml --output="../organizations"
|
|
res=$?
|
|
{ set +x; } 2>/dev/null
|
|
if [ $res -ne 0 ]; then
|
|
fatalln "Failed to generate certificates..."
|
|
fi
|
|
|
|
fi
|
|
|
|
# Create crypto material using Fabric CA
|
|
if [ "$CRYPTO" == "Certificate Authorities" ]; then
|
|
fabric-ca-client version > /dev/null 2>&1
|
|
if [[ $? -ne 0 ]]; then
|
|
echo "ERROR! fabric-ca-client binary not found.."
|
|
echo
|
|
echo "Follow the instructions in the Fabric docs to install the Fabric Binaries:"
|
|
echo "https://hyperledger-fabric.readthedocs.io/en/release-2.2/install.html"
|
|
exit 1
|
|
fi
|
|
|
|
infoln "Generating certificates using Fabric CA"
|
|
|
|
IMAGE_TAG=${CA_IMAGETAG} docker-compose -f $COMPOSE_FILE_CA_ORG3 up -d 2>&1
|
|
|
|
. fabric-ca/registerEnroll.sh
|
|
|
|
sleep 10
|
|
|
|
infoln "Creating Org3 Identities"
|
|
createOrg3
|
|
|
|
fi
|
|
|
|
infoln "Generating CCP files for Org3"
|
|
./ccp-generate.sh
|
|
}
|
|
|
|
# Generate channel configuration transaction
|
|
function generateOrg3Definition() {
|
|
which configtxgen
|
|
if [ "$?" -ne 0 ]; then
|
|
fatalln "configtxgen tool not found. exiting"
|
|
fi
|
|
infoln "Generating Org3 organization definition"
|
|
export FABRIC_CFG_PATH=$PWD
|
|
set -x
|
|
configtxgen -printOrg Org3MSP > ../organizations/peerOrganizations/org3.example.com/org3.json
|
|
res=$?
|
|
{ set +x; } 2>/dev/null
|
|
if [ $res -ne 0 ]; then
|
|
fatalln "Failed to generate Org3 organization definition..."
|
|
fi
|
|
}
|
|
|
|
function Org3Up () {
|
|
# start org3 nodes
|
|
if [ "${DATABASE}" == "couchdb" ]; then
|
|
IMAGE_TAG=${IMAGETAG} docker-compose -f $COMPOSE_FILE_ORG3 -f $COMPOSE_FILE_COUCH_ORG3 up -d 2>&1
|
|
else
|
|
IMAGE_TAG=$IMAGETAG docker-compose -f $COMPOSE_FILE_ORG3 up -d 2>&1
|
|
fi
|
|
if [ $? -ne 0 ]; then
|
|
fatalln "ERROR !!!! Unable to start Org3 network"
|
|
fi
|
|
}
|
|
|
|
# Generate the needed certificates, the genesis block and start the network.
|
|
function addOrg3 () {
|
|
# If the test network is not up, abort
|
|
if [ ! -d ../organizations/ordererOrganizations ]; then
|
|
fatalln "ERROR: Please, run ./network.sh up createChannel first."
|
|
fi
|
|
|
|
# generate artifacts if they don't exist
|
|
if [ ! -d "../organizations/peerOrganizations/org3.example.com" ]; then
|
|
generateOrg3
|
|
generateOrg3Definition
|
|
fi
|
|
|
|
infoln "Bringing up Org3 peer"
|
|
Org3Up
|
|
|
|
# Use the CLI container to create the configuration transaction needed to add
|
|
# Org3 to the network
|
|
infoln "Generating and submitting config tx to add Org3"
|
|
docker exec cli ./scripts/org3-scripts/updateChannelConfig.sh $CHANNEL_NAME $CLI_DELAY $CLI_TIMEOUT $VERBOSE
|
|
if [ $? -ne 0 ]; then
|
|
fatalln "ERROR !!!! Unable to create config tx"
|
|
fi
|
|
|
|
infoln "Joining Org3 peers to network"
|
|
docker exec cli ./scripts/org3-scripts/joinChannel.sh $CHANNEL_NAME $CLI_DELAY $CLI_TIMEOUT $VERBOSE
|
|
if [ $? -ne 0 ]; then
|
|
fatalln "ERROR !!!! Unable to join Org3 peers to network"
|
|
fi
|
|
}
|
|
|
|
# Tear down running network
|
|
function networkDown () {
|
|
cd ..
|
|
./network.sh down
|
|
}
|
|
|
|
|
|
# Obtain the OS and Architecture string that will be used to select the correct
|
|
# native binaries for your platform
|
|
OS_ARCH=$(echo "$(uname -s|tr '[:upper:]' '[:lower:]'|sed 's/mingw64_nt.*/windows/')-$(uname -m | sed 's/x86_64/amd64/g')" | awk '{print tolower($0)}')
|
|
# timeout duration - the duration the CLI should wait for a response from
|
|
# another container before giving up
|
|
|
|
# Using crpto vs CA. default is cryptogen
|
|
CRYPTO="cryptogen"
|
|
|
|
CLI_TIMEOUT=10
|
|
#default for delay
|
|
CLI_DELAY=3
|
|
# channel name defaults to "mychannel"
|
|
CHANNEL_NAME="mychannel"
|
|
# use this as the docker compose couch file
|
|
COMPOSE_FILE_COUCH_ORG3=docker/docker-compose-couch-org3.yaml
|
|
# use this as the default docker-compose yaml definition
|
|
COMPOSE_FILE_ORG3=docker/docker-compose-org3.yaml
|
|
# certificate authorities compose file
|
|
COMPOSE_FILE_CA_ORG3=docker/docker-compose-ca-org3.yaml
|
|
# default image tag
|
|
IMAGETAG="latest"
|
|
# default ca image tag
|
|
CA_IMAGETAG="latest"
|
|
# database
|
|
DATABASE="leveldb"
|
|
|
|
# Parse commandline args
|
|
|
|
## Parse mode
|
|
if [[ $# -lt 1 ]] ; then
|
|
printHelp
|
|
exit 0
|
|
else
|
|
MODE=$1
|
|
shift
|
|
fi
|
|
|
|
# parse flags
|
|
|
|
while [[ $# -ge 1 ]] ; do
|
|
key="$1"
|
|
case $key in
|
|
-h )
|
|
printHelp
|
|
exit 0
|
|
;;
|
|
-c )
|
|
CHANNEL_NAME="$2"
|
|
shift
|
|
;;
|
|
-ca )
|
|
CRYPTO="Certificate Authorities"
|
|
;;
|
|
-t )
|
|
CLI_TIMEOUT="$2"
|
|
shift
|
|
;;
|
|
-d )
|
|
CLI_DELAY="$2"
|
|
shift
|
|
;;
|
|
-s )
|
|
DATABASE="$2"
|
|
shift
|
|
;;
|
|
-i )
|
|
IMAGETAG=$(go env GOARCH)"-""$2"
|
|
shift
|
|
;;
|
|
-cai )
|
|
CA_IMAGETAG="$2"
|
|
shift
|
|
;;
|
|
-verbose )
|
|
VERBOSE=true
|
|
shift
|
|
;;
|
|
* )
|
|
errorln "Unknown flag: $key"
|
|
printHelp
|
|
exit 1
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
|
|
# Determine whether starting, stopping, restarting or generating for announce
|
|
if [ "$MODE" == "up" ]; then
|
|
infoln "Adding org3 to channel '${CHANNEL_NAME}' with '${CLI_TIMEOUT}' seconds and CLI delay of '${CLI_DELAY}' seconds and using database '${DATABASE}'"
|
|
echo
|
|
elif [ "$MODE" == "down" ]; then
|
|
EXPMODE="Stopping network"
|
|
elif [ "$MODE" == "generate" ]; then
|
|
EXPMODE="Generating certs and organization definition for Org3"
|
|
else
|
|
printHelp
|
|
exit 1
|
|
fi
|
|
|
|
#Create the network using docker compose
|
|
if [ "${MODE}" == "up" ]; then
|
|
addOrg3
|
|
elif [ "${MODE}" == "down" ]; then ## Clear the network
|
|
networkDown
|
|
elif [ "${MODE}" == "generate" ]; then ## Generate Artifacts
|
|
generateOrg3
|
|
generateOrg3Definition
|
|
else
|
|
printHelp
|
|
exit 1
|
|
fi
|