122 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* Copyright 2013-2021 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"
 | |
| 
 | |
| class UpdateChecker : public QObject
 | |
| {
 | |
|     Q_OBJECT
 | |
| 
 | |
| public:
 | |
|     UpdateChecker(shared_qobject_ptr<QNetworkAccessManager> nam, QString channelUrl, 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;
 | |
| 
 | |
|     shared_qobject_ptr<QNetworkAccessManager> m_network;
 | |
| 
 | |
|     NetJob::Ptr indexJob;
 | |
|     QByteArray indexData;
 | |
|     NetJob::Ptr chanListJob;
 | |
|     QByteArray chanlistData;
 | |
| 
 | |
|     QString m_channelUrl;
 | |
| 
 | |
|     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;
 | |
| };
 | |
| 
 |