From 9883fa765a2642f6348f8f24f8a2f8ce9c0e22d1 Mon Sep 17 00:00:00 2001 From: Lenin Mehedy Date: Sat, 11 Nov 2023 07:35:21 +1100 Subject: [PATCH] feat: implement node start and stop commands (#520) Signed-off-by: Lenin Mehedy --- .../src/commands/cluster.mjs | 2 +- .../src/commands/node.mjs | 40 ++++++++++++++++++- 2 files changed, 40 insertions(+), 2 deletions(-) diff --git a/fullstack-network-manager/src/commands/cluster.mjs b/fullstack-network-manager/src/commands/cluster.mjs index 0082e8e81..822c099d5 100644 --- a/fullstack-network-manager/src/commands/cluster.mjs +++ b/fullstack-network-manager/src/commands/cluster.mjs @@ -285,7 +285,7 @@ export class ClusterCommand extends BaseCommand { desc: 'Setup cluster with shared components', builder: yargs => { yargs.option('cluster-name', flags.clusterNameFlag) - yargs.option('namespace', flags.defaultNamespaceFlag) + yargs.option('namespace', flags.namespaceFlag) yargs.option('prometheus-stack', flags.deployPrometheusStack) yargs.option('minio', flags.deployMinio) yargs.option('envoy-gateway', flags.deployEnvoyGateway) diff --git a/fullstack-network-manager/src/commands/node.mjs b/fullstack-network-manager/src/commands/node.mjs index fc12ef1fc..fbda403fe 100644 --- a/fullstack-network-manager/src/commands/node.mjs +++ b/fullstack-network-manager/src/commands/node.mjs @@ -57,7 +57,7 @@ export class NodeCommand extends BaseCommand { '--no-headers', `-o custom-columns=":metadata.name"`, `-n "${namespace}"` - ) + ) output.forEach(podName => { nodeIds.push(Templates.extractNodeIdFromPodName(podName)) podNames.push(podName) @@ -110,6 +110,8 @@ export class NodeCommand extends BaseCommand { for (const podName of podNames) { await self.plaformInstaller.install(podName, buildZipFile, stagingDir, force); } + + return true } catch (e) { self.logger.showUserError(e) } @@ -118,11 +120,45 @@ export class NodeCommand extends BaseCommand { } async start(argv) { + const self = this + + try { + const namespace = argv.namespace + const nodeIDsArg = argv.nodeIds ? argv.nodeIds.split(',') : [] + let {podNames, nodeIDs} = await this.checkNetworkNodePods(namespace, nodeIDsArg) + for (const podName of podNames) { + self.logger.showUser(chalk.cyan('>>'), `Starting node ${podName}`) + await self.kubectl.execContainer(podName, constants.ROOT_CONTAINER, 'systemctl restart network-node') + self.logger.showUser(chalk.green('OK'), `Started node ${podName}`) + } + return true + } catch (e) { + self.logger.showUserError(e) + } + + return false } async stop(argv) { + const self = this + + try { + const namespace = argv.namespace + const nodeIDsArg = argv.nodeIds ? argv.nodeIds.split(',') : [] + let {podNames, nodeIDs} = await this.checkNetworkNodePods(namespace, nodeIDsArg) + for (const podName of podNames) { + self.logger.showUser(chalk.cyan('>>'), `Stopping node ${podName}`) + await self.kubectl.execContainer(podName, constants.ROOT_CONTAINER, 'systemctl restart network-node') + self.logger.showUser(chalk.green('OK'), `Stopped node ${podName}`) + } + return true + } catch (e) { + self.logger.showUserError(e) + } + + return false } /** @@ -161,6 +197,7 @@ export class NodeCommand extends BaseCommand { command: 'start', desc: 'Start a node running Hedera platform', builder: yargs => { + yargs.option('namespace', flags.namespaceFlag) yargs.option('node-ids', flags.nodeIDs) }, handler: argv => { @@ -181,6 +218,7 @@ export class NodeCommand extends BaseCommand { command: 'stop', desc: 'stop a node running Hedera platform', builder: yargs => { + yargs.option('namespace', flags.namespaceFlag) yargs.option('node-ids', flags.nodeIDs) }, handler: argv => {