/////////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2023 Jon Beniston, M7RCE // // // // 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 . // /////////////////////////////////////////////////////////////////////////////////// #ifndef INCLUDE_GOESXRAY_H #define INCLUDE_GOESXRAY_H #include #include #include #include "export.h" class QNetworkAccessManager; class QNetworkReply; // GOES X-Ray data // This gets 1-minute averages of solar X-rays the 1-8 Angstrom (0.1-0.8 nm) and 0.5-4.0 Angstrom (0.05-0.4 nm) passbands from the GOES satellites // https://www.swpc.noaa.gov/products/goes-x-ray-flux // There are primary and secondary data sources, from different satellites, as sometimes they can be in eclipse // Also gets Proton flux (Which may be observed on Earth a couple of days after a large flare/CME) class SDRBASE_API GOESXRay : public QObject { Q_OBJECT protected: GOESXRay(); public: struct XRayData { QDateTime m_dateTime; QString m_satellite; double m_flux; enum Band { UNKNOWN, SHORT, // 0.05-0.4nm LONG // 0.1-0.8nm } m_band; XRayData() : m_flux(NAN), m_band(UNKNOWN) { } }; struct ProtonData { QDateTime m_dateTime; QString m_satellite; double m_flux; int m_energy; // 10=10MeV, 50MeV, 100MeV, 500MeV ProtonData() : m_flux(NAN), m_energy(0) { } }; static GOESXRay* create(const QString& service="services.swpc.noaa.gov"); ~GOESXRay(); void getDataPeriodically(int periodInMins=10); public slots: void getData(); private slots: void handleReply(QNetworkReply* reply); signals: void xRayDataUpdated(const QList& data, bool primary); // Called when new data available. void protonDataUpdated(const QList &data, bool primary); private: bool containsNonNull(const QJsonObject& obj, const QString &key) const; void handleXRayJson(const QByteArray& bytes, bool primary); void handleProtonJson(const QByteArray& bytes, bool primary); QTimer m_dataTimer; // Timer for periodic updates QNetworkAccessManager *m_networkManager; }; #endif /* INCLUDE_GOESXRAY_H */