diff options
author | Arttu Tarkiainen <arttu.tarkiainen@qt.io> | 2020-04-17 16:25:25 +0300 |
---|---|---|
committer | Arttu Tarkiainen <arttu.tarkiainen@qt.io> | 2020-04-28 11:56:44 +0300 |
commit | 550186ed78a023374239c1f8494188db030f035d (patch) | |
tree | 2d96ab24f87535bf42e746970679217777571acc /src/libs/installer/packagemanagercore_p.cpp | |
parent | 4f5eace163eeb34504cb8044c42b147df03fafed (diff) |
Add possibility to accept licenses from CLI
License agreements can be accepted automatically by using command
line option --accept-licenses or interactively by answering
queries with either "Accept", "Reject" or "Show" selections.
Task-number: QTIFW-1742
Task-number: QTIFW-1745
Change-Id: Iff46b44f91faddb7f163b299994167ab16df68b3
Reviewed-by: Katja Marttila <katja.marttila@qt.io>
Diffstat (limited to 'src/libs/installer/packagemanagercore_p.cpp')
-rw-r--r-- | src/libs/installer/packagemanagercore_p.cpp | 60 |
1 files changed, 59 insertions, 1 deletions
diff --git a/src/libs/installer/packagemanagercore_p.cpp b/src/libs/installer/packagemanagercore_p.cpp index 09aa57650..8323928f9 100644 --- a/src/libs/installer/packagemanagercore_p.cpp +++ b/src/libs/installer/packagemanagercore_p.cpp @@ -219,6 +219,7 @@ PackageManagerCorePrivate::PackageManagerCorePrivate(PackageManagerCore *core) , m_commandLineInstance(false) , m_userSetBinaryMarker(false) , m_checkAvailableSpace(true) + , m_autoAcceptLicenses(false) { } @@ -253,6 +254,7 @@ PackageManagerCorePrivate::PackageManagerCorePrivate(PackageManagerCore *core, q , m_commandLineInstance(false) , m_userSetBinaryMarker(false) , m_checkAvailableSpace(true) + , m_autoAcceptLicenses(false) { foreach (const OperationBlob &operation, performedOperations) { QScopedPointer<QInstaller::Operation> op(KDUpdater::UpdateOperationFactory::instance() @@ -2510,11 +2512,67 @@ bool PackageManagerCorePrivate::calculateComponentsAndRun() QString htmlOutput; bool componentsOk = m_core->calculateComponents(&htmlOutput); qCDebug(QInstaller::lcInstallerInstallLog).noquote() << htmlToString(htmlOutput); - if (componentsOk) { + if (componentsOk && acceptLicenseAgreements()) { return m_core->run(); } return false; } +bool PackageManagerCorePrivate::acceptLicenseAgreements() +{ + // Always skip for uninstaller + if (isUninstaller()) + return true; + + typedef QHash<QString, QPair<QString, QString> > LicensesHash; + foreach (Component *component, m_core->orderedComponentsToInstall()) { + // Package manager or updater, no need to accept again as long as + // the component is installed. + if (m_core->isMaintainer() && component->isInstalled()) + continue; + + LicensesHash hash = component->licenses(); + for (LicensesHash::iterator it = hash.begin(); it != hash.end(); ++it) { + if (m_autoAcceptLicenses || askUserAcceptLicense(it.key(), it.value().second)) { + qCDebug(QInstaller::lcInstallerInstallLog) << "License" + << it.key() << "accepted by user."; + } else { + qCDebug(QInstaller::lcInstallerInstallLog) << "License" + << it.key() << "not accepted by user. Aborting."; + return false; + } + } + } + return true; +} + +bool PackageManagerCorePrivate::askUserAcceptLicense(const QString &name, const QString &content) +{ + qCDebug(QInstaller::lcInstallerInstallLog) << "You must accept " + "the terms contained in the following license agreement " + "before continuing with the installation:" << name; + + forever { + qCDebug(QInstaller::lcInstallerInstallLog) << "Accept|Reject|Show"; + + QTextStream stream(stdin); + QString input; + stream.readLineInto(&input); + + if (QString::compare(input, QLatin1String("Accept"), Qt::CaseInsensitive) == 0 + || QString::compare(input, QLatin1String("A"), Qt::CaseInsensitive) == 0) { + return true; + } else if (QString::compare(input, QLatin1String("Reject"), Qt::CaseInsensitive) == 0 + || QString::compare(input, QLatin1String("R"), Qt::CaseInsensitive) == 0) { + return false; + } else if (QString::compare(input, QLatin1String("Show"), Qt::CaseInsensitive) == 0 + || QString::compare(input, QLatin1String("S"), Qt::CaseInsensitive) == 0) { + qCDebug(QInstaller::lcInstallerInstallLog).noquote() << content; + } else { + qCDebug(QInstaller::lcInstallerInstallLog) << "Unknown answer:" << input; + } + } +} + } // namespace QInstaller |