From 2e9fe3f185f9851880b2bc93a636cd58d4194165 Mon Sep 17 00:00:00 2001 From: Philip Date: Sun, 6 Nov 2016 08:49:45 +0100 Subject: [PATCH] Modifications - [welcome] Use QNetworkAccessManager in checkHasInternet - [bootloader] Fix UEFI firmware workaround for 32-bit UEFI --- src/modules/bootloader/main.py | 8 +++-- src/modules/welcome/CMakeLists.txt | 3 +- .../welcome/checker/RequirementsChecker.cpp | 29 ++----------------- 3 files changed, 11 insertions(+), 29 deletions(-) diff --git a/src/modules/bootloader/main.py b/src/modules/bootloader/main.py index c009443da..9feb02e72 100644 --- a/src/modules/bootloader/main.py +++ b/src/modules/bootloader/main.py @@ -231,9 +231,13 @@ def install_grub(efi_directory, fw_type): check_target_env_call(["mkdir", "-p", efi_boot_directory]) # Workaround for some UEFI firmwares + efi_file_source = {"32": os.path.join(efi_directory_firmware, efi_bootloader_id, "grubia32.efi"), + "64": os.path.join(efi_directory_firmware, efi_bootloader_id, "grubx64.efi")} + efi_file_target = {"32": os.path.join(efi_boot_directory, "bootia32.efi"), + "64": os.path.join(efi_boot_directory, "bootx64.efi")} check_target_env_call(["cp", - os.path.join(efi_directory_firmware, efi_bootloader_id, "grubx64.efi"), - os.path.join(efi_boot_directory, "bootx64.efi")]) + efi_file_source[efi_bitness], + efi_file_target[efi_bitness]]) else: print("Bootloader: grub (bios)") boot_loader = libcalamares.globalstorage.value("bootLoader") diff --git a/src/modules/welcome/CMakeLists.txt b/src/modules/welcome/CMakeLists.txt index b8d2af27d..5e3a6f084 100644 --- a/src/modules/welcome/CMakeLists.txt +++ b/src/modules/welcome/CMakeLists.txt @@ -1,7 +1,7 @@ include_directories( ${PROJECT_BINARY_DIR}/src/libcalamaresui ) set( CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_SOURCE_DIR}/CMakeModules ) find_package( LIBPARTED REQUIRED ) -find_package( Qt5 ${QT_VERSION} CONFIG REQUIRED DBus ) +find_package( Qt5 ${QT_VERSION} CONFIG REQUIRED DBus Network ) set_source_files_properties( checker/partman_devices.c PROPERTIES LANGUAGE CXX ) @@ -14,6 +14,7 @@ set( CHECKER_SOURCES set( CHECKER_LINK_LIBRARIES ${LIBPARTED_LIBS} Qt5::DBus + Qt5::Network ) calamares_add_plugin( welcome diff --git a/src/modules/welcome/checker/RequirementsChecker.cpp b/src/modules/welcome/checker/RequirementsChecker.cpp index f77847cf7..12f681720 100644 --- a/src/modules/welcome/checker/RequirementsChecker.cpp +++ b/src/modules/welcome/checker/RequirementsChecker.cpp @@ -36,6 +36,7 @@ #include #include #include +#include #include #include @@ -336,32 +337,8 @@ RequirementsChecker::checkHasPower() bool RequirementsChecker::checkHasInternet() { - const QString NM_SVC_NAME( "org.freedesktop.NetworkManager" ); - const QString NM_INTF_NAME( "org.freedesktop.NetworkManager" ); - const QString NM_PATH( "/org/freedesktop/NetworkManager" ); - const int NM_STATE_CONNECTED_GLOBAL = 70; - - QDBusInterface nmIntf( NM_SVC_NAME, - NM_PATH, - NM_INTF_NAME, - QDBusConnection::systemBus(), 0 ); - - bool ok = false; - int nmState = nmIntf.property( "State" ).toInt( &ok ); - - if ( !ok || !nmIntf.isValid() ) - { - // We can't talk to NM, so no idea. Wild guess: we're connected - // using ssh with X forwarding, and are therefore connected. This - // allows us to proceed with a minimum of complaint. - Calamares::JobQueue::instance()->globalStorage()->insert( "hasInternet", true ); - return true; - } - - bool hasInternet = nmState == NM_STATE_CONNECTED_GLOBAL; - - Calamares::JobQueue::instance()->globalStorage()->insert( "hasInternet", hasInternet ); - return hasInternet; + // default to true in the QNetworkAccessManager::UnknownAccessibility case + return QNetworkAccessManager(this).networkAccessible() != QNetworkAccessManager::NotAccessible; }