2
0
mirror of https://github.com/xcat2/confluent.git synced 2025-01-17 21:23:18 +00:00

Update IPMI user management to enable partial update.

Improvements in InputCredential fields validation.
Check for all fields in InputCredential when operation = 'create'.
This commit is contained in:
Juliana Motira 2015-07-28 14:08:59 -03:00
parent 5f1ddc7f84
commit 3f1d49c30b
2 changed files with 33 additions and 14 deletions

View File

@ -429,18 +429,27 @@ class InputCredential(ConfluentMessage):
if len(path) == 4:
inputdata['uid'] = path[-1]
# if the operation is 'create' check if all fields are present
elif ('uid' not in inputdata or 'privilege_level' not in inputdata or
'username' not in inputdata or 'password' not in inputdata):
raise exc.InvalidArgumentException('all fields are required')
if ('uid' not in inputdata or 'privilege_level' not in inputdata
or 'username' not in inputdata or 'password' not in inputdata):
raise exc.InvalidArgumentException('missing arguments')
if not inputdata['uid'].isdigit():
if 'uid' not in inputdata:
raise exc.InvalidArgumentException('uid is missing')
if (isinstance(inputdata['uid'], str) and
not inputdata['uid'].isdigit()):
raise exc.InvalidArgumentException('uid must be a number')
else:
inputdata['uid'] = int(inputdata['uid'])
if inputdata['privilege_level'] not in self.valid_privilege_levels:
if ('privilege_level' in inputdata and
inputdata['privilege_level'] not in self.valid_privilege_levels):
raise exc.InvalidArgumentException('privilege_level is not one of '
+ ','.join(self.valid_privilege_levels))
if 'username' in inputdata and len(inputdata['username']) > 16:
raise exc.InvalidArgumentException(
'name must be less than or = 16 chars')
if 'password' in inputdata and len(inputdata['password']) > 20:
raise exc.InvalidArgumentException('password has limit of 20 chars')
if nodes is None:
raise exc.InvalidArgumentException(

View File

@ -427,21 +427,23 @@ class IpmiHandler(object):
raise Exception('Not implemented')
def handle_users(self):
# Create user
if len(self.element) == 3:
if self.op == 'update':
user = self.inputdata.credentials[self.node]
self.ipmicmd.create_user(uid=user['uid'], name=user['username'],
password=user['password'], channel=1,
password=user['password'],
callback=True,link_auth=True, ipmi_msg=True,
privilege_level=user['privilege_level'])
# A list of users
for user in self.ipmicmd.get_users(channel=1):
for user in self.ipmicmd.get_users():
self.output.put(msg.ChildCollection(user, candelete=True))
return
# Update user
elif len(self.element) == 4:
user = int(self.element[-1])
if self.op == 'read':
data = self.ipmicmd.get_user(uid=user, channel=1)
data = self.ipmicmd.get_user(uid=user)
self.output.put(msg.User(
uid=data['uid'],
username=data['name'],
@ -450,13 +452,21 @@ class IpmiHandler(object):
return
elif self.op == 'update':
user = self.inputdata.credentials[self.node]
self.ipmicmd.create_user(uid=user['uid'], name=user['username'],
password=user['password'], channel=1,
callback=True,link_auth=True, ipmi_msg=True,
privilege_level=user['privilege_level'])
if 'username' in user:
self.ipmicmd.set_user_name(uid=user['uid'],
name=user['username'])
if 'privilege_level' in user:
self.ipmicmd.set_user_access(uid=user['uid'],
privilege_level=user['privilege_level'])
if 'password' in user:
self.ipmicmd.set_user_password(uid=user['uid'],
password=user['password'])
self.ipmicmd.set_user_password(uid=user['uid'],
mode='enable', password=user['password'])
return
elif self.op == 'delete':
self.ipmicmd.user_delete(uid=user, channel=1)
self.ipmicmd.user_delete(uid=user)
return
def do_eventlog(self):