mirror of
https://github.com/nextcloud/desktop.git
synced 2024-11-23 13:35:58 +03:00
Merge pull request #5329 from nextcloud/feature/allow-forceoverrideurl-via-command-line
Feature/allow forceoverrideurl via command line
This commit is contained in:
commit
4ee22a91cc
9 changed files with 149 additions and 19 deletions
|
@ -69,7 +69,7 @@ AccountManager *AccountManager::instance()
|
||||||
return &instance;
|
return &instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AccountManager::restore()
|
bool AccountManager::restore(bool alsoRestoreLegacySettings)
|
||||||
{
|
{
|
||||||
QStringList skipSettingsKeys;
|
QStringList skipSettingsKeys;
|
||||||
backwardMigrationSettingsKeys(&skipSettingsKeys, &skipSettingsKeys);
|
backwardMigrationSettingsKeys(&skipSettingsKeys, &skipSettingsKeys);
|
||||||
|
@ -88,8 +88,7 @@ bool AccountManager::restore()
|
||||||
}
|
}
|
||||||
|
|
||||||
// If there are no accounts, check the old format.
|
// If there are no accounts, check the old format.
|
||||||
if (settings->childGroups().isEmpty()
|
if (settings->childGroups().isEmpty() && !settings->contains(QLatin1String(versionC)) && alsoRestoreLegacySettings) {
|
||||||
&& !settings->contains(QLatin1String(versionC))) {
|
|
||||||
restoreFromLegacySettings();
|
restoreFromLegacySettings();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,7 +41,7 @@ public:
|
||||||
* Returns false if there was an error reading the settings,
|
* Returns false if there was an error reading the settings,
|
||||||
* but note that settings not existing is not an error.
|
* but note that settings not existing is not an error.
|
||||||
*/
|
*/
|
||||||
bool restore();
|
bool restore(bool alsoRestoreLegacySettings = true);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add this account in the list of saved accounts.
|
* Add this account in the list of saved accounts.
|
||||||
|
|
|
@ -87,6 +87,8 @@ namespace {
|
||||||
" --logdebug : also output debug-level messages in the log.\n"
|
" --logdebug : also output debug-level messages in the log.\n"
|
||||||
" --confdir <dirname> : Use the given configuration folder.\n"
|
" --confdir <dirname> : Use the given configuration folder.\n"
|
||||||
" --background : launch the application in the background.\n"
|
" --background : launch the application in the background.\n"
|
||||||
|
" --overrideserverurl : specify a server URL to use for the force override to be used in the account setup wizard.\n"
|
||||||
|
" --overridelocaldir : specify a local dir to be used in the account setup wizard.\n"
|
||||||
" --userid : userId (username as on the server) to pass when creating an account via command-line.\n"
|
" --userid : userId (username as on the server) to pass when creating an account via command-line.\n"
|
||||||
" --apppassword : appPassword to pass when creating an account via command-line.\n"
|
" --apppassword : appPassword to pass when creating an account via command-line.\n"
|
||||||
" --localdirpath : (optional) path where to create a local sync folder when creating an account via command-line.\n"
|
" --localdirpath : (optional) path where to create a local sync folder when creating an account via command-line.\n"
|
||||||
|
@ -335,12 +337,12 @@ Application::Application(int &argc, char **argv)
|
||||||
|
|
||||||
connect(this, &SharedTools::QtSingleApplication::messageReceived, this, &Application::slotParseMessage);
|
connect(this, &SharedTools::QtSingleApplication::messageReceived, this, &Application::slotParseMessage);
|
||||||
|
|
||||||
if (!AccountManager::instance()->restore()) {
|
if (!AccountManager::instance()->restore(cfg.overrideServerUrl().isEmpty())) {
|
||||||
// If there is an error reading the account settings, try again
|
// If there is an error reading the account settings, try again
|
||||||
// after a couple of seconds, if that fails, give up.
|
// after a couple of seconds, if that fails, give up.
|
||||||
// (non-existence is not an error)
|
// (non-existence is not an error)
|
||||||
Utility::sleep(5);
|
Utility::sleep(5);
|
||||||
if (!AccountManager::instance()->restore()) {
|
if (!AccountManager::instance()->restore(cfg.overrideServerUrl().isEmpty())) {
|
||||||
qCCritical(lcApplication) << "Could not read the account settings, quitting";
|
qCCritical(lcApplication) << "Could not read the account settings, quitting";
|
||||||
QMessageBox::critical(
|
QMessageBox::critical(
|
||||||
nullptr,
|
nullptr,
|
||||||
|
@ -620,6 +622,8 @@ void Application::parseOptions(const QStringList &options)
|
||||||
if (it.hasNext())
|
if (it.hasNext())
|
||||||
it.next();
|
it.next();
|
||||||
|
|
||||||
|
bool shouldExit = false;
|
||||||
|
|
||||||
//parse options; if help or bad option exit
|
//parse options; if help or bad option exit
|
||||||
while (it.hasNext()) {
|
while (it.hasNext()) {
|
||||||
QString option = it.next();
|
QString option = it.next();
|
||||||
|
@ -680,6 +684,26 @@ void Application::parseOptions(const QStringList &options)
|
||||||
qCInfo(lcApplication) << errorParsingLocalFileEditingUrl;
|
qCInfo(lcApplication) << errorParsingLocalFileEditingUrl;
|
||||||
showHint(errorParsingLocalFileEditingUrl.toStdString());
|
showHint(errorParsingLocalFileEditingUrl.toStdString());
|
||||||
}
|
}
|
||||||
|
} else if (option == QStringLiteral("--overrideserverurl")) {
|
||||||
|
if (it.hasNext() && !it.peekNext().startsWith(QLatin1String("--"))) {
|
||||||
|
const auto overrideUrl = it.next();
|
||||||
|
const auto isUrlValid = (overrideUrl.startsWith(QStringLiteral("http://")) || overrideUrl.startsWith(QStringLiteral("https://")))
|
||||||
|
&& QUrl::fromUserInput(overrideUrl).isValid();
|
||||||
|
if (!isUrlValid) {
|
||||||
|
showHint("Invalid URL passed to --overrideserverurl");
|
||||||
|
} else {
|
||||||
|
ConfigFile().setOverrideServerUrl(overrideUrl);
|
||||||
|
shouldExit = true;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
showHint("Invalid URL passed to --overrideserverurl");
|
||||||
|
}
|
||||||
|
} else if (option == QStringLiteral("--overridelocaldir")) {
|
||||||
|
if (it.hasNext() && !it.peekNext().startsWith(QLatin1String("--"))) {
|
||||||
|
ConfigFile().setOverrideLocalDir(it.next());
|
||||||
|
} else {
|
||||||
|
showHint("Invalid URL passed to --overridelocaldir");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
QString errorMessage;
|
QString errorMessage;
|
||||||
|
@ -692,6 +716,9 @@ void Application::parseOptions(const QStringList &options)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (shouldExit) {
|
||||||
|
std::exit(0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Helpers for displaying messages. Note that there is no console on Windows.
|
// Helpers for displaying messages. Note that there is no console on Windows.
|
||||||
|
|
|
@ -69,6 +69,12 @@ static QPointer<OwncloudSetupWizard> wiz = nullptr;
|
||||||
|
|
||||||
void OwncloudSetupWizard::runWizard(QObject *obj, const char *amember, QWidget *parent)
|
void OwncloudSetupWizard::runWizard(QObject *obj, const char *amember, QWidget *parent)
|
||||||
{
|
{
|
||||||
|
ConfigFile cfg;
|
||||||
|
if (!cfg.overrideServerUrl().isEmpty()) {
|
||||||
|
Theme::instance()->setOverrideServerUrl(cfg.overrideServerUrl());
|
||||||
|
Theme::instance()->setForceOverrideServerUrl(true);
|
||||||
|
Theme::instance()->setStartLoginFlowAutomatically(true);
|
||||||
|
}
|
||||||
if (!wiz.isNull()) {
|
if (!wiz.isNull()) {
|
||||||
bringWizardToFrontIfVisible();
|
bringWizardToFrontIfVisible();
|
||||||
return;
|
return;
|
||||||
|
@ -109,6 +115,12 @@ void OwncloudSetupWizard::startWizard()
|
||||||
}
|
}
|
||||||
|
|
||||||
_ocWizard->setProperty("localFolder", localFolder);
|
_ocWizard->setProperty("localFolder", localFolder);
|
||||||
|
{
|
||||||
|
ConfigFile cfg;
|
||||||
|
if (!cfg.overrideLocalDir().isEmpty()) {
|
||||||
|
_ocWizard->setProperty("localFolder", cfg.overrideLocalDir());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// remember the local folder to compare later if it changed, but clean first
|
// remember the local folder to compare later if it changed, but clean first
|
||||||
QString lf = QDir::fromNativeSeparators(localFolder);
|
QString lf = QDir::fromNativeSeparators(localFolder);
|
||||||
|
@ -120,8 +132,11 @@ void OwncloudSetupWizard::startWizard()
|
||||||
|
|
||||||
_ocWizard->setRemoteFolder(_remoteFolder);
|
_ocWizard->setRemoteFolder(_remoteFolder);
|
||||||
|
|
||||||
|
const auto isEnforcedServerSetup =
|
||||||
|
Theme::instance()->startLoginFlowAutomatically() && Theme::instance()->forceOverrideServerUrl() && !account->url().isEmpty();
|
||||||
|
|
||||||
#ifdef WITH_PROVIDERS
|
#ifdef WITH_PROVIDERS
|
||||||
const auto startPage = WizardCommon::Page_Welcome;
|
const auto startPage = isEnforcedServerSetup ? WizardCommon::Page_ServerSetup : WizardCommon::Page_Welcome;
|
||||||
#else // WITH_PROVIDERS
|
#else // WITH_PROVIDERS
|
||||||
const auto startPage = WizardCommon::Page_ServerSetup;
|
const auto startPage = WizardCommon::Page_ServerSetup;
|
||||||
#endif // WITH_PROVIDERS
|
#endif // WITH_PROVIDERS
|
||||||
|
|
|
@ -193,6 +193,16 @@ void OwncloudAdvancedSetupPage::initializePage()
|
||||||
if (nextButton) {
|
if (nextButton) {
|
||||||
nextButton->setDefault(true);
|
nextButton->setDefault(true);
|
||||||
}
|
}
|
||||||
|
if (Theme::instance()->forceOverrideServerUrl()) {
|
||||||
|
QTimer::singleShot(0, this, [this]() {
|
||||||
|
connect(_ocWizard, &QDialog::accepted, []() {
|
||||||
|
ConfigFile cfg;
|
||||||
|
cfg.setOverrideServerUrl({});
|
||||||
|
cfg.setOverrideLocalDir({});
|
||||||
|
});
|
||||||
|
_ocWizard->accept();
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void OwncloudAdvancedSetupPage::fetchUserAvatar()
|
void OwncloudAdvancedSetupPage::fetchUserAvatar()
|
||||||
|
|
|
@ -67,6 +67,8 @@ static constexpr char autoUpdateCheckC[] = "autoUpdateCheck";
|
||||||
static constexpr char updateCheckIntervalC[] = "updateCheckInterval";
|
static constexpr char updateCheckIntervalC[] = "updateCheckInterval";
|
||||||
static constexpr char updateSegmentC[] = "updateSegment";
|
static constexpr char updateSegmentC[] = "updateSegment";
|
||||||
static constexpr char updateChannelC[] = "updateChannel";
|
static constexpr char updateChannelC[] = "updateChannel";
|
||||||
|
static constexpr char overrideServerUrlC[] = "overrideServerUrl";
|
||||||
|
static constexpr char overrideLocalDirC[] = "overrideLocalDir";
|
||||||
static constexpr char geometryC[] = "geometry";
|
static constexpr char geometryC[] = "geometry";
|
||||||
static constexpr char timeoutC[] = "timeout";
|
static constexpr char timeoutC[] = "timeout";
|
||||||
static constexpr char chunkSizeC[] = "chunkSize";
|
static constexpr char chunkSizeC[] = "chunkSize";
|
||||||
|
@ -688,6 +690,30 @@ void ConfigFile::setUpdateChannel(const QString &channel)
|
||||||
settings.setValue(QLatin1String(updateChannelC), channel);
|
settings.setValue(QLatin1String(updateChannelC), channel);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[[nodiscard]] QString ConfigFile::overrideServerUrl() const
|
||||||
|
{
|
||||||
|
QSettings settings(configFile(), QSettings::IniFormat);
|
||||||
|
return settings.value(QLatin1String(overrideServerUrlC), {}).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ConfigFile::setOverrideServerUrl(const QString &url)
|
||||||
|
{
|
||||||
|
QSettings settings(configFile(), QSettings::IniFormat);
|
||||||
|
settings.setValue(QLatin1String(overrideServerUrlC), url);
|
||||||
|
}
|
||||||
|
|
||||||
|
[[nodiscard]] QString ConfigFile::overrideLocalDir() const
|
||||||
|
{
|
||||||
|
QSettings settings(configFile(), QSettings::IniFormat);
|
||||||
|
return settings.value(QLatin1String(overrideLocalDirC), {}).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ConfigFile::setOverrideLocalDir(const QString &localDir)
|
||||||
|
{
|
||||||
|
QSettings settings(configFile(), QSettings::IniFormat);
|
||||||
|
settings.setValue(QLatin1String(overrideLocalDirC), localDir);
|
||||||
|
}
|
||||||
|
|
||||||
void ConfigFile::setProxyType(int proxyType,
|
void ConfigFile::setProxyType(int proxyType,
|
||||||
const QString &host,
|
const QString &host,
|
||||||
int port, bool needsAuth,
|
int port, bool needsAuth,
|
||||||
|
|
|
@ -186,6 +186,12 @@ public:
|
||||||
[[nodiscard]] QString updateChannel() const;
|
[[nodiscard]] QString updateChannel() const;
|
||||||
void setUpdateChannel(const QString &channel);
|
void setUpdateChannel(const QString &channel);
|
||||||
|
|
||||||
|
[[nodiscard]] QString overrideServerUrl() const;
|
||||||
|
void setOverrideServerUrl(const QString &url);
|
||||||
|
|
||||||
|
[[nodiscard]] QString overrideLocalDir() const;
|
||||||
|
void setOverrideLocalDir(const QString &localDir);
|
||||||
|
|
||||||
void saveGeometryHeader(QHeaderView *header);
|
void saveGeometryHeader(QHeaderView *header);
|
||||||
void restoreGeometryHeader(QHeaderView *header);
|
void restoreGeometryHeader(QHeaderView *header);
|
||||||
|
|
||||||
|
|
|
@ -371,6 +371,13 @@ Theme::Theme()
|
||||||
reserveDarkPalette.setColor(QPalette::Disabled, QPalette::HighlightedText,
|
reserveDarkPalette.setColor(QPalette::Disabled, QPalette::HighlightedText,
|
||||||
QColor(127, 127, 127));
|
QColor(127, 127, 127));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef APPLICATION_SERVER_URL_ENFORCE
|
||||||
|
_forceOverrideServerUrl = true;
|
||||||
|
#endif
|
||||||
|
#ifdef APPLICATION_SERVER_URL
|
||||||
|
_overrideServerUrl = QString::fromLatin1(APPLICATION_SERVER_URL);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// If this option returns true, the client only supports one folder to sync.
|
// If this option returns true, the client only supports one folder to sync.
|
||||||
|
@ -411,20 +418,17 @@ QString Theme::conflictHelpUrl() const
|
||||||
|
|
||||||
QString Theme::overrideServerUrl() const
|
QString Theme::overrideServerUrl() const
|
||||||
{
|
{
|
||||||
#ifdef APPLICATION_SERVER_URL
|
return _overrideServerUrl;
|
||||||
return QString::fromLatin1(APPLICATION_SERVER_URL);
|
|
||||||
#else
|
|
||||||
return QString();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Theme::forceOverrideServerUrl() const
|
bool Theme::forceOverrideServerUrl() const
|
||||||
{
|
{
|
||||||
#ifdef APPLICATION_SERVER_URL_ENFORCE
|
return _forceOverrideServerUrl;
|
||||||
return true;
|
}
|
||||||
#else
|
|
||||||
return false;
|
bool Theme::startLoginFlowAutomatically() const
|
||||||
#endif
|
{
|
||||||
|
return _startLoginFlowAutomatically;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Theme::enableStaplingOCSP() const
|
bool Theme::enableStaplingOCSP() const
|
||||||
|
@ -952,4 +956,27 @@ bool Theme::darkMode()
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Theme::setOverrideServerUrl(const QString &overrideServerUrl)
|
||||||
|
{
|
||||||
|
if (_overrideServerUrl != overrideServerUrl) {
|
||||||
|
_overrideServerUrl = overrideServerUrl;
|
||||||
|
emit overrideServerUrlChanged();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void Theme::setForceOverrideServerUrl(bool forceOverride)
|
||||||
|
{
|
||||||
|
if (_forceOverrideServerUrl != forceOverride) {
|
||||||
|
_forceOverrideServerUrl = forceOverride;
|
||||||
|
emit forceOverrideServerUrlChanged();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Theme::setStartLoginFlowAutomatically(bool startLoginFlowAuto)
|
||||||
|
{
|
||||||
|
if (_startLoginFlowAutomatically != startLoginFlowAuto) {
|
||||||
|
_startLoginFlowAutomatically = startLoginFlowAuto;
|
||||||
|
emit startLoginFlowAutomaticallyChanged();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // end namespace client
|
} // end namespace client
|
||||||
|
|
|
@ -55,8 +55,9 @@ class OWNCLOUDSYNC_EXPORT Theme : public QObject
|
||||||
Q_PROPERTY(QString version READ version CONSTANT)
|
Q_PROPERTY(QString version READ version CONSTANT)
|
||||||
Q_PROPERTY(QString helpUrl READ helpUrl CONSTANT)
|
Q_PROPERTY(QString helpUrl READ helpUrl CONSTANT)
|
||||||
Q_PROPERTY(QString conflictHelpUrl READ conflictHelpUrl CONSTANT)
|
Q_PROPERTY(QString conflictHelpUrl READ conflictHelpUrl CONSTANT)
|
||||||
Q_PROPERTY(QString overrideServerUrl READ overrideServerUrl CONSTANT)
|
Q_PROPERTY(QString overrideServerUrl READ overrideServerUrl WRITE setOverrideServerUrl NOTIFY overrideServerUrlChanged)
|
||||||
Q_PROPERTY(bool forceOverrideServerUrl READ forceOverrideServerUrl CONSTANT)
|
Q_PROPERTY(bool forceOverrideServerUrl READ forceOverrideServerUrl WRITE setForceOverrideServerUrl NOTIFY forceOverrideServerUrlChanged)
|
||||||
|
Q_PROPERTY(bool startLoginFlowAutomatically READ startLoginFlowAutomatically WRITE setStartLoginFlowAutomatically NOTIFY startLoginFlowAutomaticallyChanged)
|
||||||
#ifndef TOKEN_AUTH_ONLY
|
#ifndef TOKEN_AUTH_ONLY
|
||||||
Q_PROPERTY(QColor wizardHeaderTitleColor READ wizardHeaderTitleColor CONSTANT)
|
Q_PROPERTY(QColor wizardHeaderTitleColor READ wizardHeaderTitleColor CONSTANT)
|
||||||
Q_PROPERTY(QColor wizardHeaderBackgroundColor READ wizardHeaderBackgroundColor CONSTANT)
|
Q_PROPERTY(QColor wizardHeaderBackgroundColor READ wizardHeaderBackgroundColor CONSTANT)
|
||||||
|
@ -242,6 +243,13 @@ public:
|
||||||
*/
|
*/
|
||||||
virtual bool forceOverrideServerUrl() const;
|
virtual bool forceOverrideServerUrl() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Automatically start login flow
|
||||||
|
*
|
||||||
|
* When true, the browser will get opened automatically
|
||||||
|
*/
|
||||||
|
virtual bool startLoginFlowAutomatically() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enable OCSP stapling for SSL handshakes
|
* Enable OCSP stapling for SSL handshakes
|
||||||
*
|
*
|
||||||
|
@ -584,6 +592,11 @@ public:
|
||||||
QPalette systemPalette();
|
QPalette systemPalette();
|
||||||
bool darkMode();
|
bool darkMode();
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
virtual void setOverrideServerUrl(const QString &overrideServerUrl);
|
||||||
|
virtual void setForceOverrideServerUrl(bool forceOverride);
|
||||||
|
virtual void setStartLoginFlowAutomatically(bool startLoginFlowAuto);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
#ifndef TOKEN_AUTH_ONLY
|
#ifndef TOKEN_AUTH_ONLY
|
||||||
QIcon themeIcon(const QString &name, bool sysTray = false) const;
|
QIcon themeIcon(const QString &name, bool sysTray = false) const;
|
||||||
|
@ -602,6 +615,9 @@ signals:
|
||||||
void systrayUseMonoIconsChanged(bool);
|
void systrayUseMonoIconsChanged(bool);
|
||||||
void systemPaletteChanged(const QPalette &palette);
|
void systemPaletteChanged(const QPalette &palette);
|
||||||
void darkModeChanged();
|
void darkModeChanged();
|
||||||
|
void overrideServerUrlChanged();
|
||||||
|
void forceOverrideServerUrlChanged();
|
||||||
|
void startLoginFlowAutomaticallyChanged();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Theme(Theme const &);
|
Theme(Theme const &);
|
||||||
|
@ -616,6 +632,10 @@ private:
|
||||||
bool _mono = false;
|
bool _mono = false;
|
||||||
bool _paletteSignalsConnected = false;
|
bool _paletteSignalsConnected = false;
|
||||||
|
|
||||||
|
QString _overrideServerUrl;
|
||||||
|
bool _forceOverrideServerUrl = false;
|
||||||
|
bool _startLoginFlowAutomatically = false;
|
||||||
|
|
||||||
#ifndef TOKEN_AUTH_ONLY
|
#ifndef TOKEN_AUTH_ONLY
|
||||||
mutable QHash<QString, QIcon> _iconCache;
|
mutable QHash<QString, QIcon> _iconCache;
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue