From 4fcc75899ef9f05b9c8030fcf11fc701ff7698b7 Mon Sep 17 00:00:00 2001 From: Jarrod Johnson Date: Tue, 15 Nov 2016 10:45:26 -0500 Subject: [PATCH] Consolidate IMM date string parsing Various strings/date formats may be used in different places, and in fact the same place. Use a consolidated catch-all parser to convert the strings to a datetime. Change-Id: Ie84229056ba55806bce1527ea263a80c29ff7048 --- pyghmi/ipmi/oem/lenovo/handler.py | 3 ++- pyghmi/ipmi/oem/lenovo/imm.py | 38 +++++++++++++++++++++++-------- 2 files changed, 31 insertions(+), 10 deletions(-) diff --git a/pyghmi/ipmi/oem/lenovo/handler.py b/pyghmi/ipmi/oem/lenovo/handler.py index d1edf439..1d97221c 100755 --- a/pyghmi/ipmi/oem/lenovo/handler.py +++ b/pyghmi/ipmi/oem/lenovo/handler.py @@ -493,7 +493,8 @@ class OEMHandler(generic.OEMHandler): if len(bdata['data'][:]) != 3: self._hasimm = False return False - self._hasimm = ord(bdata['data'][1]) & 1 == 1 + rdata = bytearray(bdata['data'][:]) + self._hasimm = (rdata[1] & 1 == 1) or (rdata[1] & 16 == 16) return self._hasimm def get_oem_firmware(self, bmcver): diff --git a/pyghmi/ipmi/oem/lenovo/imm.py b/pyghmi/ipmi/oem/lenovo/imm.py index 0ace1ba2..8600db21 100644 --- a/pyghmi/ipmi/oem/lenovo/imm.py +++ b/pyghmi/ipmi/oem/lenovo/imm.py @@ -21,6 +21,30 @@ import pyghmi.util.webclient as webclient import urllib +def _parse_builddate(strval): + try: + return datetime.strptime(strval, '%Y/%m/%d %H:%M:%S') + except ValueError: + pass + try: + return datetime.strptime(strval, '%Y-%m-%d %H:%M:%S') + except ValueError: + pass + try: + return datetime.strptime(strval, '%Y/%m/%d') + except ValueError: + pass + try: + return datetime.strptime(strval, '%m/%d/%Y') + except ValueError: + pass + try: + return datetime.strptime(strval, '%m %d %Y') + except ValueError: + pass + return None + + def get_imm_property(ipmicmd, propname): propname = propname.encode('utf-8') proplen = len(propname) | 0b10000000 @@ -63,14 +87,14 @@ def get_imm_webclient(imm, certverify, uid, password): def parse_imm_buildinfo(buildinfo): buildid = buildinfo[:9].rstrip(' \x00') bdt = ' '.join(buildinfo[9:].replace('\x00', ' ').split()) - bdate = datetime.strptime(bdt, '%Y/%m/%d %H:%M:%S') + bdate = _parse_builddate(bdt) return (buildid, bdate) def datefromprop(propstr): if propstr is None: return None - return datetime.strptime(propstr, '%Y/%m/%d') + return _parse_builddate(propstr) def fetch_grouped_properties(ipmicmd, groupinfo): @@ -171,14 +195,10 @@ def fetch_agentless_firmware(ipmicmd, certverify): firm['releaseDate'] and firm['releaseDate'] != 'N/A'): try: - bdata['date'] = datetime.strptime( - firm['releaseDate'], '%m/%d/%Y') + bdata['date'] = _parse_builddate( + firm['releaseDate']) except ValueError: - try: - bdata['date'] = datetime.strptime( - firm['releaseDate'], '%m %d %Y') - except ValueError: - pass + pass yield ('{0} {1}'.format(aname, fname), bdata) storagedata = get_cached_data(ipmicmd, 'lenovo_cached_storage') if not storagedata: