UpdateChecker: Parse and forward the new "DownloadChecksum" entry from update info file.
This commit is contained in:
parent
4bc32e75c6
commit
2eac767ad2
@ -39,6 +39,7 @@ namespace MUtils
|
||||
public:
|
||||
UpdateCheckerInfo(void);
|
||||
void resetInfo(void);
|
||||
bool isComplete(void);
|
||||
|
||||
const quint32 &getBuildNo(void) const { return m_buildNo; }
|
||||
const QDate &getBuildDate(void) const { return m_buildDate; }
|
||||
@ -46,6 +47,7 @@ namespace MUtils
|
||||
const QString &getDownloadAddress(void) const { return m_downloadAddress; }
|
||||
const QString &getDownloadFilename(void) const { return m_downloadFilename; }
|
||||
const QString &getDownloadFilecode(void) const { return m_downloadFilecode; }
|
||||
const QString &getDownloadChecksum(void) const { return m_downloadChecksum; }
|
||||
|
||||
private:
|
||||
quint32 m_buildNo;
|
||||
@ -54,6 +56,7 @@ namespace MUtils
|
||||
QString m_downloadAddress;
|
||||
QString m_downloadFilename;
|
||||
QString m_downloadFilecode;
|
||||
QString m_downloadChecksum;
|
||||
};
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
@ -80,11 +83,11 @@ namespace MUtils
|
||||
UpdateChecker(const QString &binWGet, const QString &binGnuPG, const QString &binKeys, const QString &applicationId, const quint32 &installedBuildNo, const bool betaUpdates, const bool testMode = false);
|
||||
~UpdateChecker(void);
|
||||
|
||||
const int getUpdateStatus(void) const { return m_status; }
|
||||
const bool getSuccess(void) const { return m_success; };
|
||||
const int getMaximumProgress(void) const { return m_maxProgress; };
|
||||
const int getCurrentProgress(void) const { return m_progress; };
|
||||
const UpdateCheckerInfo *getUpdateInfo(void) const { return m_updateInfo; }
|
||||
const int getUpdateStatus(void) const { return m_status; }
|
||||
const bool getSuccess(void) const { return m_success; };
|
||||
const int getMaximumProgress(void) const { return m_maxProgress; };
|
||||
const int getCurrentProgress(void) const { return m_progress; };
|
||||
const UpdateCheckerInfo *getUpdateInfo(void) const { return m_updateInfo.data(); }
|
||||
|
||||
protected:
|
||||
void run(void);
|
||||
@ -98,7 +101,7 @@ namespace MUtils
|
||||
|
||||
private:
|
||||
const int m_maxProgress;
|
||||
UpdateCheckerInfo *const m_updateInfo;
|
||||
QScopedPointer<UpdateCheckerInfo> m_updateInfo;
|
||||
|
||||
const bool m_betaUpdates;
|
||||
const bool m_testMode;
|
||||
|
@ -207,6 +207,20 @@ void UpdateCheckerInfo::resetInfo(void)
|
||||
m_downloadAddress.clear();
|
||||
m_downloadFilename.clear();
|
||||
m_downloadFilecode.clear();
|
||||
m_downloadChecksum.clear();
|
||||
}
|
||||
|
||||
bool UpdateCheckerInfo::isComplete(void)
|
||||
{
|
||||
if(this->m_buildNo < 1) return false;
|
||||
if(this->m_buildDate.year() < 2010) return false;
|
||||
if(this->m_downloadSite.isEmpty()) return false;
|
||||
if(this->m_downloadAddress.isEmpty()) return false;
|
||||
if(this->m_downloadFilename.isEmpty()) return false;
|
||||
if(this->m_downloadFilecode.isEmpty()) return false;
|
||||
if(this->m_downloadChecksum.isEmpty()) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////
|
||||
@ -237,7 +251,6 @@ UpdateChecker::UpdateChecker(const QString &binWGet, const QString &binGnuPG, co
|
||||
|
||||
UpdateChecker::~UpdateChecker(void)
|
||||
{
|
||||
delete m_updateInfo;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////
|
||||
@ -340,7 +353,7 @@ void UpdateChecker::checkForUpdates(void)
|
||||
setProgress(m_progress + 1);
|
||||
if(!m_success)
|
||||
{
|
||||
if(tryUpdateMirror(m_updateInfo, currentMirror))
|
||||
if(tryUpdateMirror(m_updateInfo.data(), currentMirror))
|
||||
{
|
||||
m_success = true;
|
||||
}
|
||||
@ -669,12 +682,12 @@ bool UpdateChecker::parseVersionInfo(const QString &file, UpdateCheckerInfo *upd
|
||||
if(value.cap(1).compare("BuildNo", Qt::CaseInsensitive) == 0)
|
||||
{
|
||||
bool ok = false;
|
||||
unsigned int temp = value.cap(2).toUInt(&ok);
|
||||
const unsigned int temp = value.cap(2).toUInt(&ok);
|
||||
if(ok) updateInfo->m_buildNo = temp;
|
||||
}
|
||||
else if(value.cap(1).compare("BuildDate", Qt::CaseInsensitive) == 0)
|
||||
{
|
||||
QDate temp = QDate::fromString(value.cap(2).trimmed(), Qt::ISODate);
|
||||
const QDate temp = QDate::fromString(value.cap(2).trimmed(), Qt::ISODate);
|
||||
if(temp.isValid()) updateInfo->m_buildDate = temp;
|
||||
}
|
||||
else if(value.cap(1).compare("DownloadSite", Qt::CaseInsensitive) == 0)
|
||||
@ -693,6 +706,10 @@ bool UpdateChecker::parseVersionInfo(const QString &file, UpdateCheckerInfo *upd
|
||||
{
|
||||
updateInfo->m_downloadFilecode = value.cap(2).trimmed();
|
||||
}
|
||||
else if(value.cap(1).compare("DownloadChecksum", Qt::CaseInsensitive) == 0)
|
||||
{
|
||||
updateInfo->m_downloadChecksum = value.cap(2).trimmed();
|
||||
}
|
||||
}
|
||||
if(inHdr && (value.indexIn(line) >= 0))
|
||||
{
|
||||
@ -725,21 +742,13 @@ bool UpdateChecker::parseVersionInfo(const QString &file, UpdateCheckerInfo *upd
|
||||
qWarning("Version info is from the future, take care!");
|
||||
}
|
||||
|
||||
bool complete = true;
|
||||
|
||||
if(!(updateInfo->m_buildNo > 0)) complete = false;
|
||||
if(!(updateInfo->m_buildDate.year() >= 2010)) complete = false;
|
||||
if(updateInfo->m_downloadSite.isEmpty()) complete = false;
|
||||
if(updateInfo->m_downloadAddress.isEmpty()) complete = false;
|
||||
if(updateInfo->m_downloadFilename.isEmpty()) complete = false;
|
||||
if(updateInfo->m_downloadFilecode.isEmpty()) complete = false;
|
||||
|
||||
if(!complete)
|
||||
if(!updateInfo->isComplete())
|
||||
{
|
||||
log("WARNING: Version info is incomplete!");
|
||||
return false;
|
||||
}
|
||||
|
||||
return complete;
|
||||
return true;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////
|
||||
|
Loading…
Reference in New Issue
Block a user