2019-01-14 21:06:13 +00:00
|
|
|
#!/usr/bin/python
|
|
|
|
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
|
|
|
|
|
|
# Copyright 2019 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
|
|
|
|
import time
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
exitcode = 0
|
|
|
|
|
|
|
|
argparser = optparse.OptionParser(
|
|
|
|
usage="Usage: "
|
2019-06-19 20:35:24 +00:00
|
|
|
"%prog <noderange> [list][install <file>|save <directory>|delete <name>]")
|
2019-01-14 21:06:13 +00:00
|
|
|
(options, args) = argparser.parse_args()
|
|
|
|
upfile = None
|
2019-06-19 19:43:45 +00:00
|
|
|
downdir = None
|
2019-06-19 20:35:24 +00:00
|
|
|
delete = False
|
2019-01-14 21:06:13 +00:00
|
|
|
try:
|
|
|
|
noderange = args[0]
|
|
|
|
if len(args) > 1:
|
|
|
|
if args[1] == 'install':
|
|
|
|
upfile = args[2]
|
2019-06-19 19:43:45 +00:00
|
|
|
elif args[1] == 'save':
|
|
|
|
downdir = args[2]
|
2019-06-19 20:35:24 +00:00
|
|
|
elif args[1] == 'delete':
|
|
|
|
delete = args[2]
|
2019-01-14 21:06:13 +00:00
|
|
|
else:
|
|
|
|
components = ['all']
|
|
|
|
except IndexError:
|
|
|
|
argparser.print_help()
|
|
|
|
sys.exit(1)
|
|
|
|
client.check_globbing(noderange)
|
|
|
|
|
2019-06-19 19:43:45 +00:00
|
|
|
|
2019-01-14 21:06:13 +00:00
|
|
|
def install_license(session, filename):
|
|
|
|
global exitcode
|
2019-06-26 17:24:24 +00:00
|
|
|
if not os.path.exists(filename):
|
|
|
|
sys.stderr.write('Unable to locate requested file {0}\n'.format(
|
|
|
|
filename))
|
|
|
|
sys.exit(404)
|
2019-01-14 21:06:13 +00:00
|
|
|
resource = '/noderange/{0}/configuration/' \
|
|
|
|
'management_controller/licenses/'.format(noderange)
|
|
|
|
filename = os.path.abspath(filename)
|
|
|
|
instargs = {'filename': filename}
|
|
|
|
for res in session.create(resource, instargs):
|
|
|
|
pass # print(repr(res))
|
2019-06-12 18:47:28 +00:00
|
|
|
show_licenses(session)
|
2019-01-14 21:06:13 +00:00
|
|
|
|
2019-06-19 19:43:45 +00:00
|
|
|
|
|
|
|
def save_licenses(session, dirname):
|
|
|
|
global exitcode
|
|
|
|
resource = '/noderange/{0}/configuration/' \
|
|
|
|
'management_controller/save_licenses'.format(noderange)
|
|
|
|
filename = os.path.abspath(dirname)
|
2019-06-26 17:24:24 +00:00
|
|
|
if not os.path.exists(filename):
|
|
|
|
sys.stderr.write('Unable to locate specified directory {0}\n'.format(
|
|
|
|
filename))
|
|
|
|
sys.exit(404)
|
2019-06-19 19:43:45 +00:00
|
|
|
instargs = {'dirname': filename}
|
|
|
|
for res in session.create(resource, instargs):
|
|
|
|
for node in res.get('databynode', {}):
|
|
|
|
fname = res['databynode'][node].get('filename', None)
|
|
|
|
if fname:
|
|
|
|
print('{0}: Saved license to {1}'.format(node, fname))
|
|
|
|
else:
|
|
|
|
sys.stderr.write('{0}: {1}', node, repr(res['databynode'][node]))
|
|
|
|
|
|
|
|
|
2019-01-14 21:06:13 +00:00
|
|
|
def show_licenses(session):
|
|
|
|
global exitcode
|
|
|
|
for res in session.read(
|
|
|
|
'/noderange/{0}/configuration/management_controller/licenses/'
|
|
|
|
'all'.format(noderange)):
|
|
|
|
for node in res.get('databynode', {}):
|
|
|
|
for license in res['databynode'][node].get('License', []):
|
2019-06-21 14:17:52 +00:00
|
|
|
msg = '{0}: {1}'.format(node, license.get('feature',
|
|
|
|
'Unknown'))
|
|
|
|
if license.get('state', 'Active') != 'Active':
|
|
|
|
msg += ' ({0})'.format(license['state'])
|
|
|
|
print(msg)
|
2019-01-14 21:06:13 +00:00
|
|
|
|
|
|
|
|
2019-06-19 20:35:24 +00:00
|
|
|
def delete_license(session, licname):
|
|
|
|
global exitcode
|
|
|
|
licstodel = []
|
|
|
|
for res in list(session.read(
|
|
|
|
'/noderange/{0}/configuration/management_controller/licenses/'
|
|
|
|
'all'.format(noderange))):
|
|
|
|
for node in res.get('databynode', {}):
|
|
|
|
for license in res['databynode'][node].get('License', []):
|
|
|
|
if license.get('feature', None) == licname:
|
|
|
|
prefix = '/nodes/{0}/configuration/management_controller/licenses/'.format(node)
|
|
|
|
for currlic in list(session.read(prefix)):
|
|
|
|
currlic = currlic.get('item', {}).get('href', 'all')
|
|
|
|
if currlic == 'all':
|
|
|
|
continue
|
|
|
|
currname = list(session.read(prefix + currlic))[0]
|
|
|
|
currname = currname.get('License', [{}])[0].get('feature', None)
|
|
|
|
if currname == licname:
|
|
|
|
list(session.delete(prefix + currlic))
|
|
|
|
show_licenses(session)
|
|
|
|
|
2019-01-14 21:06:13 +00:00
|
|
|
try:
|
|
|
|
session = client.Command()
|
2019-06-19 19:43:45 +00:00
|
|
|
if upfile:
|
2019-01-14 21:06:13 +00:00
|
|
|
install_license(session, upfile)
|
2019-06-19 19:43:45 +00:00
|
|
|
elif downdir:
|
|
|
|
save_licenses(session, downdir)
|
2019-06-19 20:35:24 +00:00
|
|
|
elif delete:
|
|
|
|
delete_license(session, delete)
|
2019-06-19 19:43:45 +00:00
|
|
|
else:
|
|
|
|
show_licenses(session)
|
2019-01-14 21:06:13 +00:00
|
|
|
except KeyboardInterrupt:
|
|
|
|
print('')
|
2019-06-26 17:24:24 +00:00
|
|
|
sys.exit(exitcode)
|