| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | #ifndef MESSAGE_SERVER_HPP__
 | 
					
						
							|  |  |  | #define MESSAGE_SERVER_HPP__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <QObject>
 | 
					
						
							|  |  |  | #include <QTime>
 | 
					
						
							|  |  |  | #include <QDateTime>
 | 
					
						
							|  |  |  | #include <QHostAddress>
 | 
					
						
							| 
									
										
										
										
											2018-03-28 22:25:46 +00:00
										 |  |  | #include <QColor>
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-24 10:08:35 +00:00
										 |  |  | #include "udp_export.h"
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | #include "Radio.hpp"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "pimpl_h.hpp"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 22:01:40 +00:00
										 |  |  | class QString; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | //
 | 
					
						
							|  |  |  | // MessageServer - a reference implementation of a message server
 | 
					
						
							|  |  |  | //                  matching the MessageClient class at the other end
 | 
					
						
							|  |  |  | //                  of the wire
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // This class is fully functioning and suitable for use in C++
 | 
					
						
							|  |  |  | // applications that use the Qt framework. Other applications should
 | 
					
						
							|  |  |  | // use this classes' implementation as a reference implementation.
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2016-05-24 10:08:35 +00:00
										 |  |  | class UDP_EXPORT MessageServer | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   : public QObject | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Q_OBJECT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |   using port_type = quint16; | 
					
						
							|  |  |  |   using Frequency = Radio::Frequency; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-04 00:55:15 +00:00
										 |  |  |   MessageServer (QObject * parent = nullptr, | 
					
						
							|  |  |  |                  QString const& version = QString {}, QString const& revision = QString {}); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // start or restart the server, if the multicast_group_address
 | 
					
						
							|  |  |  |   // argument is given it is assumed to be a multicast group address
 | 
					
						
							|  |  |  |   // which the server will join
 | 
					
						
							| 
									
										
										
										
											2016-12-04 00:55:15 +00:00
										 |  |  |   Q_SLOT void start (port_type port, | 
					
						
							|  |  |  |                      QHostAddress const& multicast_group_address = QHostAddress {}); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-03 00:49:35 +00:00
										 |  |  |   // ask the client to clear one or both of the decode windows
 | 
					
						
							|  |  |  |   Q_SLOT void clear_decodes (QString const& id, quint8 window = 0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   // ask the client with identification 'id' to make the same action
 | 
					
						
							|  |  |  |   // as a double click on the decode would
 | 
					
						
							|  |  |  |   //
 | 
					
						
							|  |  |  |   // note that the client is not obliged to take any action and only
 | 
					
						
							|  |  |  |   // takes any action if the decode is present and is a CQ or QRZ message
 | 
					
						
							|  |  |  |   Q_SLOT void reply (QString const& id, QTime time, qint32 snr, float delta_time, quint32 delta_frequency | 
					
						
							| 
									
										
										
										
											2017-09-22 15:36:24 +00:00
										 |  |  |                      , QString const& mode, QString const& message, bool low_confidence, quint8 modifiers); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |   // ask the client with identification 'id' to close down gracefully
 | 
					
						
							|  |  |  |   Q_SLOT void close (QString const& id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   // ask the client with identification 'id' to replay all decodes
 | 
					
						
							|  |  |  |   Q_SLOT void replay (QString const& id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-06 22:25:56 +00:00
										 |  |  |   // ask the client with identification 'id' to halt transmitting
 | 
					
						
							|  |  |  |   // auto_only just disables auto Tx, otherwise halt is immediate
 | 
					
						
							|  |  |  |   Q_SLOT void halt_tx (QString const& id, bool auto_only); | 
					
						
							| 
									
										
										
										
											2015-05-06 20:30:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-28 17:33:39 +00:00
										 |  |  |   // ask the client with identification 'id' to set the free text
 | 
					
						
							|  |  |  |   // message and optionally send it ASAP
 | 
					
						
							|  |  |  |   Q_SLOT void free_text (QString const& id, QString const& text, bool send); | 
					
						
							| 
									
										
										
										
											2015-05-06 20:30:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 22:42:35 +00:00
										 |  |  |   // ask the client with identification 'id' to set the location provided
 | 
					
						
							|  |  |  |   Q_SLOT void location (QString const& id, QString const& location); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-28 22:25:46 +00:00
										 |  |  |   // ask the client with identification 'id' to highlight the callsign
 | 
					
						
							|  |  |  |   // specified with the given colors
 | 
					
						
							|  |  |  |   Q_SLOT void highlight_callsign (QString const& id, QString const& callsign | 
					
						
							|  |  |  |                                   , QColor const& bg = QColor {}, QColor const& fg = QColor {} | 
					
						
							|  |  |  |                                   , bool last_only = false); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |   // ask the client with identification 'id' to switch to
 | 
					
						
							|  |  |  |   // configuration 'configuration_name'
 | 
					
						
							| 
									
										
										
										
											2019-06-13 01:44:28 +01:00
										 |  |  |   Q_SLOT void switch_configuration (QString const& id, QString const& configuration_name); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |   // ask the client with identification 'id' to change configuration
 | 
					
						
							|  |  |  |   Q_SLOT void configure (QString const& id, QString const& mode, quint32 frequency_tolerance | 
					
						
							|  |  |  |                          , QString const& submode, bool fast_mode, quint32 tr_period, quint32 rx_df | 
					
						
							|  |  |  |                          , QString const& dx_call, QString const& dx_grid, bool generate_messages); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   // the following signals are emitted when a client broadcasts the
 | 
					
						
							|  |  |  |   // matching message
 | 
					
						
							| 
									
										
										
										
											2016-12-04 00:55:15 +00:00
										 |  |  |   Q_SIGNAL void client_opened (QString const& id, QString const& version, QString const& revision); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   Q_SIGNAL void status_update (QString const& id, Frequency, QString const& mode, QString const& dx_call | 
					
						
							| 
									
										
										
										
											2015-11-13 15:44:11 +00:00
										 |  |  |                                , QString const& report, QString const& tx_mode, bool tx_enabled | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |                                , bool transmitting, bool decoding, quint32 rx_df, quint32 tx_df | 
					
						
							| 
									
										
										
										
											2016-07-08 10:25:21 +00:00
										 |  |  |                                , QString const& de_call, QString const& de_grid, QString const& dx_grid | 
					
						
							| 
									
										
										
										
											2018-12-02 23:19:08 +00:00
										 |  |  |                                , bool watchdog_timeout, QString const& sub_mode, bool fast_mode | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |                                , quint8 special_op_mode, quint32 frequency_tolerance, quint32 tr_period | 
					
						
							|  |  |  |                                , QString const& configuration_name); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   Q_SIGNAL void client_closed (QString const& id); | 
					
						
							|  |  |  |   Q_SIGNAL void decode (bool is_new, QString const& id, QTime time, qint32 snr, float delta_time | 
					
						
							| 
									
										
										
										
											2017-07-26 21:18:59 +00:00
										 |  |  |                         , quint32 delta_frequency, QString const& mode, QString const& message | 
					
						
							| 
									
										
										
										
											2017-09-16 22:20:59 +00:00
										 |  |  |                         , bool low_confidence, bool off_air); | 
					
						
							| 
									
										
										
										
											2015-11-15 23:03:11 +00:00
										 |  |  |   Q_SIGNAL void WSPR_decode (bool is_new, QString const& id, QTime time, qint32 snr, float delta_time, Frequency | 
					
						
							| 
									
										
										
										
											2017-09-16 22:20:59 +00:00
										 |  |  |                              , qint32 drift, QString const& callsign, QString const& grid, qint32 power | 
					
						
							|  |  |  |                              , bool off_air); | 
					
						
							|  |  |  |   Q_SIGNAL void qso_logged (QString const& id, QDateTime time_off, QString const& dx_call, QString const& dx_grid | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |                             , Frequency dial_frequency, QString const& mode, QString const& report_sent | 
					
						
							|  |  |  |                             , QString const& report_received, QString const& tx_power, QString const& comments | 
					
						
							| 
									
										
										
										
											2018-02-04 22:42:35 +00:00
										 |  |  |                             , QString const& name, QDateTime time_on, QString const& operator_call | 
					
						
							| 
									
										
										
										
											2018-12-02 10:09:37 -05:00
										 |  |  |                             , QString const& my_call, QString const& my_grid | 
					
						
							| 
									
										
										
										
											2020-06-27 00:17:03 +02:00
										 |  |  |                             , QString const& exchange_sent, QString const& exchange_rcvd, QString const& prop_mode); | 
					
						
							| 
									
										
										
										
											2019-02-03 00:49:35 +00:00
										 |  |  |   Q_SIGNAL void decodes_cleared (QString const& id); | 
					
						
							| 
									
										
										
										
											2018-02-04 22:42:35 +00:00
										 |  |  |   Q_SIGNAL void logged_ADIF (QString const& id, QByteArray const& ADIF); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // this signal is emitted when a network error occurs
 | 
					
						
							|  |  |  |   Q_SIGNAL void error (QString const&) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2016-05-24 10:08:35 +00:00
										 |  |  |   class UDP_NO_EXPORT impl; | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   pimpl<impl> m_; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |