2015-03-23 11:36:12 +00:00
|
|
|
# DASD configuration dialog
|
|
|
|
#
|
|
|
|
# Copyright (C) 2014 Red Hat, Inc.
|
|
|
|
#
|
|
|
|
# This copyrighted material is made available to anyone wishing to use,
|
|
|
|
# modify, copy, or redistribute it subject to the terms and conditions of
|
|
|
|
# the GNU General Public License v.2, or (at your option) any later version.
|
|
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
# ANY WARRANTY expressed or implied, including the implied warranties 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 this program; if not, write to the
|
|
|
|
# Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
|
|
# 02110-1301, USA. Any Red Hat trademarks that are incorporated in the
|
|
|
|
# source code or documentation are not subject to the GNU General Public
|
|
|
|
# License and may only be used or replicated with the express permission of
|
|
|
|
# Red Hat, Inc.
|
|
|
|
#
|
|
|
|
|
2016-04-10 04:00:00 +00:00
|
|
|
import gi
|
|
|
|
gi.require_version("BlockDev", "1.0")
|
|
|
|
|
|
|
|
from gi.repository import BlockDev as blockdev
|
|
|
|
|
2015-03-23 11:36:12 +00:00
|
|
|
from pyanaconda.ui.gui import GUIObject
|
|
|
|
from pyanaconda.ui.gui.utils import gtk_action_nowait
|
2017-01-09 02:09:07 +00:00
|
|
|
from pyanaconda.storage_utils import try_populate_devicetree
|
2015-03-23 11:36:12 +00:00
|
|
|
|
|
|
|
__all__ = ["DASDDialog"]
|
|
|
|
|
|
|
|
class DASDDialog(GUIObject):
|
|
|
|
""" Gtk dialog which allows users to manually add DASD devices without
|
|
|
|
having previously specified them in a parm file.
|
2016-04-10 04:00:00 +00:00
|
|
|
|
|
|
|
.. inheritance-diagram:: DASDDialog
|
|
|
|
:parts: 3
|
2015-03-23 11:36:12 +00:00
|
|
|
"""
|
|
|
|
builderObjects = ["dasdDialog"]
|
|
|
|
mainWidgetName = "dasdDialog"
|
|
|
|
uiFile = "spokes/advstorage/dasd.glade"
|
|
|
|
|
|
|
|
def __init__(self, data, storage):
|
|
|
|
GUIObject.__init__(self, data)
|
|
|
|
self.storage = storage
|
2017-01-09 02:09:07 +00:00
|
|
|
self.dasd = [d for d in self.storage.devices if d.type == "dasd"]
|
|
|
|
self.dasd.sort(key=lambda d: d.name)
|
2015-03-23 11:36:12 +00:00
|
|
|
|
|
|
|
self._discoveryError = None
|
|
|
|
|
|
|
|
self._update_devicetree = False
|
|
|
|
|
|
|
|
# grab all of the ui objects
|
|
|
|
self._configureGrid = self.builder.get_object("configureGrid")
|
|
|
|
self._conditionNotebook = self.builder.get_object("conditionNotebook")
|
|
|
|
|
|
|
|
self._startButton = self.builder.get_object("startButton")
|
|
|
|
self._okButton = self.builder.get_object("okButton")
|
|
|
|
self._cancelButton = self.builder.get_object("cancelButton")
|
2016-04-10 04:00:00 +00:00
|
|
|
self._retryButton = self.builder.get_object("retryButton")
|
2015-03-23 11:36:12 +00:00
|
|
|
|
|
|
|
self._deviceEntry = self.builder.get_object("deviceEntry")
|
|
|
|
|
|
|
|
self._spinner = self.builder.get_object("waitSpinner")
|
|
|
|
|
|
|
|
def refresh(self):
|
|
|
|
self._deviceEntry.set_text("")
|
|
|
|
self._deviceEntry.set_sensitive(True)
|
|
|
|
self._startButton.set_sensitive(True)
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
rc = self.window.run()
|
|
|
|
self.window.destroy()
|
|
|
|
# We need to call this to get the device nodes to show up
|
|
|
|
# in our devicetree.
|
|
|
|
if self._update_devicetree:
|
2017-01-09 02:09:07 +00:00
|
|
|
try_populate_devicetree(self.storage.devicetree)
|
2015-03-23 11:36:12 +00:00
|
|
|
return rc
|
|
|
|
|
|
|
|
def on_start_clicked(self, *args):
|
|
|
|
""" Go through the process of validating entry contents and then
|
|
|
|
attempt to add the device.
|
|
|
|
"""
|
|
|
|
# First update widgets
|
|
|
|
self._startButton.hide()
|
|
|
|
self._cancelButton.set_sensitive(False)
|
|
|
|
self._okButton.set_sensitive(False)
|
|
|
|
|
|
|
|
self._conditionNotebook.set_current_page(1)
|
|
|
|
|
|
|
|
try:
|
2016-04-10 04:00:00 +00:00
|
|
|
device = blockdev.s390.sanitize_dev_input(self._deviceEntry.get_text())
|
2015-03-23 11:36:12 +00:00
|
|
|
except ValueError as e:
|
|
|
|
_config_error = str(e)
|
|
|
|
self.builder.get_object("deviceErrorLabel").set_text(_config_error)
|
|
|
|
self._conditionNotebook.set_current_page(2)
|
|
|
|
self._configureGrid.set_sensitive(True)
|
|
|
|
self._cancelButton.set_sensitive(True)
|
|
|
|
return
|
|
|
|
|
|
|
|
self._spinner.start()
|
|
|
|
|
|
|
|
self._discover(device)
|
|
|
|
self._check_discover()
|
|
|
|
|
|
|
|
@gtk_action_nowait
|
|
|
|
def _check_discover(self):
|
|
|
|
""" After the DASD discover thread runs, check to see whether a valid
|
|
|
|
device was discovered. Display an error message if not.
|
|
|
|
"""
|
|
|
|
|
|
|
|
self._spinner.stop()
|
|
|
|
|
|
|
|
if self._discoveryError:
|
|
|
|
# Failure, display a message and leave the user on the dialog so
|
|
|
|
# they can try again (or cancel)
|
|
|
|
self.builder.get_object("deviceErrorLabel").set_text(self._discoveryError)
|
|
|
|
self._discoveryError = None
|
|
|
|
self._conditionNotebook.set_current_page(2)
|
|
|
|
else:
|
2017-01-09 02:09:07 +00:00
|
|
|
# Great success. Since DASDs go under local disks, update dialog to
|
|
|
|
# show users that's where they'll be
|
|
|
|
self._conditionNotebook.set_current_page(3)
|
|
|
|
self._okButton.set_sensitive(True)
|
2015-03-23 11:36:12 +00:00
|
|
|
|
|
|
|
self._cancelButton.set_sensitive(True)
|
|
|
|
return False
|
|
|
|
|
|
|
|
def _discover(self, device):
|
|
|
|
""" Given the configuration options from a user, attempt to discover
|
|
|
|
a DASD device. This includes searching black-listed devices.
|
|
|
|
"""
|
|
|
|
# attempt to add the device
|
|
|
|
try:
|
2016-04-10 04:00:00 +00:00
|
|
|
blockdev.s390.dasd_online(device)
|
2015-03-23 11:36:12 +00:00
|
|
|
self._update_devicetree = True
|
2016-04-10 04:00:00 +00:00
|
|
|
except blockdev.S390Error as err:
|
|
|
|
self._discoveryError = str(err)
|
2015-03-23 11:36:12 +00:00
|
|
|
return
|
2017-01-09 02:09:07 +00:00
|
|
|
except TypeError as err:
|
|
|
|
# this happens when a user doesn't pass any input, so pass a more
|
|
|
|
# informative error str back
|
|
|
|
self._discoveryError = "You must enter values for the device."
|
|
|
|
return
|
2016-04-10 04:00:00 +00:00
|
|
|
|
|
|
|
def on_device_entry_activate(self, entry, user_data=None):
|
|
|
|
# If the user hit Enter while the start button is displayed, activate
|
|
|
|
# whichever button is displayed.
|
|
|
|
current_page = self._conditionNotebook.get_current_page()
|
|
|
|
if current_page == 0:
|
|
|
|
self._startButton.clicked()
|
|
|
|
elif current_page == 2:
|
|
|
|
self._retryButton.clicked()
|