summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--qt-ui/mainwindow.cpp2
-rw-r--r--qt-ui/updatemanager.cpp59
-rw-r--r--qt-ui/updatemanager.h5
3 files changed, 56 insertions, 10 deletions
diff --git a/qt-ui/mainwindow.cpp b/qt-ui/mainwindow.cpp
index c578cb3d1..3ce038ba0 100644
--- a/qt-ui/mainwindow.cpp
+++ b/qt-ui/mainwindow.cpp
@@ -64,7 +64,6 @@ MainWindow::MainWindow() : QMainWindow(),
actionPreviousDive(0),
helpView(0),
state(VIEWALL),
- updateManager(0),
survey(0)
{
Q_ASSERT_X(m_Instance == NULL, "MainWindow", "MainWindow recreated!");
@@ -136,6 +135,7 @@ MainWindow::MainWindow() : QMainWindow(),
QLayoutItem *p = ui.gridLayout->takeAt(0);
ui.gridLayout->addWidget(toolBar, 0, 0);
ui.gridLayout->addItem(p, 0, 1);
+ updateManager = new UpdateManager(this);
}
MainWindow::~MainWindow()
diff --git a/qt-ui/updatemanager.cpp b/qt-ui/updatemanager.cpp
index 6a02578b5..b6e8dc47a 100644
--- a/qt-ui/updatemanager.cpp
+++ b/qt-ui/updatemanager.cpp
@@ -2,14 +2,31 @@
#include "usersurvey.h"
#include <QtNetwork>
#include <QMessageBox>
+#include <QDateTime>
#include "subsurfacewebservices.h"
#include "ssrf-version.h"
+#include "mainwindow.h"
UpdateManager::UpdateManager(QObject *parent) : QObject(parent)
{
+ // is this the first time this version was run?
+ QSettings settings;
+ settings.beginGroup("UpdateManager");
+ if (settings.contains("LastVersionUsed") && settings.value("LastVersionUsed").toString() == GIT_VERSION_STRING) {
+ // this is the version we've been using
+ QString nextCheckString = settings.value("NextCheck").toString();
+ QDateTime nextCheck = QDateTime::fromString(nextCheckString, Qt::ISODate);
+ if (nextCheck > QDateTime::currentDateTime())
+ return;
+ }
+ settings.setValue("LastVersionUsed", QString(GIT_VERSION_STRING));
+ if (settings.contains("DontCheckForUpdates") && settings.value("DontCheckForUpdates") == "TRUE")
+ return;
+ checkForUpdates(true);
+ settings.setValue("NextCheck", QDateTime::currentDateTime().addDays(14).toString(Qt::ISODate));
}
-void UpdateManager::checkForUpdates()
+void UpdateManager::checkForUpdates(bool automatic)
{
QString os;
@@ -22,7 +39,8 @@ void UpdateManager::checkForUpdates()
#else
os = "unknown";
#endif
-
+ qDebug() << "checking for update";
+ isAutomaticCheck = automatic;
QString version = CANONICAL_VERSION_STRING;
QString url = QString("http://subsurface-divelog.org/updatecheck.html?os=%1&version=%2").arg(os, version);
QNetworkRequest request;
@@ -35,6 +53,7 @@ void UpdateManager::checkForUpdates()
void UpdateManager::requestReceived()
{
+ bool haveNewVersion = false;
QMessageBox msgbox;
QString msgTitle = tr("Check for updates.");
QString msgText = "<h3>" + tr("Subsurface was unable to check for updates.") + "</h3>";
@@ -58,11 +77,13 @@ void UpdateManager::requestReceived()
if (responseBody == "OK") {
msgText = tr("You are using the latest version of Subsurface.");
} else if (responseBody.startsWith("http")) {
+ haveNewVersion = true;
msgText = tr("A new version of Subsurface is available.<br/>Click on:<br/><a href=\"%1\">%1</a><br/> to download it.")
.arg(responseBody);
} else if (responseBody.startsWith("Latest version")) {
// the webservice backend doesn't localize - but it's easy enough to just replace the
// strings that it is likely to send back
+ haveNewVersion = true;
responseBody.replace("Latest version is ", "");
responseBody.replace(". please check with your OS vendor for updates.", "");
msgText = QString("<b>") + tr("A new version of Subsurface is available.") + QString("</b><br/><br/>") +
@@ -71,16 +92,38 @@ void UpdateManager::requestReceived()
} else {
// the webservice backend doesn't localize - but it's easy enough to just replace the
// strings that it is likely to send back
+ haveNewVersion = true;
if (responseBody.contains("Newest release version is "))
responseBody.replace("Newest release version is ", tr("Newest release version is "));
msgText = tr("The server returned the following information:").append("<br/><br/>").append(responseBody);
msgbox.setIcon(QMessageBox::Warning);
}
}
-
- msgbox.setWindowTitle(msgTitle);
- msgbox.setWindowIcon(QIcon(":/subsurface-icon"));
- msgbox.setText(msgText);
- msgbox.setTextFormat(Qt::RichText);
- msgbox.exec();
+ if (haveNewVersion || !isAutomaticCheck) {
+ msgbox.setWindowTitle(msgTitle);
+ msgbox.setWindowIcon(QIcon(":/subsurface-icon"));
+ msgbox.setText(msgText);
+ msgbox.setTextFormat(Qt::RichText);
+ msgbox.exec();
+ }
+ if (isAutomaticCheck) {
+ QSettings settings;
+ settings.beginGroup("UpdateManager");
+ if (!settings.contains("DontCheckForUpdates")) {
+ // we allow an opt out of future checks
+ QMessageBox response(MainWindow::instance());
+ QString message = tr("Subsurface is checking every two weeks if a new version is available. If you don't want Subsurface to continue checking, please click Decline.");
+ response.addButton(tr("Decline"), QMessageBox::RejectRole);
+ response.addButton(tr("Accept"), QMessageBox::AcceptRole);
+ response.setText(message);
+ response.setWindowTitle(tr("Automatic check for updates"));
+ response.setIcon(QMessageBox::Question);
+ response.setWindowModality(Qt::WindowModal);
+ int ret = response.exec();
+ if (ret == QMessageBox::Accepted)
+ settings.setValue("DontCheckForUpdates", "FALSE");
+ else
+ settings.setValue("DontCheckForUpdates", "TRUE");
+ }
+ }
}
diff --git a/qt-ui/updatemanager.h b/qt-ui/updatemanager.h
index 98b84021d..4e95d740f 100644
--- a/qt-ui/updatemanager.h
+++ b/qt-ui/updatemanager.h
@@ -10,11 +10,14 @@ class UpdateManager : public QObject {
Q_OBJECT
public:
explicit UpdateManager(QObject *parent = 0);
- void checkForUpdates();
+ void checkForUpdates(bool automatic = false);
public
slots:
void requestReceived();
+
+private:
+ bool isAutomaticCheck;
};
#endif // UPDATEMANAGER_H