summaryrefslogtreecommitdiffstats
path: root/api/logic/updater/UpdateChecker.h
blob: 4996da262ee594e235ee305dc42a3b8a68fe4fb9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/* Copyright 2013-2018 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 "net/NetJob.h"
#include "GoUpdate.h"

#include "multimc_logic_export.h"

class MULTIMC_LOGIC_EXPORT UpdateChecker : public QObject
{
	Q_OBJECT

public:
	UpdateChecker(QString channelListUrl, QString currentChannel, int currentBuild);
	void checkForUpdate(QString updateChannel, bool notifyNoUpdate);

	/*!
	 * Causes the update checker to download the channel list from the URL specified in config.h (generated by CMake).
	 * If this isn't called before checkForUpdate(), it will automatically be called.
	 */
	void updateChanList(bool notifyNoUpdate);

	/*!
	 * An entry in the channel list.
	 */
	struct ChannelListEntry
	{
		QString id;
		QString name;
		QString description;
		QString url;
	};

	/*!
	 * Returns a the current channel list.
	 * If the channel list hasn't been loaded, this list will be empty.
	 */
	QList<ChannelListEntry> getChannelList() const;

	/*!
	 * Returns false if the channel list is empty.
	 */
	bool hasChannels() const;

signals:
	//! Signal emitted when an update is available. Passes the URL for the repo and the ID and name for the version.
	void updateAvailable(GoUpdate::Status status);

	//! Signal emitted when the channel list finishes loading or fails to load.
	void channelListLoaded();

	void noUpdateFound();

private slots:
	void updateCheckFinished(bool notifyNoUpdate);
	void updateCheckFailed();

	void chanListDownloadFinished(bool notifyNoUpdate);
	void chanListDownloadFailed(QString reason);

private:
	friend class UpdateCheckerTest;

	NetJobPtr indexJob;
	QByteArray indexData;
	NetJobPtr chanListJob;
	QByteArray chanlistData;

	QString m_channelListUrl;

	QList<ChannelListEntry> m_channels;

	/*!
	 * True while the system is checking for updates.
	 * If checkForUpdate is called while this is true, it will be ignored.
	 */
	bool m_updateChecking = false;

	/*!
	 * True if the channel list has loaded.
	 * If this is false, trying to check for updates will call updateChanList first.
	 */
	bool m_chanListLoaded = false;

	/*!
	 * Set to true while the channel list is currently loading.
	 */
	bool m_chanListLoading = false;

	/*!
	 * Set to true when checkForUpdate is called while the channel list isn't loaded.
	 * When the channel list finishes loading, if this is true, the update checker will check for updates.
	 */
	bool m_checkUpdateWaiting = false;

	/*!
	 * if m_checkUpdateWaiting, this is the last used update channel
	 */
	QString m_deferredUpdateChannel;

	int m_currentBuild = -1;
	QString m_currentChannel;
	QString m_currentRepoUrl;

	QString m_newRepoUrl;
};