mirror of
https://github.com/MultiMC/MultiMC5.git
synced 2025-01-25 09:35:18 +00:00
98 lines
3.1 KiB
C++
98 lines
3.1 KiB
C++
/* Copyright 2013-2019 MultiMC Contributors
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "tasks/Task.h"
|
|
#include "net/NetJob.h"
|
|
#include "GoUpdate.h"
|
|
|
|
#include "multimc_logic_export.h"
|
|
|
|
namespace GoUpdate
|
|
{
|
|
/*!
|
|
* The DownloadTask is a task that takes a given version ID and repository URL,
|
|
* downloads that version's files from the repository, and prepares to install them.
|
|
*/
|
|
class MULTIMC_LOGIC_EXPORT DownloadTask : public Task
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/**
|
|
* Create a download task
|
|
*
|
|
* target is a template - XXXXXX at the end will be replaced with a random generated string, ensuring uniqueness
|
|
*/
|
|
explicit DownloadTask(Status status, QString target, QObject* parent = 0);
|
|
virtual ~DownloadTask() {};
|
|
|
|
/// Get the directory that will contain the update files.
|
|
QString updateFilesDir();
|
|
|
|
/// Get the list of operations that should be done
|
|
OperationList operations();
|
|
|
|
/// set updater download behavior
|
|
void setUseLocalUpdater(bool useLocal);
|
|
|
|
protected:
|
|
//! Entry point for tasks.
|
|
virtual void executeTask() override;
|
|
|
|
/*!
|
|
* Downloads the version info files from the repository.
|
|
* The files for both the current build, and the build that we're updating to need to be downloaded.
|
|
* If the current version's info file can't be found, MultiMC will not delete files that
|
|
* were removed between versions. It will still replace files that have changed, however.
|
|
* Note that although the repository URL for the current version is not given to the update task,
|
|
* the task will attempt to look it up in the UpdateChecker's channel list.
|
|
* If an error occurs here, the function will call emitFailed and return false.
|
|
*/
|
|
void loadVersionInfo();
|
|
|
|
NetJobPtr m_vinfoNetJob;
|
|
QByteArray currentVersionFileListData;
|
|
QByteArray newVersionFileListData;
|
|
Net::Download::Ptr m_currentVersionFileListDownload;
|
|
Net::Download::Ptr m_newVersionFileListDownload;
|
|
|
|
NetJobPtr m_filesNetJob;
|
|
|
|
Status m_status;
|
|
|
|
OperationList m_operations;
|
|
|
|
/*!
|
|
* Temporary directory to store update files in.
|
|
* This will be set to not auto delete. Task will fail if this fails to be created.
|
|
*/
|
|
QTemporaryDir m_updateFilesDir;
|
|
|
|
protected slots:
|
|
/*!
|
|
* This function is called when version information is finished downloading
|
|
* and at least the new file list download succeeded
|
|
*/
|
|
void processDownloadedVersionInfo();
|
|
void vinfoDownloadFailed();
|
|
|
|
void fileDownloadFinished();
|
|
void fileDownloadFailed(QString reason);
|
|
void fileDownloadProgressChanged(qint64 current, qint64 total);
|
|
};
|
|
|
|
} |