From 3ecb73e36e18840917ad9973e2991b4692bbaec8 Mon Sep 17 00:00:00 2001 From: f4exb Date: Thu, 8 Aug 2019 18:42:17 +0200 Subject: [PATCH] REST API: Channel Analyzer settings (1) --- plugins/channelrx/chanalyzer/CMakeLists.txt | 11 +- .../channelrx/chanalyzer/chanalyzerplugin.cpp | 7 +- .../channelrx/chanalyzer/chanalyzerplugin.h | 1 + .../chanalyzer/chanalyzerwebapiadapter.cpp | 150 +++++++++++++++++- .../chanalyzer/chanalyzerwebapiadapter.h | 3 + sdrbase/dsp/glscopesettings.h | 4 +- sdrbase/resources/webapi/doc/html2/index.html | 4 +- .../webapi/doc/swagger/include/GLScope.yaml | 2 +- sdrbase/webapi/webapiadapterinterface.cpp | 75 +++++++++ sdrbase/webapi/webapiadapterinterface.h | 1 + sdrbase/webapi/webapirequestmapper.cpp | 27 +++- sdrbase/webapi/webapiserver.cpp | 1 + .../api/swagger/include/ChannelAnalyzer.yaml | 2 +- .../sdrangel/api/swagger/include/GLScope.yaml | 2 +- swagger/sdrangel/code/html2/index.html | 4 +- .../sdrangel/code/qt5/client/SWGGLScope.cpp | 32 ++-- swagger/sdrangel/code/qt5/client/SWGGLScope.h | 8 +- 17 files changed, 296 insertions(+), 38 deletions(-) diff --git a/plugins/channelrx/chanalyzer/CMakeLists.txt b/plugins/channelrx/chanalyzer/CMakeLists.txt index 2bd23494f..a93f72035 100644 --- a/plugins/channelrx/chanalyzer/CMakeLists.txt +++ b/plugins/channelrx/chanalyzer/CMakeLists.txt @@ -5,7 +5,7 @@ set(chanalyzer_SOURCES chanalyzergui.cpp chanalyzerplugin.cpp chanalyzersettings.cpp - + chanalyzerwebapiadapter.cpp chanalyzergui.ui ) @@ -14,6 +14,11 @@ set(chanalyzer_HEADERS chanalyzergui.h chanalyzerplugin.h chanalyzersettings.h + chanalyzerwebapiadapter.h +) + +include_directories( + ${CMAKE_SOURCE_DIR}/swagger/sdrangel/code/qt5/client ) include_directories( @@ -25,8 +30,8 @@ add_library(chanalyzer SHARED ) target_link_libraries(chanalyzer - Qt5::Core - Qt5::Widgets + Qt5::Core + Qt5::Widgets sdrbase sdrgui ) diff --git a/plugins/channelrx/chanalyzer/chanalyzerplugin.cpp b/plugins/channelrx/chanalyzer/chanalyzerplugin.cpp index 0b9d4c48a..942540f7f 100644 --- a/plugins/channelrx/chanalyzer/chanalyzerplugin.cpp +++ b/plugins/channelrx/chanalyzer/chanalyzerplugin.cpp @@ -21,10 +21,11 @@ #include "chanalyzer.h" #include "chanalyzerplugin.h" #include "chanalyzergui.h" +#include "chanalyzerwebapiadapter.h" const PluginDescriptor ChannelAnalyzerPlugin::m_pluginDescriptor = { QString("Channel Analyzer"), - QString("4.5.1"), + QString("4.11.6"), QString("(c) Edouard Griffiths, F4EXB"), QString("https://github.com/f4exb/sdrangel"), true, @@ -65,3 +66,7 @@ ChannelAPI* ChannelAnalyzerPlugin::createRxChannelCS(DeviceAPI *deviceAPI) const return new ChannelAnalyzer(deviceAPI); } +ChannelWebAPIAdapter* ChannelAnalyzerPlugin::createChannelWebAPIAdapter() const +{ + return new ChannelAnalyzerWebAPIAdapter(); +} \ No newline at end of file diff --git a/plugins/channelrx/chanalyzer/chanalyzerplugin.h b/plugins/channelrx/chanalyzer/chanalyzerplugin.h index 313325978..83b0fb0ad 100644 --- a/plugins/channelrx/chanalyzer/chanalyzerplugin.h +++ b/plugins/channelrx/chanalyzer/chanalyzerplugin.h @@ -39,6 +39,7 @@ public: virtual PluginInstanceGUI* createRxChannelGUI(DeviceUISet *deviceUISet, BasebandSampleSink *rxChannel) const; virtual BasebandSampleSink* createRxChannelBS(DeviceAPI *deviceAPI) const; virtual ChannelAPI* createRxChannelCS(DeviceAPI *deviceAPI) const; + virtual ChannelWebAPIAdapter* createChannelWebAPIAdapter() const; private: static const PluginDescriptor m_pluginDescriptor; diff --git a/plugins/channelrx/chanalyzer/chanalyzerwebapiadapter.cpp b/plugins/channelrx/chanalyzer/chanalyzerwebapiadapter.cpp index 8b37bfac7..f102607cb 100644 --- a/plugins/channelrx/chanalyzer/chanalyzerwebapiadapter.cpp +++ b/plugins/channelrx/chanalyzer/chanalyzerwebapiadapter.cpp @@ -15,6 +15,8 @@ // along with this program. If not, see . // /////////////////////////////////////////////////////////////////////////////////// +#include + #include "SWGChannelSettings.h" #include "chanalyzerwebapiadapter.h" @@ -27,6 +29,17 @@ ChannelAnalyzerWebAPIAdapter::ChannelAnalyzerWebAPIAdapter() ChannelAnalyzerWebAPIAdapter::~ChannelAnalyzerWebAPIAdapter() {} +int ChannelAnalyzerWebAPIAdapter::webapiSettingsGet( + SWGSDRangel::SWGChannelSettings& response, + QString& errorMessage) +{ + (void) errorMessage; + response.setChannelAnalyzerSettings(new SWGSDRangel::SWGChannelAnalyzerSettings()); + response.getChannelAnalyzerSettings()->init(); + webapiFormatChannelSettings(response, m_settings, m_glScopeSettings, m_glSpectrumSettings); + return 200; +} + void ChannelAnalyzerWebAPIAdapter::webapiFormatChannelSettings( SWGSDRangel::SWGChannelSettings& response, const ChannelAnalyzerSettings& settings, @@ -48,6 +61,8 @@ void ChannelAnalyzerWebAPIAdapter::webapiFormatChannelSettings( response.getChannelAnalyzerSettings()->setInputType((int) settings.m_inputType); response.getChannelAnalyzerSettings()->setRgbColor(settings.m_rgbColor); response.getChannelAnalyzerSettings()->setTitle(new QString(settings.m_title)); + + // scope SWGSDRangel::SWGGLScope *swgScope = new SWGSDRangel::SWGGLScope(); swgScope->init(); response.getChannelAnalyzerSettings()->setScopeConfig(swgScope); @@ -58,8 +73,61 @@ void ChannelAnalyzerWebAPIAdapter::webapiFormatChannelSettings( swgScope->setTraceIntensity(scopeSettings.m_traceIntensity); swgScope->setTraceLen(scopeSettings.m_traceLen); swgScope->setTrigPre(scopeSettings.m_trigPre); - // TODO array of traces - // TODO array of triggers + + // array of traces + swgScope->setTracesData(new QList); + std::vector::const_iterator traceIt = scopeSettings.m_tracesData.begin(); + + for (; traceIt != scopeSettings.m_tracesData.end(); ++traceIt) + { + swgScope->getTracesData()->append(new SWGSDRangel::SWGTraceData); + swgScope->getTracesData()->back()->setAmp(traceIt->m_amp); + swgScope->getTracesData()->back()->setAmpIndex(traceIt->m_ampIndex); + swgScope->getTracesData()->back()->setHasTextOverlay(traceIt->m_hasTextOverlay ? 1 : 0); + swgScope->getTracesData()->back()->setInputIndex(traceIt->m_inputIndex); + swgScope->getTracesData()->back()->setOfs(traceIt->m_ofs); + swgScope->getTracesData()->back()->setOfsCoarse(traceIt->m_ofsCoarse); + swgScope->getTracesData()->back()->setOfsFine(traceIt->m_ofsFine); + swgScope->getTracesData()->back()->setProjectionType((int) traceIt->m_projectionType); + swgScope->getTracesData()->back()->setTextOverlay(new QString(traceIt->m_textOverlay)); + swgScope->getTracesData()->back()->setTraceColor(qColorToInt(traceIt->m_traceColor)); + swgScope->getTracesData()->back()->setTraceColorB(traceIt->m_traceColorB); + swgScope->getTracesData()->back()->setTraceColorG(traceIt->m_traceColorG); + swgScope->getTracesData()->back()->setTraceColorR(traceIt->m_traceColorR); + swgScope->getTracesData()->back()->setTraceDelay(traceIt->m_traceDelay); + swgScope->getTracesData()->back()->setTraceDelayCoarse(traceIt->m_traceDelayCoarse); + swgScope->getTracesData()->back()->setTraceDelayFine(traceIt->m_traceDelayFine); + swgScope->getTracesData()->back()->setTriggerDisplayLevel(traceIt->m_triggerDisplayLevel); + swgScope->getTracesData()->back()->setViewTrace(traceIt->m_viewTrace ? 1 : 0); + } + + // array of triggers + swgScope->setTriggersData(new QList); + std::vector::const_iterator triggerIt = scopeSettings.m_triggersData.begin(); + + for (; triggerIt != scopeSettings.m_triggersData.end(); ++triggerIt) + { + swgScope->getTriggersData()->append(new SWGSDRangel::SWGTriggerData); + swgScope->getTriggersData()->back()->setInputIndex(triggerIt->m_inputIndex); + swgScope->getTriggersData()->back()->setProjectionType((int) triggerIt->m_projectionType); + swgScope->getTriggersData()->back()->setTriggerBothEdges(triggerIt->m_triggerBothEdges ? 1 : 0); + swgScope->getTriggersData()->back()->setTriggerColor(qColorToInt(triggerIt->m_triggerColor)); + swgScope->getTriggersData()->back()->setTriggerColorB(triggerIt->m_triggerColorB); + swgScope->getTriggersData()->back()->setTriggerColorG(triggerIt->m_triggerColorG); + swgScope->getTriggersData()->back()->setTriggerColorR(triggerIt->m_triggerColorR); + swgScope->getTriggersData()->back()->setTriggerDelay(triggerIt->m_triggerDelay); + swgScope->getTriggersData()->back()->setTriggerDelayCoarse(triggerIt->m_triggerDelayCoarse); + swgScope->getTriggersData()->back()->setTriggerDelayFine(triggerIt->m_triggerDelayFine); + swgScope->getTriggersData()->back()->setTriggerDelayMult(triggerIt->m_triggerDelayMult); + swgScope->getTriggersData()->back()->setTriggerHoldoff(triggerIt->m_triggerHoldoff ? 1 : 0); + swgScope->getTriggersData()->back()->setTriggerLevel(triggerIt->m_triggerLevel); + swgScope->getTriggersData()->back()->setTriggerLevelCoarse(triggerIt->m_triggerLevelCoarse); + swgScope->getTriggersData()->back()->setTriggerLevelFine(triggerIt->m_triggerLevelFine); + swgScope->getTriggersData()->back()->setTriggerPositiveEdge(triggerIt->m_triggerPositiveEdge ? 1 : 0); + swgScope->getTriggersData()->back()->setTriggerRepeat(triggerIt->m_triggerRepeat); + } + + // spectrum SWGSDRangel::SWGGLSpectrum *swgSpectrum = new SWGSDRangel::SWGGLSpectrum(); swgSpectrum->init(); response.getChannelAnalyzerSettings()->setSpectrumConfig(swgSpectrum); @@ -76,7 +144,17 @@ void ChannelAnalyzerWebAPIAdapter::webapiFormatChannelSettings( swgSpectrum->setDisplayWaterfall(spectrumSettings.m_displayWaterfall ? 1 : 0); swgSpectrum->setFftOverlap(spectrumSettings.m_fftOverlap); swgSpectrum->setFftSize(spectrumSettings.m_fftSize); +} +int ChannelAnalyzerWebAPIAdapter::webapiSettingsPutPatch( + bool force, + const QStringList& channelSettingsKeys, + SWGSDRangel::SWGChannelSettings& response, + QString& errorMessage) +{ + (void) force; + (void) errorMessage; + webapiUpdateChannelSettings(m_settings, m_glScopeSettings, m_glSpectrumSettings, channelSettingsKeys, response); } void ChannelAnalyzerWebAPIAdapter::webapiUpdateChannelSettings( @@ -86,6 +164,72 @@ void ChannelAnalyzerWebAPIAdapter::webapiUpdateChannelSettings( const QStringList& channelSettingsKeys, SWGSDRangel::SWGChannelSettings& response) { - + if (channelSettingsKeys.contains("frequency")) { + settings.m_frequency = response.getChannelAnalyzerSettings()->getFrequency(); + } + if (channelSettingsKeys.contains("downSample")) { + settings.m_downSample = response.getChannelAnalyzerSettings()->getDownSample() != 0; + } + if (channelSettingsKeys.contains("downSampleRate")) { + settings.m_downSampleRate = response.getChannelAnalyzerSettings()->getDownSampleRate(); + } + if (channelSettingsKeys.contains("bandwidth")) { + settings.m_bandwidth = response.getChannelAnalyzerSettings()->getBandwidth(); + } + if (channelSettingsKeys.contains("lowCutoff")) { + settings.m_lowCutoff = response.getChannelAnalyzerSettings()->getLowCutoff(); + } + if (channelSettingsKeys.contains("spanLog2")) { + settings.m_spanLog2 = response.getChannelAnalyzerSettings()->getSpanLog2(); + } + if (channelSettingsKeys.contains("ssb")) { + settings.m_ssb = response.getChannelAnalyzerSettings()->getSsb() != 0; + } + if (channelSettingsKeys.contains("pll")) { + settings.m_pll = response.getChannelAnalyzerSettings()->getPll() != 0; + } + if (channelSettingsKeys.contains("fll")) { + settings.m_fll = response.getChannelAnalyzerSettings()->getFll() != 0; + } + if (channelSettingsKeys.contains("rrc")) { + settings.m_rrc = response.getChannelAnalyzerSettings()->getRrc() != 0; + } + if (channelSettingsKeys.contains("rrcRolloff")) { + settings.m_rrcRolloff = response.getChannelAnalyzerSettings()->getRrcRolloff(); + } + if (channelSettingsKeys.contains("pllPskOrder")) { + settings.m_pllPskOrder = response.getChannelAnalyzerSettings()->getPllPskOrder(); + } + if (channelSettingsKeys.contains("inputType")) { + settings.m_inputType = (ChannelAnalyzerSettings::InputType) response.getChannelAnalyzerSettings()->getInputType(); + } + if (channelSettingsKeys.contains("rgbColor")) { + settings.m_rgbColor = response.getChannelAnalyzerSettings()->getRgbColor(); + } + if (channelSettingsKeys.contains("title")) { + settings.m_title = *response.getChannelAnalyzerSettings()->getTitle(); + } + // scope + if (channelSettingsKeys.contains("scopeConfig.displayMode")) { + scopeSettings.m_displayMode = (GLScopeSettings::DisplayMode) response.getChannelAnalyzerSettings()->getScopeConfig()->getDisplayMode(); + } + // TODO ... + for (int i = 0; i < 10; i++) // no more than 10 traces anyway + { + // TODO ... + } } +int ChannelAnalyzerWebAPIAdapter::qColorToInt(const QColor& color) +{ + return 256*256*color.blue() + 256*color.green() + color.red(); +} + +QColor ChannelAnalyzerWebAPIAdapter::intToQColor(int intColor) +{ + int r = intColor % 256; + int bg = intColor / 256; + int g = bg % 256; + int b = bg / 256; + return QColor(r, g, b); +} \ No newline at end of file diff --git a/plugins/channelrx/chanalyzer/chanalyzerwebapiadapter.h b/plugins/channelrx/chanalyzer/chanalyzerwebapiadapter.h index dafb4d283..326c97109 100644 --- a/plugins/channelrx/chanalyzer/chanalyzerwebapiadapter.h +++ b/plugins/channelrx/chanalyzer/chanalyzerwebapiadapter.h @@ -61,6 +61,9 @@ private: ChannelAnalyzerSettings m_settings; GLScopeSettings m_glScopeSettings; GLSpectrumSettings m_glSpectrumSettings; + + static int qColorToInt(const QColor& color); + static QColor intToQColor(int intColor); }; #endif // INCLUDE_CHANALYZER_WEBAPIADAPTER_H diff --git a/sdrbase/dsp/glscopesettings.h b/sdrbase/dsp/glscopesettings.h index e6b793165..94c48f82a 100644 --- a/sdrbase/dsp/glscopesettings.h +++ b/sdrbase/dsp/glscopesettings.h @@ -15,11 +15,11 @@ // along with this program. If not, see . // /////////////////////////////////////////////////////////////////////////////////// +#include + #include #include -#include - #include "export.h" #include "dsp/dsptypes.h" #include "dsp/projector.h" diff --git a/sdrbase/resources/webapi/doc/html2/index.html b/sdrbase/resources/webapi/doc/html2/index.html index 5ee79cf72..0540a91e7 100644 --- a/sdrbase/resources/webapi/doc/html2/index.html +++ b/sdrbase/resources/webapi/doc/html2/index.html @@ -3187,7 +3187,7 @@ margin-bottom: 20px; "$ref" : "#/definitions/TraceData" } }, - "m_triggersData" : { + "triggersData" : { "type" : "array", "items" : { "$ref" : "#/definitions/TriggerData" @@ -27607,7 +27607,7 @@ except ApiException as e:
- Generated 2019-08-07T23:30:36.250+02:00 + Generated 2019-08-08T13:54:12.590+02:00
diff --git a/sdrbase/resources/webapi/doc/swagger/include/GLScope.yaml b/sdrbase/resources/webapi/doc/swagger/include/GLScope.yaml index f809f9361..21ca03bc5 100644 --- a/sdrbase/resources/webapi/doc/swagger/include/GLScope.yaml +++ b/sdrbase/resources/webapi/doc/swagger/include/GLScope.yaml @@ -140,7 +140,7 @@ GLScope: type: array items: $ref: "/doc/swagger/include/GLScope.yaml#/TraceData" - m_triggersData: + triggersData: type: array items: $ref: "/doc/swagger/include/GLScope.yaml#/TriggerData" diff --git a/sdrbase/webapi/webapiadapterinterface.cpp b/sdrbase/webapi/webapiadapterinterface.cpp index 70bceff39..fb46406df 100644 --- a/sdrbase/webapi/webapiadapterinterface.cpp +++ b/sdrbase/webapi/webapiadapterinterface.cpp @@ -49,3 +49,78 @@ std::regex WebAPIAdapterInterface::devicesetChannelURLRe("^/sdrangel/deviceset/( std::regex WebAPIAdapterInterface::devicesetChannelIndexURLRe("^/sdrangel/deviceset/([0-9]{1,2})/channel/([0-9]{1,2})$"); std::regex WebAPIAdapterInterface::devicesetChannelSettingsURLRe("^/sdrangel/deviceset/([0-9]{1,2})/channel/([0-9]{1,2})/settings$"); std::regex WebAPIAdapterInterface::devicesetChannelReportURLRe("^/sdrangel/deviceset/([0-9]{1,2})/channel/([0-9]{1,2})/report"); + +void WebAPIAdapterInterface::ConfigKeys::debug() +{ + qDebug("WebAPIAdapterInterface::ConfigKeys::debug"); + + qDebug("preferences:"); + foreach(QString preferenceKey, m_preferencesKeys) { + qDebug(" %s", qPrintable(preferenceKey)); + } + + qDebug("commands:"); + foreach(CommandKeys commandKeys, m_commandKeys) + { + qDebug(" {"); + foreach(QString commandKey, commandKeys.m_keys) { + qDebug(" %s", qPrintable(commandKey)); + } + qDebug(" }"); + } + + qDebug("presets:"); + foreach(PresetKeys presetKeys, m_presetKeys) + { + qDebug(" {"); + foreach(QString presetKey, presetKeys.m_keys) { + qDebug(" %s", qPrintable(presetKey)); + } + qDebug(" deviceConfigs:"); + foreach(DeviceKeys deviceKeys, presetKeys.m_devicesKeys) + { + qDebug(" {"); + qDebug(" config:"); + foreach(QString deviceKey, deviceKeys.m_deviceKeys) { + qDebug(" %s", qPrintable(deviceKey)); + } + qDebug(" }"); + } + qDebug(" channelConfigs"); + foreach(ChannelKeys channelKeys, presetKeys.m_channelsKeys) + { + qDebug(" {"); + qDebug(" config:"); + foreach(QString channelKey, channelKeys.m_channelKeys) { + qDebug(" %s", qPrintable(channelKey)); + } + qDebug(" }"); + } + qDebug(" }"); + } + + qDebug("workingPreset:"); + foreach(QString presetKey, m_workingPresetKeys.m_keys) { + qDebug(" %s", qPrintable(presetKey)); + } + qDebug(" deviceConfigs:"); + foreach(DeviceKeys deviceKeys, m_workingPresetKeys.m_devicesKeys) + { + qDebug(" {"); + qDebug(" config:"); + foreach(QString deviceKey, deviceKeys.m_deviceKeys) { + qDebug(" %s", qPrintable(deviceKey)); + } + qDebug(" }"); + } + qDebug(" channelConfigs:"); + foreach(ChannelKeys channelKeys, m_workingPresetKeys.m_channelsKeys) + { + qDebug(" {"); + qDebug(" config:"); + foreach(QString channelKey, channelKeys.m_channelKeys) { + qDebug(" %s", qPrintable(channelKey)); + } + qDebug(" }"); + } +} \ No newline at end of file diff --git a/sdrbase/webapi/webapiadapterinterface.h b/sdrbase/webapi/webapiadapterinterface.h index 5d5eff6ad..5be95f484 100644 --- a/sdrbase/webapi/webapiadapterinterface.h +++ b/sdrbase/webapi/webapiadapterinterface.h @@ -89,6 +89,7 @@ public: PresetKeys m_workingPresetKeys; QList m_presetKeys; QList m_commandKeys; + void debug(); }; virtual ~WebAPIAdapterInterface() {} diff --git a/sdrbase/webapi/webapirequestmapper.cpp b/sdrbase/webapi/webapirequestmapper.cpp index 85eeba295..4310456f7 100644 --- a/sdrbase/webapi/webapirequestmapper.cpp +++ b/sdrbase/webapi/webapirequestmapper.cpp @@ -53,6 +53,7 @@ const QMap WebAPIRequestMapper::m_channelURIToSettingsKey = { {"sdrangel.channeltx.ammod", "AMModSettings"}, {"sdrangel.channeltx.atvmod", "ATVModSettings"}, {"sdrangel.channel.bfm", "BFMDemodSettings"}, + {"sdrangel.channel.chanalyzer", "ChannelAnalyzerSettings"}, {"sdrangel.channel.dsddemod", "DSDDemodSettings"}, {"sdrangel.channeltx.filesrc", "FileSourceSettings"}, {"sdrangel.channel.freedvdemod", "FreeDVDemodSettings"}, @@ -117,6 +118,7 @@ const QMap WebAPIRequestMapper::m_channelTypeToSettingsKey = { {"AMMod", "AMModSettings"}, {"ATVMod", "ATVModSettings"}, {"BFMDemod", "BFMDemodSettings"}, + {"ChannelAnalyzer", "ChannelAnalyzerSettings"}, {"DSDDemod", "DSDDemodSettings"}, {"FileSource", "FileSourceSettings"}, {"FreeDVDemod", "FreeDVDemodSettings"}, @@ -375,6 +377,7 @@ void WebAPIRequestMapper::instanceConfigService(qtwebapp::HttpRequest& request, if (validateConfig(query, jsonObject, configKeys)) { + configKeys.debug(); int status = m_adapter->instanceConfigPutPatch( true, query, @@ -2254,11 +2257,26 @@ bool WebAPIRequestMapper::validateConfig(SWGSDRangel::SWGInstanceConfigResponse& } } + if (jsonObject.contains("presets")) + { + QJsonArray presetsJson = jsonObject["presets"].toArray(); + QJsonArray::const_iterator presetsIt = presetsJson.begin(); + + for (; presetsIt != presetsJson.end(); ++presetsIt) + { + SWGSDRangel::SWGPreset *preset = new SWGSDRangel::SWGPreset(); + QJsonObject presetJson = presetsIt->toObject(); + configKeys.m_presetKeys.append(WebAPIAdapterInterface::PresetKeys()); + appendPresetKeys(preset, presetJson, configKeys.m_presetKeys.back()); + } + } + if (jsonObject.contains("workingPreset")) { - SWGSDRangel::SWGPreset *workingPreset = new SWGSDRangel::SWGPreset(); + SWGSDRangel::SWGPreset *preset = new SWGSDRangel::SWGPreset(); + config.setWorkingPreset(preset); QJsonObject presetJson = jsonObject["workingPreset"].toObject(); - appendPresetKeys(workingPreset, presetJson, configKeys.m_workingPresetKeys); + appendPresetKeys(preset, presetJson, configKeys.m_workingPresetKeys); } return true; @@ -2413,6 +2431,11 @@ bool WebAPIRequestMapper::getChannel( channelSettings->setBfmDemodSettings(new SWGSDRangel::SWGBFMDemodSettings()); channelSettings->getBfmDemodSettings()->fromJsonObject(settingsJsonObject); } + else if (channelSettingsKey == "ChannelAnalyzerSettings") + { + channelSettings->setChannelAnalyzerSettings(new SWGSDRangel::SWGChannelAnalyzerSettings()); + channelSettings->getChannelAnalyzerSettings()->fromJsonObject(settingsJsonObject); + } else if (channelSettingsKey == "DSDDemodSettings") { channelSettings->setDsdDemodSettings(new SWGSDRangel::SWGDSDDemodSettings()); diff --git a/sdrbase/webapi/webapiserver.cpp b/sdrbase/webapi/webapiserver.cpp index a2640ddcb..6749b404c 100644 --- a/sdrbase/webapi/webapiserver.cpp +++ b/sdrbase/webapi/webapiserver.cpp @@ -29,6 +29,7 @@ WebAPIServer::WebAPIServer(const QString& host, uint16_t port, WebAPIRequestMapp { m_settings.host = host; m_settings.port = port; + m_settings.maxRequestSize = 1<<23; // 8M } WebAPIServer::~WebAPIServer() diff --git a/swagger/sdrangel/api/swagger/include/ChannelAnalyzer.yaml b/swagger/sdrangel/api/swagger/include/ChannelAnalyzer.yaml index 4031a84e9..a4bb0dea1 100644 --- a/swagger/sdrangel/api/swagger/include/ChannelAnalyzer.yaml +++ b/swagger/sdrangel/api/swagger/include/ChannelAnalyzer.yaml @@ -32,7 +32,7 @@ ChannelAnalyzerSettings: pllPskOrder: type: integer inputType: - description: see ChannelAnalyzer::InputType + description: see ChannelAnalyzerSettings::InputType type: integer rgbColor: type: integer diff --git a/swagger/sdrangel/api/swagger/include/GLScope.yaml b/swagger/sdrangel/api/swagger/include/GLScope.yaml index 60cc0bfa6..150118125 100644 --- a/swagger/sdrangel/api/swagger/include/GLScope.yaml +++ b/swagger/sdrangel/api/swagger/include/GLScope.yaml @@ -140,7 +140,7 @@ GLScope: type: array items: $ref: "http://localhost:8081/api/swagger/include/GLScope.yaml#/TraceData" - m_triggersData: + triggersData: type: array items: $ref: "http://localhost:8081/api/swagger/include/GLScope.yaml#/TriggerData" diff --git a/swagger/sdrangel/code/html2/index.html b/swagger/sdrangel/code/html2/index.html index 5ee79cf72..0540a91e7 100644 --- a/swagger/sdrangel/code/html2/index.html +++ b/swagger/sdrangel/code/html2/index.html @@ -3187,7 +3187,7 @@ margin-bottom: 20px; "$ref" : "#/definitions/TraceData" } }, - "m_triggersData" : { + "triggersData" : { "type" : "array", "items" : { "$ref" : "#/definitions/TriggerData" @@ -27607,7 +27607,7 @@ except ApiException as e:
- Generated 2019-08-07T23:30:36.250+02:00 + Generated 2019-08-08T13:54:12.590+02:00
diff --git a/swagger/sdrangel/code/qt5/client/SWGGLScope.cpp b/swagger/sdrangel/code/qt5/client/SWGGLScope.cpp index 2a79af53f..27a4482c2 100644 --- a/swagger/sdrangel/code/qt5/client/SWGGLScope.cpp +++ b/swagger/sdrangel/code/qt5/client/SWGGLScope.cpp @@ -44,8 +44,8 @@ SWGGLScope::SWGGLScope() { m_trig_pre_isSet = false; traces_data = nullptr; m_traces_data_isSet = false; - m_triggers_data = nullptr; - m_m_triggers_data_isSet = false; + triggers_data = nullptr; + m_triggers_data_isSet = false; } SWGGLScope::~SWGGLScope() { @@ -70,8 +70,8 @@ SWGGLScope::init() { m_trig_pre_isSet = false; traces_data = new QList(); m_traces_data_isSet = false; - m_triggers_data = new QList(); - m_m_triggers_data_isSet = false; + triggers_data = new QList(); + m_triggers_data_isSet = false; } void @@ -90,12 +90,12 @@ SWGGLScope::cleanup() { } delete traces_data; } - if(m_triggers_data != nullptr) { - auto arr = m_triggers_data; + if(triggers_data != nullptr) { + auto arr = triggers_data; for(auto o: *arr) { delete o; } - delete m_triggers_data; + delete triggers_data; } } @@ -127,7 +127,7 @@ SWGGLScope::fromJsonObject(QJsonObject &pJson) { ::SWGSDRangel::setValue(&traces_data, pJson["tracesData"], "QList", "SWGTraceData"); - ::SWGSDRangel::setValue(&m_triggers_data, pJson["m_triggersData"], "QList", "SWGTriggerData"); + ::SWGSDRangel::setValue(&triggers_data, pJson["triggersData"], "QList", "SWGTriggerData"); } QString @@ -168,8 +168,8 @@ SWGGLScope::asJsonObject() { if(traces_data && traces_data->size() > 0){ toJsonArray((QList*)traces_data, obj, "tracesData", "SWGTraceData"); } - if(m_triggers_data && m_triggers_data->size() > 0){ - toJsonArray((QList*)m_triggers_data, obj, "m_triggersData", "SWGTriggerData"); + if(triggers_data && triggers_data->size() > 0){ + toJsonArray((QList*)triggers_data, obj, "triggersData", "SWGTriggerData"); } return obj; @@ -256,13 +256,13 @@ SWGGLScope::setTracesData(QList* traces_data) { } QList* -SWGGLScope::getMTriggersData() { - return m_triggers_data; +SWGGLScope::getTriggersData() { + return triggers_data; } void -SWGGLScope::setMTriggersData(QList* m_triggers_data) { - this->m_triggers_data = m_triggers_data; - this->m_m_triggers_data_isSet = true; +SWGGLScope::setTriggersData(QList* triggers_data) { + this->triggers_data = triggers_data; + this->m_triggers_data_isSet = true; } @@ -294,7 +294,7 @@ SWGGLScope::isSet(){ if(traces_data && (traces_data->size() > 0)){ isObjectUpdated = true; break; } - if(m_triggers_data && (m_triggers_data->size() > 0)){ + if(triggers_data && (triggers_data->size() > 0)){ isObjectUpdated = true; break; } }while(false); diff --git a/swagger/sdrangel/code/qt5/client/SWGGLScope.h b/swagger/sdrangel/code/qt5/client/SWGGLScope.h index ac84f5e75..c025f9d58 100644 --- a/swagger/sdrangel/code/qt5/client/SWGGLScope.h +++ b/swagger/sdrangel/code/qt5/client/SWGGLScope.h @@ -68,8 +68,8 @@ public: QList* getTracesData(); void setTracesData(QList* traces_data); - QList* getMTriggersData(); - void setMTriggersData(QList* m_triggers_data); + QList* getTriggersData(); + void setTriggersData(QList* triggers_data); virtual bool isSet() override; @@ -99,8 +99,8 @@ private: QList* traces_data; bool m_traces_data_isSet; - QList* m_triggers_data; - bool m_m_triggers_data_isSet; + QList* triggers_data; + bool m_triggers_data_isSet; };