# 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/>
#
[docs]
class BootLoaderInstallBase:
"""
**Base class for bootloader installation on device**
:param string root_dir: root directory path name
:param object device_provider: instance of :class:`DeviceProvider`
:param dict custom_args: custom arguments dictionary
"""
def __init__(
self, xml_state, root_dir, device_provider, custom_args=None
):
self.xml_state = xml_state
self.root_dir = root_dir
self.device_provider = device_provider
self.device = self.device_provider.get_device()
self.post_init(custom_args)
[docs]
def post_init(self, custom_args):
"""
Post initialization method
Store custom arguments by default
:param dict custom_args: custom bootloader arguments
"""
self.custom_args = custom_args
[docs]
def install_required(self):
"""
Check if bootloader needs to be installed
Implementation in specialized bootloader install class required
"""
raise NotImplementedError
[docs]
def install(self):
"""
Install bootloader on self.device
Implementation in specialized bootloader install class required
"""
raise NotImplementedError
[docs]
def secure_boot_install(self):
"""
Run shim-install in self.device for secure boots
Implementation in specialized bootloader install class required
"""
raise NotImplementedError