mirror of
https://github.com/qTox/qTox.git
synced 2024-03-22 14:00:36 +08:00
Better checks before applying update
Check that each file was downloaded and that the size matches. We don't check the signatures inside qTox so as not to freeze the GUI during startup. The updater will check the signatures anyway We now try to restart update downloads if we detect that it was interrupted
This commit is contained in:
parent
8813d6e4ca
commit
56e9f6f1be
|
@ -370,7 +370,7 @@ bool AutoUpdater::isLocalUpdateReady()
|
||||||
if (!updateDir.exists())
|
if (!updateDir.exists())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// Check that we have a flist and that every file on the diff exists
|
// Check that we have a flist and generate a diff
|
||||||
QFile updateFlistFile(updateDirStr+"flist");
|
QFile updateFlistFile(updateDirStr+"flist");
|
||||||
if (!updateFlistFile.open(QIODevice::ReadOnly))
|
if (!updateFlistFile.open(QIODevice::ReadOnly))
|
||||||
return false;
|
return false;
|
||||||
|
@ -380,9 +380,23 @@ bool AutoUpdater::isLocalUpdateReady()
|
||||||
QList<UpdateFileMeta> updateFlist = parseFlist(updateFlistData);
|
QList<UpdateFileMeta> updateFlist = parseFlist(updateFlistData);
|
||||||
QList<UpdateFileMeta> diff = genUpdateDiff(updateFlist);
|
QList<UpdateFileMeta> diff = genUpdateDiff(updateFlist);
|
||||||
|
|
||||||
|
// If the update wasn't downloaded correctly, redownload it
|
||||||
|
// We don't check signatures to not block qTox too long, the updater will do it anyway
|
||||||
for (UpdateFileMeta fileMeta : diff)
|
for (UpdateFileMeta fileMeta : diff)
|
||||||
|
{
|
||||||
if (!QFile::exists(updateDirStr+fileMeta.installpath))
|
if (!QFile::exists(updateDirStr+fileMeta.installpath))
|
||||||
|
{
|
||||||
|
QtConcurrent::run(&AutoUpdater::downloadUpdate);
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
QFile f(updateDirStr+fileMeta.installpath);
|
||||||
|
if (f.size() != (int64_t)fileMeta.size)
|
||||||
|
{
|
||||||
|
QtConcurrent::run(&AutoUpdater::downloadUpdate);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,9 +78,9 @@ public:
|
||||||
/// Will try to download an update, if successful returns true and qTox will apply it after a restart
|
/// Will try to download an update, if successful returns true and qTox will apply it after a restart
|
||||||
/// Will try to follow qTox's proxy settings, may block and processEvents
|
/// Will try to follow qTox's proxy settings, may block and processEvents
|
||||||
static bool downloadUpdate();
|
static bool downloadUpdate();
|
||||||
/// Returns true if an update is downloaded and ready to be installed
|
/// Returns true if an update is downloaded and ready to be installed,
|
||||||
/// If so, call installLocalUpdate. If not, call downloadUpdate.
|
/// if so, call installLocalUpdate.
|
||||||
/// This only checks that we downloaded an update and didn't stop in the middle, not that every file is still valid
|
/// If an update was partially downloaded, the function will resume asynchronously and return false
|
||||||
static bool isLocalUpdateReady();
|
static bool isLocalUpdateReady();
|
||||||
/// Launches the qTox updater to try to install the local update and exits immediately
|
/// Launches the qTox updater to try to install the local update and exits immediately
|
||||||
/// Will not check that the update actually exists, use isLocalUpdateReady first for that
|
/// Will not check that the update actually exists, use isLocalUpdateReady first for that
|
||||||
|
|
Loading…
Reference in New Issue
Block a user