| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							| 
									
										
										
										
											2023-11-18 10:07:41 +01:00
										 |  |  | // Copyright (C) 2012 maintech GmbH, Otto-Hahn-Str. 15, 97204 Hoechberg, Germany //
 | 
					
						
							|  |  |  | // written by Christian Daniel                                                   //
 | 
					
						
							|  |  |  | // Copyright (C) 2014 John Greb <hexameron@spam.no>                              //
 | 
					
						
							|  |  |  | // Copyright (C) 2015-2019, 2022-2023 Edouard Griffiths, F4EXB <f4exb06@gmail.com> //
 | 
					
						
							|  |  |  | // Copyright (C) 2019 Vort <vvort@yandex.ru>                                     //
 | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // 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/>.          //
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _AARONIARTSA_AARONIARTSAWORKER_H_
 | 
					
						
							|  |  |  | #define _AARONIARTSA_AARONIARTSAWORKER_H_
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <QTimer>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "dsp/samplesinkfifo.h"
 | 
					
						
							|  |  |  | #include "util/message.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <QProcess>
 | 
					
						
							|  |  |  | #include <QNetworkAccessManager>
 | 
					
						
							|  |  |  | #include <QNetworkReply>
 | 
					
						
							|  |  |  | #include <QTimer>
 | 
					
						
							|  |  |  | #include <QJsonDocument>
 | 
					
						
							|  |  |  | #include <QObject>
 | 
					
						
							|  |  |  | #include "dsp/decimatorsfi.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class MessageQueue; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-24 18:26:26 +01:00
										 |  |  | class AaroniaRTSAInputWorker : public QObject { | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 	Q_OBJECT | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2023-03-19 13:25:06 +01:00
										 |  |  | 	class MsgReportSampleRateAndFrequency : public Message { | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 		MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	public: | 
					
						
							|  |  |  | 		int getSampleRate() const { return m_sampleRate; } | 
					
						
							| 
									
										
										
										
											2023-03-19 13:25:06 +01:00
										 |  |  |         quint64 getCenterFrequency() const { return m_centerFrequency; } | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-19 13:25:06 +01:00
										 |  |  | 		static MsgReportSampleRateAndFrequency* create(int sampleRate, quint64 centerFrequency) { | 
					
						
							|  |  |  | 			return new MsgReportSampleRateAndFrequency(sampleRate, centerFrequency); | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	private: | 
					
						
							|  |  |  | 		int m_sampleRate; | 
					
						
							| 
									
										
										
										
											2023-03-19 13:25:06 +01:00
										 |  |  |         quint64 m_centerFrequency; | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-19 13:25:06 +01:00
										 |  |  | 		MsgReportSampleRateAndFrequency(int sampleRate, qint64 centerFrequency) : | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 			Message(), | 
					
						
							| 
									
										
										
										
											2023-03-19 13:25:06 +01:00
										 |  |  | 			m_sampleRate(sampleRate), | 
					
						
							|  |  |  |             m_centerFrequency(centerFrequency) | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 		{ } | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-24 18:26:26 +01:00
										 |  |  | 	AaroniaRTSAInputWorker(SampleSinkFifo* sampleFifo); | 
					
						
							|  |  |  |     ~AaroniaRTSAInputWorker(); | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  |     int getStatus() const { return m_status; } | 
					
						
							|  |  |  |     void setInputMessageQueue(MessageQueue *messageQueue) { m_inputMessageQueue = messageQueue; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  | 	QTimer m_timer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	SampleVector m_samplesBuf; | 
					
						
							|  |  |  | 	SampleSinkFifo* m_sampleFifo; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	QString m_serverAddress; | 
					
						
							| 
									
										
										
										
											2023-03-19 13:25:06 +01:00
										 |  |  | 	quint64 m_centerFrequency; | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  |     int m_sampleRate; | 
					
						
							|  |  |  |     MessageQueue *m_inputMessageQueue; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     int m_status; //!< See GUI for status number detail
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-23 01:30:12 +01:00
										 |  |  | 	void sendCenterFrequencyAndSampleRate(); | 
					
						
							|  |  |  |     void getConfig(); | 
					
						
							|  |  |  |     void parseConfig(QByteArray bytes); | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-23 01:30:12 +01:00
										 |  |  | 	// QT htttp clients
 | 
					
						
							|  |  |  | 	QNetworkAccessManager *m_networkAccessManager; | 
					
						
							|  |  |  | 	QNetworkAccessManager *m_networkAccessManagerConfig; | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 	// Reply from the HTTP server
 | 
					
						
							| 
									
										
										
										
											2023-03-22 17:57:21 +01:00
										 |  |  | 	QNetworkReply *mReply; | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 	// Input buffer
 | 
					
						
							| 
									
										
										
										
											2023-03-22 17:57:21 +01:00
										 |  |  | 	QByteArray mBuffer; | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 	// Number of IQ sample pairs in the current packet
 | 
					
						
							| 
									
										
										
										
											2023-03-22 17:57:21 +01:00
										 |  |  | 	int mPacketSamples; | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 	// Previous sample end time to check for packet loss
 | 
					
						
							| 
									
										
										
										
											2023-03-22 17:57:21 +01:00
										 |  |  | 	double mPrevTime; | 
					
						
							| 
									
										
										
										
											2023-03-23 01:30:12 +01:00
										 |  |  |     // Current iQ demodulator name
 | 
					
						
							|  |  |  |     QString m_iqDemodName; | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 	//Decimators<qint32, float, SDR_RX_SAMP_SZ, 32, true> m_decimatorsIQ;
 | 
					
						
							|  |  |  | 	DecimatorsFI<true> m_decimatorsFloatIQ; | 
					
						
							|  |  |  | 	SampleVector m_convertBuffer; | 
					
						
							|  |  |  | 	//void workIQ(unsigned int n_items);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | signals: | 
					
						
							|  |  |  | 	void updateStatus(int status); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | public slots: | 
					
						
							|  |  |  | 	void onCenterFrequencyChanged(quint64 centerFrequency); | 
					
						
							| 
									
										
										
										
											2023-03-24 07:57:09 +01:00
										 |  |  |     void onSampleRateChanged(int sampleRate); | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  | 	void onServerAddressChanged(QString serverAddress); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private slots: | 
					
						
							|  |  |  | 	void onSocketError(QAbstractSocket::SocketError error); | 
					
						
							|  |  |  | 	void onError(QNetworkReply::NetworkError code); | 
					
						
							|  |  |  | 	void onFinished(void); | 
					
						
							|  |  |  | 	void onReadyRead(void); | 
					
						
							| 
									
										
										
										
											2023-03-23 01:30:12 +01:00
										 |  |  |     void handleConfigReply(QNetworkReply* reply); | 
					
						
							| 
									
										
										
										
											2023-03-18 12:48:21 +01:00
										 |  |  |     void tick(); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // _AARONIARTSA_AARONIARTSAWORKER_H_
 |