| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | #ifndef MESSAGE_CLIENT_HPP__
 | 
					
						
							|  |  |  | #define MESSAGE_CLIENT_HPP__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <QObject>
 | 
					
						
							|  |  |  | #include <QTime>
 | 
					
						
							|  |  |  | #include <QDateTime>
 | 
					
						
							|  |  |  | #include <QString>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Radio.hpp"
 | 
					
						
							|  |  |  | #include "pimpl_h.hpp"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 22:01:40 +00:00
										 |  |  | class QByteArray; | 
					
						
							|  |  |  | class QHostAddress; | 
					
						
							| 
									
										
										
										
											2018-03-28 22:25:46 +00:00
										 |  |  | class QColor; | 
					
						
							| 
									
										
										
										
											2015-06-18 22:01:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | //
 | 
					
						
							|  |  |  | // MessageClient - Manage messages sent and replies received from a
 | 
					
						
							| 
									
										
										
										
											2015-11-15 23:03:11 +00:00
										 |  |  | //                 matching server (MessageServer) at the other end of
 | 
					
						
							|  |  |  | //                 the wire
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | //
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // Each outgoing message type is a Qt slot
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | class MessageClient | 
					
						
							|  |  |  |   : public QObject | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Q_OBJECT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |   using Frequency = Radio::Frequency; | 
					
						
							|  |  |  |   using port_type = quint16; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // instantiate and initiate a host lookup on the server
 | 
					
						
							|  |  |  |   //
 | 
					
						
							|  |  |  |   // messages will be silently dropped until a server host lookup is complete
 | 
					
						
							| 
									
										
										
										
											2016-12-04 00:55:15 +00:00
										 |  |  |   MessageClient (QString const& id, QString const& version, QString const& revision, | 
					
						
							|  |  |  |                  QString const& server, port_type server_port, QObject * parent = nullptr); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // query server details
 | 
					
						
							|  |  |  |   QHostAddress server_address () const; | 
					
						
							|  |  |  |   port_type server_port () const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // initiate a new server host lookup or is the server name is empty
 | 
					
						
							|  |  |  |   // the sending of messages is disabled
 | 
					
						
							|  |  |  |   Q_SLOT void set_server (QString const& server = QString {}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // change the server port messages are sent to
 | 
					
						
							|  |  |  |   Q_SLOT void set_server_port (port_type server_port = 0u); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |   // enable incoming messages
 | 
					
						
							|  |  |  |   Q_SLOT void enable (bool); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   // outgoing messages
 | 
					
						
							|  |  |  |   Q_SLOT void status_update (Frequency, QString const& mode, QString const& dx_call, QString const& report | 
					
						
							| 
									
										
										
										
											2016-05-24 10:08:35 +00:00
										 |  |  |                              , QString const& tx_mode, bool tx_enabled, bool transmitting, bool decoding | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |                              , quint32 rx_df, quint32 tx_df, QString const& de_call, QString const& de_grid | 
					
						
							| 
									
										
										
										
											2016-12-16 19:36:21 +00:00
										 |  |  |                              , QString const& dx_grid, bool watchdog_timeout, QString const& sub_mode | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |                              , bool fast_mode, quint8 special_op_mode, quint32 frequency_tolerance | 
					
						
							|  |  |  |                              , quint32 tr_period, QString const& configuration_name); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   Q_SLOT void decode (bool is_new, QTime time, qint32 snr, float delta_time, quint32 delta_frequency | 
					
						
							| 
									
										
										
										
											2017-09-16 22:20:59 +00:00
										 |  |  |                       , QString const& mode, QString const& message, bool low_confidence | 
					
						
							|  |  |  |                       , bool off_air); | 
					
						
							| 
									
										
										
										
											2015-11-15 23:03:11 +00:00
										 |  |  |   Q_SLOT void WSPR_decode (bool is_new, 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); | 
					
						
							| 
									
										
										
										
											2019-02-03 00:49:35 +00:00
										 |  |  |   Q_SLOT void decodes_cleared (); | 
					
						
							| 
									
										
										
										
											2017-09-16 22:20:59 +00:00
										 |  |  |   Q_SLOT void qso_logged (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-25 19:58:47 +02:00
										 |  |  |                           , QString const& exchange_sent, QString const& exchange_rcvd | 
					
						
							|  |  |  |                           , QString const& propmode); | 
					
						
							| 
									
										
										
										
											2018-02-04 22:42:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // ADIF_record argument should be valid ADIF excluding any <EOR> end
 | 
					
						
							|  |  |  |   // of record marker
 | 
					
						
							|  |  |  |   Q_SLOT void logged_ADIF (QByteArray const& ADIF_record); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-12 19:11:43 +00:00
										 |  |  |   // this may be used to send arbitrary UDP datagrams to and
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   // destination allowing the underlying socket to be used for general
 | 
					
						
							|  |  |  |   // UDP messaging if desired
 | 
					
						
							| 
									
										
										
										
											2018-11-12 19:11:43 +00:00
										 |  |  |   qint64 send_raw_datagram (QByteArray const&, QHostAddress const& dest_address, port_type dest_port); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-17 22:44:05 +00:00
										 |  |  |   // disallowed message destination (does not block datagrams sent
 | 
					
						
							|  |  |  |   // with send_raw_datagram() above)
 | 
					
						
							|  |  |  |   Q_SLOT void add_blocked_destination (QHostAddress const&); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-03 00:49:35 +00:00
										 |  |  |   // this signal is emitted if the server has requested a decode
 | 
					
						
							|  |  |  |   // window clear action
 | 
					
						
							|  |  |  |   Q_SIGNAL void clear_decodes (quint8 window); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   // this signal is emitted if the server sends us a reply, the only
 | 
					
						
							|  |  |  |   // reply supported is reply to a prior CQ or QRZ message
 | 
					
						
							|  |  |  |   Q_SIGNAL void reply (QTime, qint32 snr, float delta_time, quint32 delta_frequency, QString const& mode | 
					
						
							| 
									
										
										
										
											2017-09-22 15:36:24 +00:00
										 |  |  |                        , QString const& message_text, bool low_confidence, quint8 modifiers); | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |   // this signal is emitted if the server has requested this client to
 | 
					
						
							|  |  |  |   // close down gracefully
 | 
					
						
							|  |  |  |   Q_SIGNAL void close (); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  |   // this signal is emitted if the server has requested a replay of
 | 
					
						
							|  |  |  |   // all decodes
 | 
					
						
							|  |  |  |   Q_SIGNAL void replay (); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-06 22:25:56 +00:00
										 |  |  |   // this signal is emitted if the server has requested immediate (or
 | 
					
						
							|  |  |  |   // auto Tx if auto_only is true) transmission to halt
 | 
					
						
							|  |  |  |   Q_SIGNAL void halt_tx (bool auto_only); | 
					
						
							| 
									
										
										
										
											2015-05-06 20:30:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // this signal is emitted if the server has requested a new free
 | 
					
						
							|  |  |  |   // message text
 | 
					
						
							| 
									
										
										
										
											2015-05-28 17:33:39 +00:00
										 |  |  |   Q_SIGNAL void free_text (QString const&, bool send); | 
					
						
							| 
									
										
										
										
											2015-05-06 20:30:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-28 22:25:46 +00:00
										 |  |  |   // this signal is emitted if the server has sent a highlight
 | 
					
						
							|  |  |  |   // callsign request for the specified call
 | 
					
						
							|  |  |  |   Q_SIGNAL void highlight_callsign (QString const& callsign, QColor const& bg, QColor const& fg, bool last_only); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |   // this signal is emitted if the server has requested a
 | 
					
						
							|  |  |  |   // configuration switch
 | 
					
						
							| 
									
										
										
										
											2019-06-13 01:44:28 +01:00
										 |  |  |   Q_SIGNAL void switch_configuration (QString const& configuration_name); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-25 14:35:58 +01:00
										 |  |  |   // this signal is emitted if the server has requested a
 | 
					
						
							|  |  |  |   // configuration change
 | 
					
						
							|  |  |  |   Q_SIGNAL void configure (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
										 |  |  |   // this signal is emitted when network errors occur or if a host
 | 
					
						
							|  |  |  |   // lookup fails
 | 
					
						
							|  |  |  |   Q_SIGNAL void error (QString const&) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 22:42:35 +00:00
										 |  |  |   // this signal is emitted if the message obtains a location from a
 | 
					
						
							|  |  |  |   // server.  (It doesn't have to be new, could be a periodic location
 | 
					
						
							|  |  |  |   // update)
 | 
					
						
							|  |  |  |   Q_SIGNAL void location (QString const&); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 16:40:49 +00:00
										 |  |  | private: | 
					
						
							|  |  |  |   class impl; | 
					
						
							|  |  |  |   pimpl<impl> m_; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |