mirror of
https://github.com/hyperledger/fabric-samples.git
synced 2026-06-17 15:35:09 +00:00
* Decouple fabric tools image from fabric sample * update with review comments Signed-off-by: Sam Yuan <yy19902439@126.com>
68 lines
2.7 KiB
Bash
Executable file
68 lines
2.7 KiB
Bash
Executable file
#!/bin/bash
|
|
#
|
|
# Copyright IBM Corp. All Rights Reserved.
|
|
#
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
#
|
|
|
|
# import utils
|
|
# test network home var targets to test network folder
|
|
# the reason we use a var here is considering with org3 specific folder
|
|
# when invoking this for org3 as test-network/scripts/org3-scripts
|
|
# the value is changed from default as $PWD(test-network)
|
|
# to .. as relative path to make the import works
|
|
test_network_home=${test_network_home:-${PWD}}
|
|
. ${test_network_home}/scripts/envVar.sh
|
|
|
|
# fetchChannelConfig <org> <channel_id> <output_json>
|
|
# Writes the current channel config for a given channel to a JSON file
|
|
# NOTE: this must be run in a CLI container since it requires configtxlator
|
|
fetchChannelConfig() {
|
|
ORG=$1
|
|
CHANNEL=$2
|
|
OUTPUT=$3
|
|
|
|
setGlobals $ORG
|
|
|
|
infoln "Fetching the most recent configuration block for the channel"
|
|
set -x
|
|
peer channel fetch config config_block.pb -o localhost:7050 --ordererTLSHostnameOverride orderer.example.com -c $CHANNEL --tls --cafile "$ORDERER_CA"
|
|
{ set +x; } 2>/dev/null
|
|
|
|
infoln "Decoding config block to JSON and isolating config to ${OUTPUT}"
|
|
set -x
|
|
configtxlator proto_decode --input config_block.pb --type common.Block --output config_block.json
|
|
jq .data.data[0].payload.data.config config_block.json >"${OUTPUT}"
|
|
{ set +x; } 2>/dev/null
|
|
}
|
|
|
|
# createConfigUpdate <channel_id> <original_config.json> <modified_config.json> <output.pb>
|
|
# Takes an original and modified config, and produces the config update tx
|
|
# which transitions between the two
|
|
# NOTE: this must be run in a CLI container since it requires configtxlator
|
|
createConfigUpdate() {
|
|
CHANNEL=$1
|
|
ORIGINAL=$2
|
|
MODIFIED=$3
|
|
OUTPUT=$4
|
|
|
|
set -x
|
|
configtxlator proto_encode --input "${ORIGINAL}" --type common.Config --output original_config.pb
|
|
configtxlator proto_encode --input "${MODIFIED}" --type common.Config --output modified_config.pb
|
|
configtxlator compute_update --channel_id "${CHANNEL}" --original original_config.pb --updated modified_config.pb --output config_update.pb
|
|
configtxlator proto_decode --input config_update.pb --type common.ConfigUpdate --output config_update.json
|
|
echo '{"payload":{"header":{"channel_header":{"channel_id":"'$CHANNEL'", "type":2}},"data":{"config_update":'$(cat config_update.json)'}}}' | jq . >config_update_in_envelope.json
|
|
configtxlator proto_encode --input config_update_in_envelope.json --type common.Envelope --output "${OUTPUT}"
|
|
{ set +x; } 2>/dev/null
|
|
}
|
|
|
|
# signConfigtxAsPeerOrg <org> <configtx.pb>
|
|
# Set the peerOrg admin of an org and sign the config update
|
|
signConfigtxAsPeerOrg() {
|
|
ORG=$1
|
|
CONFIGTXFILE=$2
|
|
setGlobals $ORG
|
|
set -x
|
|
peer channel signconfigtx -f "${CONFIGTXFILE}"
|
|
{ set +x; } 2>/dev/null
|
|
}
|