| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // Copyright (C) 2020 Edouard Griffiths, F4EXB                                   //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // This program is free software; you can redistribute it and/or modify          //
 | 
					
						
							|  |  |  | // it under the terms of the GNU General Public License as published by          //
 | 
					
						
							|  |  |  | // the Free Software Foundation as version 3 of the License, or                  //
 | 
					
						
							|  |  |  | // (at your option) any later version.                                           //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful,               //
 | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of                //
 | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the                  //
 | 
					
						
							|  |  |  | // GNU General Public License V3 for more details.                               //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // You should have received a copy of the GNU General Public License             //
 | 
					
						
							|  |  |  | // along with this program. If not, see <http://www.gnu.org/licenses/>.          //
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <QDebug>
 | 
					
						
							|  |  |  | #include <QNetworkAccessManager>
 | 
					
						
							|  |  |  | #include <QNetworkReply>
 | 
					
						
							|  |  |  | #include <QBuffer>
 | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  | #include <QThread>
 | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "SWGFeatureSettings.h"
 | 
					
						
							|  |  |  | #include "SWGFeatureReport.h"
 | 
					
						
							|  |  |  | #include "SWGFeatureActions.h"
 | 
					
						
							|  |  |  | #include "SWGAFCReport.h"
 | 
					
						
							|  |  |  | #include "SWGDeviceState.h"
 | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | #include "SWGChannelSettings.h"
 | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "dsp/dspengine.h"
 | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | #include "device/deviceset.h"
 | 
					
						
							|  |  |  | #include "channel/channelapi.h"
 | 
					
						
							| 
									
										
										
										
											2022-01-09 05:27:12 +01:00
										 |  |  | #include "settings/serializable.h"
 | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | #include "maincore.h"
 | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "afcworker.h"
 | 
					
						
							|  |  |  | #include "afc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MESSAGE_CLASS_DEFINITION(AFC::MsgConfigureAFC, Message) | 
					
						
							|  |  |  | MESSAGE_CLASS_DEFINITION(AFC::MsgStartStop, Message) | 
					
						
							| 
									
										
										
										
											2020-10-24 10:35:07 +02:00
										 |  |  | MESSAGE_CLASS_DEFINITION(AFC::MsgDeviceTrack, Message) | 
					
						
							|  |  |  | MESSAGE_CLASS_DEFINITION(AFC::MsgDevicesApply, Message) | 
					
						
							| 
									
										
										
										
											2022-02-27 09:58:16 +01:00
										 |  |  | MESSAGE_CLASS_DEFINITION(AFC::MsgDeviceSetListsQuery, Message) | 
					
						
							|  |  |  | MESSAGE_CLASS_DEFINITION(AFC::MsgDeviceSetListsReport, Message) | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-21 20:24:18 +01:00
										 |  |  | const char* const AFC::m_featureIdURI = "sdrangel.feature.afc"; | 
					
						
							|  |  |  | const char* const AFC::m_featureId = "AFC"; | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | AFC::AFC(WebAPIAdapterInterface *webAPIAdapterInterface) : | 
					
						
							|  |  |  |     Feature(m_featureIdURI, webAPIAdapterInterface), | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |     m_thread(nullptr), | 
					
						
							|  |  |  |     m_running(false), | 
					
						
							| 
									
										
										
										
											2022-09-21 21:06:53 +02:00
										 |  |  |     m_worker(nullptr), | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |     m_trackerDeviceSet(nullptr), | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  |     m_trackedDeviceSet(nullptr), | 
					
						
							| 
									
										
										
										
											2020-10-26 21:39:34 +01:00
										 |  |  |     m_trackerIndexInDeviceSet(-1), | 
					
						
							|  |  |  |     m_trackerChannelAPI(nullptr) | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     setObjectName(m_featureId); | 
					
						
							|  |  |  |     m_state = StIdle; | 
					
						
							|  |  |  |     m_errorMessage = "AFC error"; | 
					
						
							| 
									
										
										
										
											2021-01-15 11:24:21 +00:00
										 |  |  |     m_networkManager = new QNetworkAccessManager(); | 
					
						
							| 
									
										
										
										
											2022-03-23 22:32:23 +01:00
										 |  |  |     QObject::connect( | 
					
						
							|  |  |  |         m_networkManager, | 
					
						
							|  |  |  |         &QNetworkAccessManager::finished, | 
					
						
							|  |  |  |         this, | 
					
						
							|  |  |  |         &AFC::networkManagerFinished | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | AFC::~AFC() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-03-23 22:32:23 +01:00
										 |  |  |     QObject::disconnect( | 
					
						
							|  |  |  |         m_networkManager, | 
					
						
							|  |  |  |         &QNetworkAccessManager::finished, | 
					
						
							|  |  |  |         this, | 
					
						
							|  |  |  |         &AFC::networkManagerFinished | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2021-01-15 11:24:21 +00:00
										 |  |  |     delete m_networkManager; | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |     stop(); | 
					
						
							| 
									
										
										
										
											2020-10-26 21:39:34 +01:00
										 |  |  |     removeTrackerFeatureReference(); | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  |     removeTrackedFeatureReferences(); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void AFC::start() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |     QMutexLocker m_lock(&m_mutex); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (m_running) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 	qDebug("AFC::start"); | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |     m_thread = new QThread(); | 
					
						
							|  |  |  |     m_worker = new AFCWorker(getWebAPIAdapterInterface()); | 
					
						
							|  |  |  |     m_worker->moveToThread(m_thread); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     QObject::connect( | 
					
						
							|  |  |  |         m_thread, | 
					
						
							|  |  |  |         &QThread::started, | 
					
						
							|  |  |  |         m_worker, | 
					
						
							|  |  |  |         &AFCWorker::startWork | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     QObject::connect( | 
					
						
							|  |  |  |         m_thread, | 
					
						
							|  |  |  |         &QThread::finished, | 
					
						
							|  |  |  |         m_worker, | 
					
						
							|  |  |  |         &QObject::deleteLater | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     QObject::connect( | 
					
						
							|  |  |  |         m_thread, | 
					
						
							|  |  |  |         &QThread::finished, | 
					
						
							|  |  |  |         m_thread, | 
					
						
							|  |  |  |         &QThread::deleteLater | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     m_worker->setMessageQueueToGUI(getMessageQueueToGUI()); | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |     m_thread->start(); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |     AFCWorker::MsgConfigureAFCWorker *msg = AFCWorker::MsgConfigureAFCWorker::create(m_settings, QList<QString>(), true); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     m_worker->getInputMessageQueue()->push(msg); | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     m_state = StRunning; | 
					
						
							|  |  |  |     m_running = true; | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void AFC::stop() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |     QMutexLocker m_lock(&m_mutex); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!m_running) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     qDebug("AFC::stop"); | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |     m_running = false; | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     m_state = StIdle; | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |     m_thread->quit(); | 
					
						
							|  |  |  |     m_thread->wait(); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool AFC::handleMessage(const Message& cmd) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (MsgConfigureAFC::match(cmd)) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  |         MsgConfigureAFC& cfg = (MsgConfigureAFC&) cmd; | 
					
						
							|  |  |  |         qDebug() << "AFC::handleMessage: MsgConfigureAFC"; | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |         applySettings(cfg.getSettings(), cfg.getSettingsKeys(), cfg.getForce()); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		return true; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |     else if (MsgStartStop::match(cmd)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MsgStartStop& cfg = (MsgStartStop&) cmd; | 
					
						
							|  |  |  |         qDebug() << "AFC::handleMessage: MsgStartStop: start:" << cfg.getStartStop(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (cfg.getStartStop()) { | 
					
						
							|  |  |  |             start(); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             stop(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-12-13 13:04:36 +01:00
										 |  |  |     else if (MainCore::MsgChannelSettings::match(cmd)) | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-12-13 13:04:36 +01:00
										 |  |  |         MainCore::MsgChannelSettings& cfg = (MainCore::MsgChannelSettings&) cmd; | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |         SWGSDRangel::SWGChannelSettings *swgChannelSettings = cfg.getSWGSettings(); | 
					
						
							|  |  |  |         QString *channelType  = swgChannelSettings->getChannelType(); | 
					
						
							| 
									
										
										
										
											2020-12-13 13:04:36 +01:00
										 |  |  |         qDebug() << "AFC::handleMessage: MainCore::MsgChannelSettings: " << *channelType; | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |         if (m_running) | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |         { | 
					
						
							|  |  |  |             m_worker->getInputMessageQueue()->push(&cfg); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             delete swgChannelSettings; | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-24 10:35:07 +02:00
										 |  |  |     else if (MsgDeviceTrack::match(cmd)) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |         if (m_running) | 
					
						
							| 
									
										
										
										
											2020-10-24 10:35:07 +02:00
										 |  |  |         { | 
					
						
							|  |  |  |             AFCWorker::MsgDeviceTrack *msg = AFCWorker::MsgDeviceTrack::create(); | 
					
						
							|  |  |  |             m_worker->getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if (MsgDevicesApply::match(cmd)) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-02-27 18:58:43 +01:00
										 |  |  |         qDebug("AFC::handleMessage: MsgDevicesApply"); | 
					
						
							| 
									
										
										
										
											2020-10-26 21:39:34 +01:00
										 |  |  |         removeTrackerFeatureReference(); | 
					
						
							|  |  |  |         trackerDeviceChange(m_settings.m_trackerDeviceSetIndex); | 
					
						
							|  |  |  |         removeTrackedFeatureReferences(); | 
					
						
							|  |  |  |         trackedDeviceChange(m_settings.m_trackedDeviceSetIndex); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |         if (m_running) | 
					
						
							| 
									
										
										
										
											2020-10-24 10:35:07 +02:00
										 |  |  |         { | 
					
						
							|  |  |  |             AFCWorker::MsgDevicesApply *msg = AFCWorker::MsgDevicesApply::create(); | 
					
						
							|  |  |  |             m_worker->getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-02-27 09:58:16 +01:00
										 |  |  |     else if (MsgDeviceSetListsQuery::match(cmd)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         qDebug("AFC::handleMessage: MsgDeviceSetListsQuery"); | 
					
						
							|  |  |  |         updateDeviceSetLists(); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | QByteArray AFC::serialize() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return m_settings.serialize(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool AFC::deserialize(const QByteArray& data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (m_settings.deserialize(data)) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |         MsgConfigureAFC *msg = MsgConfigureAFC::create(m_settings, QList<QString>(), true); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |         m_inputMessageQueue.push(msg); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         m_settings.resetToDefaults(); | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |         MsgConfigureAFC *msg = MsgConfigureAFC::create(m_settings, QList<QString>(), true); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |         m_inputMessageQueue.push(msg); | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  | void AFC::applySettings(const AFCSettings& settings, const QList<QString>& settingsKeys, bool force) | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |     qDebug() << "AFC::applySettings:" << settings.getDebugString(settingsKeys, force) << " force: " << force; | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |     if (settingsKeys.contains("trackerDeviceSetIndex") || force) | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-10-26 21:39:34 +01:00
										 |  |  |         removeTrackerFeatureReference(); | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |         trackerDeviceChange(settings.m_trackerDeviceSetIndex); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |     if (settingsKeys.contains("trackedDeviceSetIndex") || force) | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-10-26 21:39:34 +01:00
										 |  |  |         removeTrackedFeatureReferences(); | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |         trackedDeviceChange(settings.m_trackedDeviceSetIndex); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |     if (m_running) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         AFCWorker::MsgConfigureAFCWorker *msg = AFCWorker::MsgConfigureAFCWorker::create( | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |             settings, settingsKeys, force | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  |         ); | 
					
						
							|  |  |  |         m_worker->getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |     if (settingsKeys.contains("useReverseAPI")) | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         bool fullUpdate = (settingsKeys.contains("useReverseAPI") && settings.m_useReverseAPI) || | 
					
						
							|  |  |  |                 settingsKeys.contains("reverseAPIAddress") || | 
					
						
							|  |  |  |                 settingsKeys.contains("reverseAPIPort") || | 
					
						
							|  |  |  |                 settingsKeys.contains("reverseAPIFeatureSetIndex") || | 
					
						
							|  |  |  |                 settingsKeys.contains("m_reverseAPIFeatureIndex"); | 
					
						
							| 
									
										
										
										
											2022-11-20 19:54:13 +01:00
										 |  |  |         webapiReverseSendSettings(settingsKeys, settings, fullUpdate || force); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |     if (force) { | 
					
						
							|  |  |  |         m_settings = settings; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         m_settings.applySettings(settingsKeys, settings); | 
					
						
							| 
									
										
										
										
											2022-11-20 19:54:13 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-27 09:58:16 +01:00
										 |  |  | void AFC::updateDeviceSetLists() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     MainCore *mainCore = MainCore::instance(); | 
					
						
							|  |  |  |     std::vector<DeviceSet*>& deviceSets = mainCore->getDeviceSets(); | 
					
						
							|  |  |  |     std::vector<DeviceSet*>::const_iterator it = deviceSets.begin(); | 
					
						
							|  |  |  |     MsgDeviceSetListsReport *msg = MsgDeviceSetListsReport::create(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     unsigned int deviceIndex = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (; it != deviceSets.end(); ++it, deviceIndex++) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         DSPDeviceSourceEngine *deviceSourceEngine =  (*it)->m_deviceSourceEngine; | 
					
						
							|  |  |  |         DSPDeviceSinkEngine *deviceSinkEngine = (*it)->m_deviceSinkEngine; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (deviceSourceEngine) { | 
					
						
							|  |  |  |             msg->addTrackedDevice(deviceIndex, true); | 
					
						
							|  |  |  |         } else if (deviceSinkEngine) { | 
					
						
							|  |  |  |             msg->addTrackedDevice(deviceIndex, false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for (int chi = 0; chi < (*it)->getNumberOfChannels(); chi++) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             ChannelAPI *channel = (*it)->getChannelAt(chi); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (channel->getURI() == "sdrangel.channel.freqtracker") | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 msg->addTrackerDevice(deviceIndex, true); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (getMessageQueueToGUI()) { | 
					
						
							|  |  |  |         getMessageQueueToGUI()->push(msg); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | int AFC::webapiRun(bool run, | 
					
						
							|  |  |  |     SWGSDRangel::SWGDeviceState& response, | 
					
						
							|  |  |  |     QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-11-14 11:13:32 +01:00
										 |  |  |     (void) errorMessage; | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     getFeatureStateStr(*response.getState()); | 
					
						
							|  |  |  |     MsgStartStop *msg = MsgStartStop::create(run); | 
					
						
							|  |  |  |     getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |     return 202; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int AFC::webapiSettingsGet( | 
					
						
							|  |  |  |     SWGSDRangel::SWGFeatureSettings& response, | 
					
						
							|  |  |  |     QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     (void) errorMessage; | 
					
						
							|  |  |  |     response.setAfcSettings(new SWGSDRangel::SWGAFCSettings()); | 
					
						
							|  |  |  |     response.getAfcSettings()->init(); | 
					
						
							|  |  |  |     webapiFormatFeatureSettings(response, m_settings); | 
					
						
							|  |  |  |     return 200; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int AFC::webapiSettingsPutPatch( | 
					
						
							|  |  |  |     bool force, | 
					
						
							|  |  |  |     const QStringList& featureSettingsKeys, | 
					
						
							|  |  |  |     SWGSDRangel::SWGFeatureSettings& response, | 
					
						
							|  |  |  |     QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     (void) errorMessage; | 
					
						
							|  |  |  |     AFCSettings settings = m_settings; | 
					
						
							|  |  |  |     webapiUpdateFeatureSettings(settings, featureSettingsKeys, response); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |     MsgConfigureAFC *msg = MsgConfigureAFC::create(settings, featureSettingsKeys, force); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     m_inputMessageQueue.push(msg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     qDebug("AFC::webapiSettingsPutPatch: forward to GUI: %p", m_guiMessageQueue); | 
					
						
							|  |  |  |     if (m_guiMessageQueue) // forward to GUI if any
 | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  |         MsgConfigureAFC *msgToGUI = MsgConfigureAFC::create(settings, featureSettingsKeys, force); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |         m_guiMessageQueue->push(msgToGUI); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     webapiFormatFeatureSettings(response, settings); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return 200; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int AFC::webapiReportGet( | 
					
						
							|  |  |  |     SWGSDRangel::SWGFeatureReport& response, | 
					
						
							|  |  |  |     QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     (void) errorMessage; | 
					
						
							|  |  |  |     response.setAfcReport(new SWGSDRangel::SWGAFCReport()); | 
					
						
							|  |  |  |     response.getAfcReport()->init(); | 
					
						
							|  |  |  |     webapiFormatFeatureReport(response); | 
					
						
							|  |  |  |     return 200; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int AFC::webapiActionsPost( | 
					
						
							|  |  |  |     const QStringList& featureActionsKeys, | 
					
						
							|  |  |  |     SWGSDRangel::SWGFeatureActions& query, | 
					
						
							|  |  |  |     QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     SWGSDRangel::SWGAFCActions *swgAFCActions = query.getAfcActions(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (swgAFCActions) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-10-22 02:01:33 +02:00
										 |  |  |         bool unknownAction = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (featureActionsKeys.contains("run")) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             bool featureRun = swgAFCActions->getRun() != 0; | 
					
						
							|  |  |  |             unknownAction = false; | 
					
						
							|  |  |  |             MsgStartStop *msg = MsgStartStop::create(featureRun); | 
					
						
							|  |  |  |             getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  |         if (featureActionsKeys.contains("deviceTrack")) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             bool deviceTrack = swgAFCActions->getDeviceTrack() != 0; | 
					
						
							| 
									
										
										
										
											2021-10-22 02:01:33 +02:00
										 |  |  |             unknownAction = false; | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             if (deviceTrack) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 MsgDeviceTrack *msg = MsgDeviceTrack::create(); | 
					
						
							|  |  |  |                 getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (featureActionsKeys.contains("devicesApply")) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             bool devicesApply = swgAFCActions->getDevicesApply() != 0; | 
					
						
							| 
									
										
										
										
											2021-10-22 02:01:33 +02:00
										 |  |  |             unknownAction = false; | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             if (devicesApply) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 MsgDevicesApply *msg = MsgDevicesApply::create(); | 
					
						
							|  |  |  |                 getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-22 02:01:33 +02:00
										 |  |  |         if (unknownAction) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             errorMessage = "Unknown action"; | 
					
						
							|  |  |  |             return 400; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return 202; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         errorMessage = "Missing AFCActions in query"; | 
					
						
							|  |  |  |         return 400; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void AFC::webapiFormatFeatureSettings( | 
					
						
							|  |  |  |     SWGSDRangel::SWGFeatureSettings& response, | 
					
						
							|  |  |  |     const AFCSettings& settings) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (response.getAfcSettings()->getTitle()) { | 
					
						
							|  |  |  |         *response.getAfcSettings()->getTitle() = settings.m_title; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         response.getAfcSettings()->setTitle(new QString(settings.m_title)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     response.getAfcSettings()->setRgbColor(settings.m_rgbColor); | 
					
						
							| 
									
										
										
										
											2020-10-17 23:43:20 +02:00
										 |  |  |     response.getAfcSettings()->setTrackerDeviceSetIndex(settings.m_trackerDeviceSetIndex); | 
					
						
							|  |  |  |     response.getAfcSettings()->setTrackedDeviceSetIndex(settings.m_trackedDeviceSetIndex); | 
					
						
							|  |  |  |     response.getAfcSettings()->setHasTargetFrequency(settings.m_hasTargetFrequency); | 
					
						
							|  |  |  |     response.getAfcSettings()->setTransverterTarget(settings.m_transverterTarget); | 
					
						
							|  |  |  |     response.getAfcSettings()->setTargetFrequency(settings.m_targetFrequency); | 
					
						
							|  |  |  |     response.getAfcSettings()->setFreqTolerance(settings.m_freqTolerance); | 
					
						
							| 
									
										
										
										
											2020-10-25 11:34:47 +01:00
										 |  |  |     response.getAfcSettings()->setTrackerAdjustPeriod(settings.m_trackerAdjustPeriod); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     response.getAfcSettings()->setUseReverseApi(settings.m_useReverseAPI ? 1 : 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (response.getAfcSettings()->getReverseApiAddress()) { | 
					
						
							|  |  |  |         *response.getAfcSettings()->getReverseApiAddress() = settings.m_reverseAPIAddress; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         response.getAfcSettings()->setReverseApiAddress(new QString(settings.m_reverseAPIAddress)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     response.getAfcSettings()->setReverseApiPort(settings.m_reverseAPIPort); | 
					
						
							| 
									
										
										
										
											2021-09-17 00:52:08 +02:00
										 |  |  |     response.getAfcSettings()->setReverseApiFeatureSetIndex(settings.m_reverseAPIFeatureSetIndex); | 
					
						
							|  |  |  |     response.getAfcSettings()->setReverseApiFeatureIndex(settings.m_reverseAPIFeatureIndex); | 
					
						
							| 
									
										
										
										
											2022-01-09 05:27:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (settings.m_rollupState) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (response.getAfcSettings()->getRollupState()) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             settings.m_rollupState->formatTo(response.getAfcSettings()->getRollupState()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             SWGSDRangel::SWGRollupState *swgRollupState = new SWGSDRangel::SWGRollupState(); | 
					
						
							|  |  |  |             settings.m_rollupState->formatTo(swgRollupState); | 
					
						
							|  |  |  |             response.getAfcSettings()->setRollupState(swgRollupState); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void AFC::webapiUpdateFeatureSettings( | 
					
						
							|  |  |  |     AFCSettings& settings, | 
					
						
							|  |  |  |     const QStringList& featureSettingsKeys, | 
					
						
							|  |  |  |     SWGSDRangel::SWGFeatureSettings& response) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (featureSettingsKeys.contains("title")) { | 
					
						
							|  |  |  |         settings.m_title = *response.getAfcSettings()->getTitle(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (featureSettingsKeys.contains("rgbColor")) { | 
					
						
							|  |  |  |         settings.m_rgbColor = response.getAfcSettings()->getRgbColor(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-17 23:43:20 +02:00
										 |  |  |     if (featureSettingsKeys.contains("trackerDeviceSetIndex")) { | 
					
						
							|  |  |  |         settings.m_trackerDeviceSetIndex = response.getAfcSettings()->getTrackerDeviceSetIndex(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (featureSettingsKeys.contains("trackedDeviceSetIndex")) { | 
					
						
							|  |  |  |         settings.m_trackedDeviceSetIndex = response.getAfcSettings()->getTrackedDeviceSetIndex(); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-17 23:43:20 +02:00
										 |  |  |     if (featureSettingsKeys.contains("hasTargetFrequency")) { | 
					
						
							|  |  |  |         settings.m_hasTargetFrequency = response.getAfcSettings()->getHasTargetFrequency() != 0; | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-17 23:43:20 +02:00
										 |  |  |     if (featureSettingsKeys.contains("hasTargetFrequency")) { | 
					
						
							|  |  |  |         settings.m_hasTargetFrequency = response.getAfcSettings()->getHasTargetFrequency() != 0; | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-17 23:43:20 +02:00
										 |  |  |     if (featureSettingsKeys.contains("targetFrequency")) { | 
					
						
							|  |  |  |         settings.m_targetFrequency = response.getAfcSettings()->getTargetFrequency(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (featureSettingsKeys.contains("freqTolerance")) { | 
					
						
							|  |  |  |         settings.m_freqTolerance = response.getAfcSettings()->getFreqTolerance(); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-25 11:34:47 +01:00
										 |  |  |     if (featureSettingsKeys.contains("trackerAdjustPeriod")) { | 
					
						
							|  |  |  |         settings.m_trackerAdjustPeriod = response.getAfcSettings()->getTrackerAdjustPeriod(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     if (featureSettingsKeys.contains("useReverseAPI")) { | 
					
						
							|  |  |  |         settings.m_useReverseAPI = response.getAfcSettings()->getUseReverseApi() != 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (featureSettingsKeys.contains("reverseAPIAddress")) { | 
					
						
							|  |  |  |         settings.m_reverseAPIAddress = *response.getAfcSettings()->getReverseApiAddress(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (featureSettingsKeys.contains("reverseAPIPort")) { | 
					
						
							|  |  |  |         settings.m_reverseAPIPort = response.getAfcSettings()->getReverseApiPort(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-09-17 00:52:08 +02:00
										 |  |  |     if (featureSettingsKeys.contains("reverseAPIFeatureSetIndex")) { | 
					
						
							|  |  |  |         settings.m_reverseAPIFeatureSetIndex = response.getAfcSettings()->getReverseApiFeatureSetIndex(); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-09-17 00:52:08 +02:00
										 |  |  |     if (featureSettingsKeys.contains("reverseAPIFeatureIndex")) { | 
					
						
							|  |  |  |         settings.m_reverseAPIFeatureIndex = response.getAfcSettings()->getReverseApiFeatureIndex(); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-01-09 05:27:12 +01:00
										 |  |  |     if (settings.m_rollupState && featureSettingsKeys.contains("rollupState")) { | 
					
						
							|  |  |  |         settings.m_rollupState->updateFrom(featureSettingsKeys, response.getAfcSettings()->getRollupState()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void AFC::webapiFormatFeatureReport(SWGSDRangel::SWGFeatureReport& response) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  |     response.getAfcReport()->setTrackerChannelIndex(m_trackerIndexInDeviceSet); | 
					
						
							| 
									
										
										
										
											2021-10-23 21:24:25 +02:00
										 |  |  |     response.getAfcReport()->setRunningState(getState()); | 
					
						
							| 
									
										
										
										
											2022-09-21 06:01:45 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (m_running) { | 
					
						
							|  |  |  |         response.getAfcReport()->setTrackerDeviceFrequency(m_worker->getTrackerDeviceFrequency()); | 
					
						
							|  |  |  |         response.getAfcReport()->setTrackerChannelOffset(m_worker->getTrackerChannelOffset()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-19 23:30:49 +01:00
										 |  |  | void AFC::webapiReverseSendSettings(const QList<QString>& channelSettingsKeys, const AFCSettings& settings, bool force) | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     SWGSDRangel::SWGFeatureSettings *swgFeatureSettings = new SWGSDRangel::SWGFeatureSettings(); | 
					
						
							|  |  |  |     // swgFeatureSettings->setOriginatorFeatureIndex(getIndexInDeviceSet());
 | 
					
						
							|  |  |  |     // swgFeatureSettings->setOriginatorFeatureSetIndex(getDeviceSetIndex());
 | 
					
						
							|  |  |  |     swgFeatureSettings->setFeatureType(new QString("AFC")); | 
					
						
							|  |  |  |     swgFeatureSettings->setAfcSettings(new SWGSDRangel::SWGAFCSettings()); | 
					
						
							|  |  |  |     SWGSDRangel::SWGAFCSettings *swgAFCSettings = swgFeatureSettings->getAfcSettings(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // transfer data that has been modified. When force is on transfer all data except reverse API data
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("title") || force) { | 
					
						
							|  |  |  |         swgAFCSettings->setTitle(new QString(settings.m_title)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("rgbColor") || force) { | 
					
						
							|  |  |  |         swgAFCSettings->setRgbColor(settings.m_rgbColor); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-17 23:43:20 +02:00
										 |  |  |     if (channelSettingsKeys.contains("trackerDeviceSetIndex") || force) { | 
					
						
							|  |  |  |         swgAFCSettings->setTrackerDeviceSetIndex(settings.m_trackerDeviceSetIndex); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("trackedDeviceSetIndex") || force) { | 
					
						
							|  |  |  |         swgAFCSettings->setTrackedDeviceSetIndex(settings.m_trackedDeviceSetIndex); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("hasTargetFrequency") || force) { | 
					
						
							|  |  |  |         swgAFCSettings->setHasTargetFrequency(settings.m_hasTargetFrequency ? 1 : 0); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-17 23:43:20 +02:00
										 |  |  |     if (channelSettingsKeys.contains("targetFrequency") || force) { | 
					
						
							|  |  |  |         swgAFCSettings->setTargetFrequency(settings.m_targetFrequency ? 1 : 0); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-17 23:43:20 +02:00
										 |  |  |     if (channelSettingsKeys.contains("targetFrequency") || force) { | 
					
						
							|  |  |  |         swgAFCSettings->setTargetFrequency(settings.m_targetFrequency); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-17 23:43:20 +02:00
										 |  |  |     if (channelSettingsKeys.contains("freqTolerance") || force) { | 
					
						
							|  |  |  |         swgAFCSettings->setFreqTolerance(settings.m_freqTolerance); | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-25 11:34:47 +01:00
										 |  |  |     if (channelSettingsKeys.contains("trackerAdjustPeriod") || force) { | 
					
						
							|  |  |  |         swgAFCSettings->setTrackerAdjustPeriod(settings.m_trackerAdjustPeriod); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-16 19:20:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     QString channelSettingsURL = QString("http://%1:%2/sdrangel/featureset/%3/feature/%4/settings") | 
					
						
							|  |  |  |             .arg(settings.m_reverseAPIAddress) | 
					
						
							|  |  |  |             .arg(settings.m_reverseAPIPort) | 
					
						
							|  |  |  |             .arg(settings.m_reverseAPIFeatureSetIndex) | 
					
						
							|  |  |  |             .arg(settings.m_reverseAPIFeatureIndex); | 
					
						
							|  |  |  |     m_networkRequest.setUrl(QUrl(channelSettingsURL)); | 
					
						
							|  |  |  |     m_networkRequest.setHeader(QNetworkRequest::ContentTypeHeader, "application/json"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     QBuffer *buffer = new QBuffer(); | 
					
						
							|  |  |  |     buffer->open((QBuffer::ReadWrite)); | 
					
						
							|  |  |  |     buffer->write(swgFeatureSettings->asJson().toUtf8()); | 
					
						
							|  |  |  |     buffer->seek(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Always use PATCH to avoid passing reverse API settings
 | 
					
						
							|  |  |  |     QNetworkReply *reply = m_networkManager->sendCustomRequest(m_networkRequest, "PATCH", buffer); | 
					
						
							|  |  |  |     buffer->setParent(reply); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     delete swgFeatureSettings; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void AFC::networkManagerFinished(QNetworkReply *reply) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     QNetworkReply::NetworkError replyError = reply->error(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (replyError) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         qWarning() << "AFC::networkManagerFinished:" | 
					
						
							|  |  |  |                 << " error(" << (int) replyError | 
					
						
							|  |  |  |                 << "): " << replyError | 
					
						
							|  |  |  |                 << ": " << reply->errorString(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         QString answer = reply->readAll(); | 
					
						
							|  |  |  |         answer.chop(1); // remove last \n
 | 
					
						
							|  |  |  |         qDebug("AFC::networkManagerFinished: reply:\n%s", answer.toStdString().c_str()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     reply->deleteLater(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | void AFC::trackerDeviceChange(int deviceIndex) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-02-27 18:58:43 +01:00
										 |  |  |     qDebug("AFC::trackerDeviceChange: deviceIndex: %d", deviceIndex); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-27 09:58:16 +01:00
										 |  |  |     if (deviceIndex < 0) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |     MainCore *mainCore = MainCore::instance(); | 
					
						
							|  |  |  |     m_trackerDeviceSet = mainCore->getDeviceSets()[deviceIndex]; | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  |     m_trackerChannelAPI = nullptr; | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (int i = 0; i < m_trackerDeviceSet->getNumberOfChannels(); i++) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         ChannelAPI *channel = m_trackerDeviceSet->getChannelAt(i); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (channel->getURI() == "sdrangel.channel.freqtracker") | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2022-03-02 23:57:35 +01:00
										 |  |  |             ObjectPipe *pipe = mainCore->getMessagePipes().registerProducerToConsumer(channel, this, "settings"); | 
					
						
							| 
									
										
										
										
											2022-02-27 19:26:18 +01:00
										 |  |  |             MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (messageQueue) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 QObject::connect( | 
					
						
							|  |  |  |                     messageQueue, | 
					
						
							|  |  |  |                     &MessageQueue::messageEnqueued, | 
					
						
							|  |  |  |                     this, | 
					
						
							|  |  |  |                     [=](){ this->handleChannelMessageQueue(messageQueue); }, | 
					
						
							|  |  |  |                     Qt::QueuedConnection | 
					
						
							|  |  |  |                 ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  |             connect(pipe, SIGNAL(toBeDeleted(int, QObject*)), this, SLOT(handleTrackerMessagePipeToBeDeleted(int, QObject*))); | 
					
						
							| 
									
										
										
										
											2020-10-26 21:39:34 +01:00
										 |  |  |             m_trackerChannelAPI = channel; | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |             break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  | void AFC::handleTrackerMessagePipeToBeDeleted(int reason, QObject* object) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if ((reason == 0) && ((ChannelAPI*) object == m_trackerChannelAPI))  // tracker channel has been de;eted
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         m_trackerChannelAPI = nullptr; | 
					
						
							|  |  |  |         updateDeviceSetLists(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | void AFC::trackedDeviceChange(int deviceIndex) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-02-27 18:58:43 +01:00
										 |  |  |     qDebug("AFC::trackedDeviceChange: deviceIndex: %d", deviceIndex); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-27 09:58:16 +01:00
										 |  |  |     if (deviceIndex < 0) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |     MainCore *mainCore = MainCore::instance(); | 
					
						
							|  |  |  |     m_trackedDeviceSet = mainCore->getDeviceSets()[deviceIndex]; | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  |     m_trackerIndexInDeviceSet = -1; | 
					
						
							|  |  |  |     m_trackedChannelAPIs.clear(); | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (int i = 0; i < m_trackedDeviceSet->getNumberOfChannels(); i++) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         ChannelAPI *channel = m_trackedDeviceSet->getChannelAt(i); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  |         if (channel->getURI() != "sdrangel.channel.freqtracker") | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2022-03-02 23:57:35 +01:00
										 |  |  |             ObjectPipe *pipe = mainCore->getMessagePipes().registerProducerToConsumer(channel, this, "settings"); | 
					
						
							| 
									
										
										
										
											2022-02-27 19:26:18 +01:00
										 |  |  |             MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (messageQueue) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 QObject::connect( | 
					
						
							|  |  |  |                     messageQueue, | 
					
						
							|  |  |  |                     &MessageQueue::messageEnqueued, | 
					
						
							|  |  |  |                     this, | 
					
						
							|  |  |  |                     [=](){ this->handleChannelMessageQueue(messageQueue); }, | 
					
						
							|  |  |  |                     Qt::QueuedConnection | 
					
						
							|  |  |  |                 ); | 
					
						
							|  |  |  |                 m_trackerIndexInDeviceSet = i; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             m_trackedChannelAPIs.push_back(channel); | 
					
						
							|  |  |  |             connect(pipe, SIGNAL(toBeDeleted(int, QObject*)), this, SLOT(handleTrackedMessagePipeToBeDeleted(int, QObject*))); | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  | void AFC::handleTrackedMessagePipeToBeDeleted(int reason, QObject* object) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if ((reason == 0) && m_trackedChannelAPIs.contains((ChannelAPI*) object)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         m_trackedChannelAPIs.removeAll((ChannelAPI*) object); | 
					
						
							|  |  |  |         updateDeviceSetLists(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-26 21:39:34 +01:00
										 |  |  | void AFC::removeTrackerFeatureReference() | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-10-26 21:39:34 +01:00
										 |  |  |     if (m_trackerChannelAPI) | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-03-02 23:57:35 +01:00
										 |  |  |         ObjectPipe *pipe = MainCore::instance()->getMessagePipes().unregisterProducerToConsumer(m_trackerChannelAPI, this, "settings"); | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (pipe) | 
					
						
							| 
									
										
										
										
											2020-12-20 01:53:03 +01:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2022-02-27 19:26:18 +01:00
										 |  |  |             MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (messageQueue) { | 
					
						
							| 
									
										
										
										
											2023-04-02 05:04:18 +02:00
										 |  |  |                 disconnect(messageQueue, &MessageQueue::messageEnqueued, this, nullptr);  // Have to use nullptr, as slot is a lambda.
 | 
					
						
							| 
									
										
										
										
											2022-02-27 19:26:18 +01:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         m_trackerChannelAPI = nullptr; | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-26 13:48:19 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void AFC::removeTrackedFeatureReferences() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  |     for (auto& channel : m_trackedChannelAPIs) | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-03-02 23:57:35 +01:00
										 |  |  |         ObjectPipe *pipe = MainCore::instance()->getMessagePipes().unregisterProducerToConsumer(channel, this, "settings"); | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  |         if (pipe) | 
					
						
							| 
									
										
										
										
											2022-02-27 18:58:43 +01:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  |             MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (messageQueue) { | 
					
						
							| 
									
										
										
										
											2023-04-02 05:04:18 +02:00
										 |  |  |                 disconnect(messageQueue, &MessageQueue::messageEnqueued, this, nullptr);  // Have to use nullptr, as slot is a lambda.
 | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-10-26 21:39:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-02 06:58:54 +01:00
										 |  |  |         m_trackedChannelAPIs.removeAll(channel); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-22 08:38:43 +02:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2020-12-13 13:04:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | void AFC::handleChannelMessageQueue(MessageQueue* messageQueue) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     Message* message; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while ((message = messageQueue->pop()) != nullptr) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (handleMessage(*message)) { | 
					
						
							|  |  |  |             delete message; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |