2016-05-28 19:54:17 +02:00
|
|
|
#include "MetaCacheSink.h"
|
|
|
|
#include <QFile>
|
|
|
|
#include <QFileInfo>
|
|
|
|
#include "Env.h"
|
|
|
|
#include "FileSystem.h"
|
|
|
|
|
|
|
|
namespace Net {
|
|
|
|
|
|
|
|
MetaCacheSink::MetaCacheSink(MetaEntryPtr entry, ChecksumValidator * md5sum)
|
2018-07-15 14:51:05 +02:00
|
|
|
:Net::FileSink(entry->getFullPath()), m_entry(entry), m_md5Node(md5sum)
|
2016-05-28 19:54:17 +02:00
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
addValidator(md5sum);
|
2018-06-28 23:18:45 +02:00
|
|
|
}
|
2016-05-28 19:54:17 +02:00
|
|
|
|
|
|
|
MetaCacheSink::~MetaCacheSink()
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
// nil
|
2018-06-28 23:18:45 +02:00
|
|
|
}
|
2016-05-28 19:54:17 +02:00
|
|
|
|
2017-05-03 23:11:52 +02:00
|
|
|
JobStatus MetaCacheSink::initCache(QNetworkRequest& request)
|
2016-05-28 19:54:17 +02:00
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
if (!m_entry->isStale())
|
|
|
|
{
|
|
|
|
return Job_Finished;
|
|
|
|
}
|
|
|
|
// check if file exists, if it does, use its information for the request
|
|
|
|
QFile current(m_filename);
|
|
|
|
if(current.exists() && current.size() != 0)
|
|
|
|
{
|
|
|
|
if (m_entry->getRemoteChangedTimestamp().size())
|
|
|
|
{
|
|
|
|
request.setRawHeader(QString("If-Modified-Since").toLatin1(), m_entry->getRemoteChangedTimestamp().toLatin1());
|
|
|
|
}
|
|
|
|
if (m_entry->getETag().size())
|
|
|
|
{
|
|
|
|
request.setRawHeader(QString("If-None-Match").toLatin1(), m_entry->getETag().toLatin1());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return Job_InProgress;
|
2016-05-28 19:54:17 +02:00
|
|
|
}
|
|
|
|
|
2017-05-03 23:11:52 +02:00
|
|
|
JobStatus MetaCacheSink::finalizeCache(QNetworkReply & reply)
|
2016-05-28 19:54:17 +02:00
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
QFileInfo output_file_info(m_filename);
|
|
|
|
if(wroteAnyData)
|
|
|
|
{
|
|
|
|
m_entry->setMD5Sum(m_md5Node->hash().toHex().constData());
|
|
|
|
}
|
|
|
|
m_entry->setETag(reply.rawHeader("ETag").constData());
|
|
|
|
if (reply.hasRawHeader("Last-Modified"))
|
|
|
|
{
|
|
|
|
m_entry->setRemoteChangedTimestamp(reply.rawHeader("Last-Modified").constData());
|
|
|
|
}
|
|
|
|
m_entry->setLocalChangedTimestamp(output_file_info.lastModified().toUTC().toMSecsSinceEpoch());
|
|
|
|
m_entry->setStale(false);
|
|
|
|
ENV.metacache()->updateEntry(m_entry);
|
|
|
|
return Job_Finished;
|
2016-05-28 19:54:17 +02:00
|
|
|
}
|
2016-10-28 02:19:19 +02:00
|
|
|
|
|
|
|
bool MetaCacheSink::hasLocalData()
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
QFileInfo info(m_filename);
|
|
|
|
return info.exists() && info.size() != 0;
|
2016-10-28 02:19:19 +02:00
|
|
|
}
|
2016-05-28 19:54:17 +02:00
|
|
|
}
|