# Copyright (c) 2015 SUSE Linux GmbH. All rights reserved.
#
# This file is part of kiwi.
#
# kiwi is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# kiwi is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with kiwi. If not, see <http://www.gnu.org/licenses/>
#
import os
import re
# project
from kiwi.command import Command
[docs]
class BlockID:
"""
**Get information from a block device**
:param str device:
block device node name name. The device can
also be specified as UUID=<uuid>
"""
def __init__(self, device):
uuid_format = re.match(r'^UUID=(.*)', device)
if uuid_format:
blkid_result = Command.run(
['blkid', '--uuid', uuid_format.group(1)]
)
self.device = blkid_result.output.strip(os.linesep)
else:
self.device = device
[docs]
def get_label(self):
"""
Retrieve filesystem label from block device
:return: block device label
:rtype: str
"""
return self.get_blkid('LABEL')
[docs]
def get_uuid(self):
"""
Retrieve filesystem uuid from block device
:return: uuid for the filesystem of the block device
:rtype: str
"""
return self.get_blkid('UUID')
[docs]
def get_filesystem(self):
"""
Retrieve filesystem type from block device
:return: filesystem type
:rtype: str
"""
return self.get_blkid('TYPE')
[docs]
def get_partition_count(self) -> int:
"""
Retrieve number of partitions from block device
:return: A number
:rtype: int
"""
partition_count = 0
lsblk_result = Command.run(
['lsblk', '-r', '-o', 'NAME,TYPE', self.device]
)
for line in lsblk_result.output.strip().split(os.linesep):
if line.strip().endswith('part'):
partition_count += 1
return partition_count
[docs]
def get_blkid(self, id_type):
"""
Retrieve information for specified metadata ID from block device
:param string id_type: metadata ID, see man blkid for details
:return: ID of the block device
:rtype: str
"""
blkid_result = Command.run(
['blkid', self.device, '-s', id_type, '-o', 'value'],
raise_on_error=False
)
return blkid_result.output.strip(os.linesep) if blkid_result else ''