fixed! no more messages about missing UUID
This commit is contained in:
parent
c149a7b3b7
commit
0c0f6ee81b
@ -14,26 +14,6 @@ import psutil
|
|||||||
from lxml import etree
|
from lxml import etree
|
||||||
|
|
||||||
|
|
||||||
# def get_file_kernel_ver(self, kpath):
|
|
||||||
# # Gets the version of a kernel file.
|
|
||||||
# kpath = os.path.abspath(os.path.expanduser(kpath))
|
|
||||||
# _kinfo = {}
|
|
||||||
# with open(kpath, 'rb') as f:
|
|
||||||
# _m = magic.detect_from_content(f.read())
|
|
||||||
# for i in _m.name.split(','):
|
|
||||||
# l = i.strip().split()
|
|
||||||
# # Note: this only grabs the version number.
|
|
||||||
# # If we want to get e.g. the build user/machine, date, etc.,
|
|
||||||
# # then we need to join l[1:].
|
|
||||||
# # We technically don't even need a dict, either. We can just iterate.
|
|
||||||
# # TODO.
|
|
||||||
# _kinfo[l[0].lower()] = (l[1] if len(l) > 1 else None)
|
|
||||||
# if 'version' not in _kinfo:
|
|
||||||
# raise RuntimeError('Cannot deterimine the version of {0}'.format(
|
|
||||||
# kpath))
|
|
||||||
# else:
|
|
||||||
# return (_kinfo['version'])
|
|
||||||
|
|
||||||
class BootSync(object):
|
class BootSync(object):
|
||||||
def __init__(self, cfg = None, *args, **kwargs):
|
def __init__(self, cfg = None, *args, **kwargs):
|
||||||
if not cfg:
|
if not cfg:
|
||||||
@ -117,7 +97,13 @@ class BootSync(object):
|
|||||||
d = dict(map(lambda i: i.split('='), line))
|
d = dict(map(lambda i: i.split('='), line))
|
||||||
if d.get('TYPE') == 'squashfs':
|
if d.get('TYPE') == 'squashfs':
|
||||||
continue
|
continue
|
||||||
self.blkids[d['DEVNAME']] = d.get('PARTUUID', d['UUID'])
|
try:
|
||||||
|
self.blkids[d['DEVNAME']] = d.get('UUID', d['PARTUUID'])
|
||||||
|
except KeyError:
|
||||||
|
try:
|
||||||
|
self.blkids[d['DEVNAME']] = d['UUID']
|
||||||
|
except KeyError:
|
||||||
|
continue
|
||||||
c = subprocess.run(['/usr/bin/findmnt',
|
c = subprocess.run(['/usr/bin/findmnt',
|
||||||
'--json',
|
'--json',
|
||||||
'-T', '/boot'],
|
'-T', '/boot'],
|
||||||
@ -233,14 +219,16 @@ class BootSync(object):
|
|||||||
disk = os.path.abspath(os.path.expanduser(esp.attrib['path']))
|
disk = os.path.abspath(os.path.expanduser(esp.attrib['path']))
|
||||||
with open(os.path.join(mount, 'grub/grub.cfg'), 'w') as f:
|
with open(os.path.join(mount, 'grub/grub.cfg'), 'w') as f:
|
||||||
for line in _grubcfg.splitlines():
|
for line in _grubcfg.splitlines():
|
||||||
# if re.search(r'^\s*search\s+(.*)\s(-u|--fs-uuid)', line):
|
# If the array is in a degraded state, this will still let us at LEAST boot.
|
||||||
# pass
|
line = re.sub(r'\s+--hint=[\'"]?mduuid/[a-f0-9]{32}[\'"]?', '', line)
|
||||||
i = re.sub(r'(?<!\=UUID\=){0}'.format(self.dummy_uuid),
|
line = re.sub(r'^(\s*set\s+root=){0}$'.format(self.dummy_uuid),
|
||||||
self.blkids[disk],
|
self.blkids[disk],
|
||||||
line)
|
line)
|
||||||
# If the array is in a degraded state, this will still let us at LEAST boot.
|
line = re.sub(r'(?<!\=UUID\=){0}'.format(self.dummy_uuid),
|
||||||
i = re.sub(r'\s+--hint=[\'"]?mduuid/[a-f0-9]{32}[\'"]?', '', i)
|
self.blkids[disk],
|
||||||
f.write('{0}\n'.format(i))
|
line)
|
||||||
|
line = re.sub('/boot', '', line)
|
||||||
|
f.write('{0}\n'.format(line))
|
||||||
return()
|
return()
|
||||||
|
|
||||||
def _getRunningKernel(self):
|
def _getRunningKernel(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user