Skip to content

Commit

Permalink
upgrade peer fetch func to HLF V2.5.10
Browse files Browse the repository at this point in the history
Signed-off-by: YoungHypo <haiboyang@smail.nju.edu.cn>
  • Loading branch information
YoungHypo committed Oct 25, 2024
1 parent b7ef2df commit c0faf77
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 20 deletions.
33 changes: 19 additions & 14 deletions src/api-engine/api/lib/peer/channel.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,20 +18,20 @@ def __init__(self, version=FABRIC_VERSION, peer=FABRIC_TOOL, **kwargs):
self.osnadmin = peer + "/osnadmin"
super(Channel, self).__init__(version, **kwargs)

def create(self, channel, orderer_url, block_path, time_out="90s"):
def create(self, channel, orderer_admin_url, block_path, time_out="90s"):
try:
res = 0x100
command = ""

if os.getenv("CORE_PEER_TLS_ENABLED") == "false" or os.getenv("CORE_PEER_TLS_ENABLED") is None:
command = "{} channel join --channelID {} --config-block {} -o {}".format(self.osnadmin, channel, block_path, orderer_url)
command = "{} channel join --channelID {} --config-block {} -o {}".format(self.osnadmin, channel, block_path, orderer_admin_url)
else:
ORDERER_CA = os.getenv("ORDERER_CA")
ORDERER_ADMIN_TLS_SIGN_CERT = os.getenv("ORDERER_ADMIN_TLS_SIGN_CERT")
ORDERER_ADMIN_TLS_PRIVATE_KEY = os.getenv("ORDERER_ADMIN_TLS_PRIVATE_KEY")
command = "{} channel join --channelID {} --config-block {} -o {} --ca-file {} --client-cert {} --client-key {}".format(self.osnadmin, channel, block_path, orderer_url, ORDERER_CA, ORDERER_ADMIN_TLS_SIGN_CERT, ORDERER_ADMIN_TLS_PRIVATE_KEY)
command = "{} channel join --channelID {} --config-block {} -o {} --ca-file {} --client-cert {} --client-key {}".format(self.osnadmin, channel, block_path, orderer_admin_url, ORDERER_CA, ORDERER_ADMIN_TLS_SIGN_CERT, ORDERER_ADMIN_TLS_PRIVATE_KEY)

LOG.info(f"Running command: {command}")
LOG.info(f"{command}")
res = os.system(command)

# The return value of os.system is not the result of executing the program. It is a 16 bit number,
Expand Down Expand Up @@ -78,22 +78,27 @@ def update(self, channel, channel_tx, orderer_url):
res = res >> 8
return res

def fetch(self, option, channel):
def fetch(self, block_path, channel, orderer_general_url):
"""
Fetch a specified block, writing it to a file e.g. <channelID>.block.
params:
option: block option newest|oldest|config|(block number).
channel: channel id.
"""
try:
res = subprocess.call(args=[
self.peer,
"channel",
"fetch",
"{}".format(option),
"-c",
channel
])
res = 0x100
command = ""
if os.getenv("CORE_PEER_TLS_ENABLED") == "false" or os.getenv("CORE_PEER_TLS_ENABLED") is None:
command = "{} channel fetch config {} -o {} -c {}".format(self.peer, block_path, orderer_general_url, channel)
else:
ORDERER_CA = os.getenv("ORDERER_CA")
orderer_address = orderer_general_url.split(":")[0]
command = "{} channel fetch config {} -o {} --ordererTLSHostnameOverride {} -c {} --tls --cafile {}".format(self.peer, block_path, orderer_general_url, orderer_address, channel, ORDERER_CA)

LOG.info(f"{command}")
res = os.system(command)

res = res >> 8
except Exception as e:
err_msg = "fetch a specified block failed {}!".format(e)
raise Exception(err_msg)
Expand Down Expand Up @@ -123,7 +128,7 @@ def join(self, block_path):
try:
command = "{} channel join -b {} ".format(self.peer, block_path)

LOG.info(f"Running command: {command}")
LOG.info(f"{command}")

res = os.system(command)

Expand Down
24 changes: 18 additions & 6 deletions src/api-engine/api/routes/channel/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -150,21 +150,32 @@ def create(self, request):
ConfigTX(org.network.name).create(name, org.network.consensus, _orderers, _peers)
ConfigTxGen(org.network.name).genesis(profile=name, channelid=name, outputblock="{}.block".format(name))

block_path = "{}/{}/{}.block".format(
CELLO_HOME, org.network.name, name)
# osnadmin channel join
ordering_node = Node.objects.get(id=orderers[0])
envs = init_env_vars(ordering_node, org)
peer_channel_cli = PeerChannel(**envs)
peer_channel_cli.create(
channel=name,
orderer_url="{}.{}:{}".format(
orderer_admin_url="{}.{}:{}".format(
ordering_node.name, org.name.split(".", 1)[1], str(7053)),
block_path=block_path
block_path="{}/{}/{}.block".format(
CELLO_HOME, org.network.name, name)
)

# peer channel join
for i in range(len(peers)):
peer_node = Node.objects.get(id=peers[i])
envs = init_env_vars(peer_node, org)
join_peers(envs, block_path)
join_peers(envs, "{}/{}/{}.block".format(
CELLO_HOME, org.network.name, name))

# peer channel fetch
peer_node = Node.objects.get(id=peers[0])
envs = init_env_vars(peer_node, org)
peer_channel_cli = PeerChannel(**envs)
peer_channel_cli.fetch(block_path="{}/{}/config_block.pb".format(CELLO_HOME, org.network.name),
channel=name, orderer_general_url="{}.{}:{}".format(
ordering_node.name, org.name.split(".", 1)[1], str(7050)))

channel = Channel(
name=name,
Expand Down Expand Up @@ -395,7 +406,8 @@ def init_env_vars(node, org):

if(node.type == "orderer"):
envs = {
"ORDERER_CA": "{}/msp/tlscacerts/tlsca.{}-cert.pem".format(dir_certificate, org_domain),
"CORE_PEER_TLS_ENABLED": "true",
"ORDERER_CA": "{}/orderers/{}/msp/tlscacerts/tlsca.{}-cert.pem".format(dir_certificate, node.name + "." + org_domain, org_domain),
"ORDERER_ADMIN_TLS_SIGN_CERT": "{}/orderers/{}/tls/server.crt".format(dir_certificate, node.name + "." + org_domain),
"ORDERER_ADMIN_TLS_PRIVATE_KEY": "{}/orderers/{}/tls/server.key".format(dir_certificate, node.name + "." + org_domain)
}
Expand Down

0 comments on commit c0faf77

Please sign in to comment.