mirror of
				https://github.com/xcat2/confluent.git
				synced 2025-10-25 16:35:35 +00:00 
			
		
		
		
	Add nodepower arguments for PDU operations
This commit is contained in:
		| @@ -33,7 +33,7 @@ import confluent.client as client | ||||
|  | ||||
| argparser = optparse.OptionParser( | ||||
|     usage="Usage: %prog [options] <noderange> " | ||||
|           "([status|on|off|shutdown|boot|reset])") | ||||
|           "([status|on|off|shutdown|boot|reset|pdu_status|pdu_off|pdu_on])") | ||||
| argparser.add_option('-p', '--showprevious', dest='previous', | ||||
|                      action='store_true', default=False, | ||||
|                      help='Show previous power state') | ||||
| @@ -53,20 +53,24 @@ setstate = None | ||||
| if len(args) > 1: | ||||
|     if setstate == 'softoff': | ||||
|         setstate = 'shutdown' | ||||
|     elif not args[1] in ('stat', 'state', 'status'): | ||||
|         setstate = args[1] | ||||
|  | ||||
| if setstate not in (None, 'on', 'off', 'shutdown', 'boot', 'reset'): | ||||
| if setstate not in (None, 'on', 'off', 'shutdown', 'boot', 'reset', 'pdu_status', 'pdu_stat', 'pdu_on', 'pdu_off'): | ||||
|     argparser.print_help() | ||||
|     sys.exit(1) | ||||
| session = client.Command() | ||||
| exitcode = 0 | ||||
| session.add_precede_key('oldstate') | ||||
| powurl = 'state' | ||||
| if setstate and setstate.startswith('pdu_'): | ||||
|     setstate = setstate.replace('pdu_', '') | ||||
|     powurl = 'inlets/all' | ||||
| if setstate in ('status', 'state', 'stat'): | ||||
|     setstate = None | ||||
|  | ||||
| if options.previous: | ||||
|     # get previous states | ||||
|     prev = {} | ||||
|     for rsp in session.read("/noderange/{0}/power/state".format(noderange)): | ||||
|     for rsp in session.read("/noderange/{0}/power/{1}".format(noderange, powurl)): | ||||
|         # gets previous (current) states | ||||
|  | ||||
|         databynode = rsp["databynode"] | ||||
| @@ -77,4 +81,4 @@ if options.previous: | ||||
|     # add dictionary to session | ||||
|     session.add_precede_dict(prev) | ||||
|  | ||||
| sys.exit(session.simple_noderange_command(noderange, '/power/state', setstate, promptover=options.maxnodes)) | ||||
| sys.exit(session.simple_noderange_command(noderange, '/power/{0}'.format(powurl), setstate, promptover=options.maxnodes, key='state')) | ||||
|   | ||||
| @@ -245,6 +245,9 @@ class Command(object): | ||||
|                         node, val, self._prevdict[node])) | ||||
|                 else: | ||||
|                     cprint('{0}: {1}'.format(node, val)) | ||||
|             elif ikey == 'state': | ||||
|                 for k in res[node]: | ||||
|                     cprint('{0}: {1}: {2}'.format(node, k, res[node][k])) | ||||
|         return rc | ||||
|  | ||||
|     def simple_noderange_command(self, noderange, resource, input=None, | ||||
|   | ||||
| @@ -24,6 +24,9 @@ respond. | ||||
| * `reset`:  Request immediate reset of nodes of the noderange.  Nodes that are | ||||
| off will not react to this request. | ||||
| * `status`:  Behave identically to having no argument passed at all. | ||||
| * `pdu_status`: Query state of associated PDU outlets, if configured. | ||||
| * `pdu_on`: Energize all PDU outlets associated with the noderange. | ||||
| * `pdu_off`: De-energize all PDU outlets associated with the noderange. | ||||
|  | ||||
| ## OPTIONS | ||||
|  | ||||
|   | ||||
| @@ -85,7 +85,7 @@ class GeistClient(object): | ||||
|             raise Exception('Multiple PDUs not supported per pdu') | ||||
|         pduname = list(rsp)[0] | ||||
|         outlet = rsp[pduname]['outlet'][str(int(outlet) - 1)] | ||||
|         state = outlet['state'] | ||||
|         state = outlet['state'].split('2')[-1] | ||||
|         return state | ||||
|  | ||||
|     def set_outlet(self, outlet, state): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user