From 1d0b78267d8f8cf6a0649f5b7270c330d67c5ea5 Mon Sep 17 00:00:00 2001 From: Amanda Duffy Date: Tue, 25 Jul 2017 17:10:52 -0400 Subject: [PATCH 1/2] Add nodebmcreset command and man page --- confluent_client/bin/nodebmcreset | 62 ++++++++++++++++++++++ confluent_client/doc/man/nodebmcreset.ronn | 19 +++++++ 2 files changed, 81 insertions(+) create mode 100644 confluent_client/bin/nodebmcreset create mode 100644 confluent_client/doc/man/nodebmcreset.ronn diff --git a/confluent_client/bin/nodebmcreset b/confluent_client/bin/nodebmcreset new file mode 100644 index 00000000..0dea0ce3 --- /dev/null +++ b/confluent_client/bin/nodebmcreset @@ -0,0 +1,62 @@ +#!/usr/bin/env python +# vim: tabstop=4 shiftwidth=4 softtabstop=4 + +# Copyright 2015-2017 Lenovo +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import optparse +import os +import signal +import sys +try: + signal.signal(signal.SIGPIPE, signal.SIG_DFL) +except AttributeError: + pass + +path = os.path.dirname(os.path.realpath(__file__)) +path = os.path.realpath(os.path.join(path, '..', 'lib', 'python')) +if path.startswith('/opt'): + sys.path.append(path) + +import confluent.client as client + +argparser = optparse.OptionParser(usage="Usage: %prog ") +(options, args) = argparser.parse_args() +try: + noderange = args[0] +except IndexError: + argparser.print_help() + sys.exit(1) + +session = client.Command() +exitcode = 0 + +errorNodes = set([]) + +success = session.simple_noderange_command(noderange, 'configuration/management_controller/reset', 'reset', key='state', errnodes=errorNodes) # = 0 if successful + +# Determine which nodes were successful and print them + +allNodes = set([]) + +for node in session.read('/noderange/{0}/nodes/'.format(noderange)): + allNodes.add(node['item']['href'].replace("/", "")) + +goodNodes = allNodes - errorNodes + +for node in goodNodes: + print node + ": BMC Reset Successful" + + +sys.exit() diff --git a/confluent_client/doc/man/nodebmcreset.ronn b/confluent_client/doc/man/nodebmcreset.ronn new file mode 100644 index 00000000..d2fc608a --- /dev/null +++ b/confluent_client/doc/man/nodebmcreset.ronn @@ -0,0 +1,19 @@ +nodebmcreset(8) -- Reset management controller +========================================================= + +## SYNOPSIS + +`nodebmcreset ` + +## DESCRIPTION + +`nodebmcreset` allows you to reset the management controller of the specified noderange + +## EXAMPLES: + +* Reset the management controller for nodes n1 through n4: + `# nodebmcreset n1-n4` + `n1: BMC Reset Successful` + `n2: BMC Reset Successful` + `n3: BMC Reset Successful` + `n4: BMC Reset Successful` \ No newline at end of file From 3e90dd64620b965041226a8f4978ed3096c445c9 Mon Sep 17 00:00:00 2001 From: Amanda Duffy Date: Thu, 27 Jul 2017 14:31:37 -0400 Subject: [PATCH 2/2] Pass sys.exit() an argument Change sys.exit() to sys.exit(success) --- confluent_client/bin/nodebmcreset | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/confluent_client/bin/nodebmcreset b/confluent_client/bin/nodebmcreset index 0dea0ce3..8d983d3a 100644 --- a/confluent_client/bin/nodebmcreset +++ b/confluent_client/bin/nodebmcreset @@ -59,4 +59,4 @@ for node in goodNodes: print node + ": BMC Reset Successful" -sys.exit() +sys.exit(success)