Refactor block_device: isolate the getval call
Add a new getval call that allows to retrieve values from the block device. Also isolating the block device information into a 'blockdev' dictionary entry, to better return it with the getval command. This is a refactor from the original code at I3600c6a3d663c697b59d91bd3fbb5e408af345e4. Change-Id: I93d33669a3a0ae644eab9f9b955bb5a9470cadeb Co-Authored-By: Andreas Florath <andreas@florath.net>
This commit is contained in:
parent
803d40b0c6
commit
943f1ccf04
4 changed files with 50 additions and 25 deletions
|
@ -40,6 +40,10 @@ class BlockDevice(object):
|
||||||
call it is possible to e.g. query information from the (partially
|
call it is possible to e.g. query information from the (partially
|
||||||
automatic generated) internal state like root-label.
|
automatic generated) internal state like root-label.
|
||||||
|
|
||||||
|
cmd_getval: retrieve information about the (internal) block device
|
||||||
|
state like the block image device (for bootloader) or the
|
||||||
|
root-label (for writing fstab).
|
||||||
|
|
||||||
cmd_create: creates all the different aspects of the block
|
cmd_create: creates all the different aspects of the block
|
||||||
device. When this call is successful, the complete block level
|
device. When this call is successful, the complete block level
|
||||||
device is set up, filesystems are created and are mounted at
|
device is set up, filesystems are created and are mounted at
|
||||||
|
@ -209,6 +213,28 @@ class BlockDevice(object):
|
||||||
logger.info("Wrote final block device config to [%s]"
|
logger.info("Wrote final block device config to [%s]"
|
||||||
% self.config_json_file_name)
|
% self.config_json_file_name)
|
||||||
|
|
||||||
|
def cmd_getval(self):
|
||||||
|
"""Retrieve value from block device level
|
||||||
|
|
||||||
|
This is needed for backward compatibility (non python) access
|
||||||
|
to (internal) configuration.
|
||||||
|
"""
|
||||||
|
symbol = self.args.symbol
|
||||||
|
logger.info("Getting value for [%s]" % symbol)
|
||||||
|
if symbol == 'image-block-partition':
|
||||||
|
# If there is no partition needed, pass back directly the
|
||||||
|
# image.
|
||||||
|
if 'root' in self.state['blockdev']:
|
||||||
|
print("%s" % self.state['blockdev']['root']['device'])
|
||||||
|
else:
|
||||||
|
print("%s" % self.state['blockdev']['image0']['device'])
|
||||||
|
return 0
|
||||||
|
if symbol == 'image-path':
|
||||||
|
print("%s" % self.state['blockdev']['image0']['image'])
|
||||||
|
return 0
|
||||||
|
logger.error("Invalid symbol [%s] for getval" % symbol)
|
||||||
|
return 1
|
||||||
|
|
||||||
def cmd_create(self):
|
def cmd_create(self):
|
||||||
"""Creates the block device"""
|
"""Creates the block device"""
|
||||||
|
|
||||||
|
@ -226,15 +252,6 @@ class BlockDevice(object):
|
||||||
rollback_cb()
|
rollback_cb()
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
# To be compatible with the current implementation, echo the
|
|
||||||
# result to stdout.
|
|
||||||
# If there is no partition needed, pass back directly the
|
|
||||||
# image.
|
|
||||||
if 'root' in result:
|
|
||||||
print("%s" % result['root']['device'])
|
|
||||||
else:
|
|
||||||
print("%s" % result['image0']['device'])
|
|
||||||
|
|
||||||
self.write_state(result)
|
self.write_state(result)
|
||||||
|
|
||||||
logger.info("create() finished")
|
logger.info("create() finished")
|
||||||
|
@ -250,10 +267,6 @@ class BlockDevice(object):
|
||||||
for node in reverse_order:
|
for node in reverse_order:
|
||||||
node.umount(self.state)
|
node.umount(self.state)
|
||||||
|
|
||||||
# To be compatible with the current implementation, echo the
|
|
||||||
# result to stdout.
|
|
||||||
print("%s" % self.state['image0']['image'])
|
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
def cmd_cleanup(self):
|
def cmd_cleanup(self):
|
||||||
|
|
|
@ -111,17 +111,20 @@ class LocalLoop(NodePluginBase):
|
||||||
block_device = self._loopdev_attach(self.filename)
|
block_device = self._loopdev_attach(self.filename)
|
||||||
rollback.append(lambda: self._loopdev_detach(block_device))
|
rollback.append(lambda: self._loopdev_detach(block_device))
|
||||||
|
|
||||||
result[self.name] = {"device": block_device,
|
if 'blockdev' not in result:
|
||||||
|
result['blockdev'] = {}
|
||||||
|
|
||||||
|
result['blockdev'][self.name] = {"device": block_device,
|
||||||
"image": self.filename}
|
"image": self.filename}
|
||||||
logger.debug("Created loop name [%s] device [%s] image [%s]"
|
logger.debug("Created loop name [%s] device [%s] image [%s]"
|
||||||
% (self.name, block_device, self.filename))
|
% (self.name, block_device, self.filename))
|
||||||
return
|
return
|
||||||
|
|
||||||
def umount(self, state):
|
def umount(self, state):
|
||||||
self._loopdev_detach(state[self.name]['device'])
|
self._loopdev_detach(state['blockdev'][self.name]['device'])
|
||||||
|
|
||||||
def cleanup(self, state):
|
def cleanup(self, state):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def delete(self, state):
|
def delete(self, state):
|
||||||
self._image_delete(state[self.name]['image'])
|
self._image_delete(state['blockdev'][self.name]['image'])
|
||||||
|
|
|
@ -198,8 +198,8 @@ class Partitioning(PluginBase):
|
||||||
self._exec_sudo(["kpartx", "-avs", device_path])
|
self._exec_sudo(["kpartx", "-avs", device_path])
|
||||||
|
|
||||||
def create(self, result, rollback):
|
def create(self, result, rollback):
|
||||||
image_path = result[self.base]['image']
|
image_path = result['blockdev'][self.base]['image']
|
||||||
device_path = result[self.base]['device']
|
device_path = result['blockdev'][self.base]['device']
|
||||||
logger.info("Creating partition on [%s] [%s]" %
|
logger.info("Creating partition on [%s] [%s]" %
|
||||||
(self.base, image_path))
|
(self.base, image_path))
|
||||||
|
|
||||||
|
@ -229,7 +229,8 @@ class Partitioning(PluginBase):
|
||||||
logger.debug("Create partition [%s] [%d]" %
|
logger.debug("Create partition [%s] [%d]" %
|
||||||
(part_name, part_no))
|
(part_name, part_no))
|
||||||
partition_device_name = device_path + "p%d" % part_no
|
partition_device_name = device_path + "p%d" % part_no
|
||||||
result[part_name] = {'device': partition_device_name}
|
result['blockdev'][part_name] \
|
||||||
|
= {'device': partition_device_name}
|
||||||
partition_devices.add(partition_device_name)
|
partition_devices.add(partition_device_name)
|
||||||
|
|
||||||
self.already_created = True
|
self.already_created = True
|
||||||
|
|
|
@ -419,18 +419,23 @@ fi
|
||||||
DIB_BLOCK_DEVICE_SCRIPT=$(which dib-block-device)
|
DIB_BLOCK_DEVICE_SCRIPT=$(which dib-block-device)
|
||||||
|
|
||||||
if [ -z ${IMAGE_BLOCK_DEVICE} ] ; then
|
if [ -z ${IMAGE_BLOCK_DEVICE} ] ; then
|
||||||
# For compatibily reasons in addition to the YAML configuration
|
# For compatibility reasons in addition to the YAML configuration
|
||||||
# there is the need to handle the old environment variables.
|
# there is the need to handle the old environment variables.
|
||||||
echo "image-size: ${DIB_IMAGE_SIZE}KiB" >> ${DIB_BLOCK_DEVICE_PARAMS_YAML}
|
echo "image-size: ${DIB_IMAGE_SIZE}KiB" >> ${DIB_BLOCK_DEVICE_PARAMS_YAML}
|
||||||
|
|
||||||
# After changeing the parameters, there is the need to
|
# After changing the parameters, there is the need to
|
||||||
# re-run dib-block-device init because some value might
|
# re-run dib-block-device init because some value might
|
||||||
# change based on the new set parameters.
|
# change based on the new set parameters.
|
||||||
dib-block-device --phase=init \
|
dib-block-device --phase=init \
|
||||||
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}"
|
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}"
|
||||||
|
|
||||||
# values to dib-block-device: using the YAML config and
|
# values to dib-block-device: using the YAML config and
|
||||||
IMAGE_BLOCK_DEVICE=$(dib-block-device --phase=create \
|
dib-block-device --phase=create \
|
||||||
|
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}"
|
||||||
|
|
||||||
|
# It's called 'DEVICE' but it's the partition.
|
||||||
|
IMAGE_BLOCK_DEVICE=$(dib-block-device \
|
||||||
|
--phase=getval --symbol=image-block-partition \
|
||||||
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}")
|
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}")
|
||||||
fi
|
fi
|
||||||
export IMAGE_BLOCK_DEVICE
|
export IMAGE_BLOCK_DEVICE
|
||||||
|
@ -496,10 +501,13 @@ fi
|
||||||
# space before converting the image to some other format.
|
# space before converting the image to some other format.
|
||||||
export EXTRA_UNMOUNT=""
|
export EXTRA_UNMOUNT=""
|
||||||
unmount_image
|
unmount_image
|
||||||
TMP_IMAGE_PATH=$(dib-block-device --phase=umount \
|
TMP_IMAGE_PATH=$(dib-block-device --phase=getval --symbol=image-path \
|
||||||
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}")
|
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}")
|
||||||
export TMP_IMAGE_PATH
|
export TMP_IMAGE_PATH
|
||||||
|
|
||||||
|
dib-block-device --phase=umount \
|
||||||
|
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}"
|
||||||
|
|
||||||
dib-block-device --phase=cleanup \
|
dib-block-device --phase=cleanup \
|
||||||
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}"
|
--params="${DIB_BLOCK_DEVICE_PARAMS_YAML}"
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue