Web API: /sdrangel/deviceset/{index} (GET) implementation

This commit is contained in:
f4exb 2017-11-26 10:37:39 +01:00
parent 3e7efb4c6f
commit c5a19e261c
9 changed files with 95 additions and 12 deletions

View File

@ -792,7 +792,7 @@ margin-bottom: 20px;
"description" : "Channel summarized information" "description" : "Channel summarized information"
}; };
defs.ChannelListItem = { defs.ChannelListItem = {
"required" : [ "id", "name" ], "required" : [ "id" ],
"properties" : { "properties" : {
"name" : { "name" : {
"type" : "string", "type" : "string",
@ -848,7 +848,7 @@ margin-bottom: 20px;
"description" : "DV serial device details" "description" : "DV serial device details"
}; };
defs.DeviceListItem = { defs.DeviceListItem = {
"required" : [ "hwType" ], "required" : [ "hwType", "tx" ],
"properties" : { "properties" : {
"displayedName" : { "displayedName" : {
"type" : "string", "type" : "string",
@ -8445,7 +8445,7 @@ except ApiException as e:
</div> </div>
<div id="generator"> <div id="generator">
<div class="content"> <div class="content">
Generated 2017-11-26T00:25:44.253+01:00 Generated 2017-11-26T10:35:17.573+01:00
</div> </div>
</div> </div>
</div> </div>

View File

@ -28,5 +28,5 @@ QString WebAPIAdapterInterface::instanceDVSerialURL = "/sdrangel/dvserial";
QString WebAPIAdapterInterface::instancePresetURL = "/sdrangel/preset"; QString WebAPIAdapterInterface::instancePresetURL = "/sdrangel/preset";
QString WebAPIAdapterInterface::instanceDeviceSetsURL = "/sdrangel/devicesets"; QString WebAPIAdapterInterface::instanceDeviceSetsURL = "/sdrangel/devicesets";
std::regex WebAPIAdapterInterface::devicesetURLRe("^/sdrangel/deviceset/([0-9]+)$"); std::regex WebAPIAdapterInterface::devicesetURLRe("^/sdrangel/deviceset/([0-9]{1,2})$");
std::regex WebAPIAdapterInterface::devicesetDeviceURLRe("^/sdrangel/deviceset/([0-9]+)/device$"); std::regex WebAPIAdapterInterface::devicesetDeviceURLRe("^/sdrangel/deviceset/([0-9]{1,2})/device$");

View File

@ -205,7 +205,6 @@ public:
Swagger::SWGErrorResponse& error __attribute__((unused))) Swagger::SWGErrorResponse& error __attribute__((unused)))
{ return 501; } { return 501; }
/** /**
* Handler of /sdrangel/devicesets (DELETE) swagger/sdrangel/code/html2/index.html#api-Default-instanceChannels * Handler of /sdrangel/devicesets (DELETE) swagger/sdrangel/code/html2/index.html#api-Default-instanceChannels
* returns the Http status code (default 501: not implemented) * returns the Http status code (default 501: not implemented)
@ -215,6 +214,16 @@ public:
Swagger::SWGErrorResponse& error __attribute__((unused))) Swagger::SWGErrorResponse& error __attribute__((unused)))
{ return 501; } { return 501; }
/**
* Handler of /sdrangel/devicesets (DELETE) swagger/sdrangel/code/html2/index.html#api-Default-instanceChannels
* returns the Http status code (default 501: not implemented)
*/
virtual int devicesetGet(
int deviceSetIndex __attribute__((unused)),
Swagger::SWGDeviceSet& response __attribute__((unused)),
Swagger::SWGErrorResponse& error __attribute__((unused)))
{ return 501; }
static QString instanceSummaryURL; static QString instanceSummaryURL;
static QString instanceDevicesURL; static QString instanceDevicesURL;
static QString instanceChannelsURL; static QString instanceChannelsURL;

View File

@ -20,6 +20,8 @@
#include <QJsonDocument> #include <QJsonDocument>
#include <QJsonArray> #include <QJsonArray>
#include <boost/lexical_cast.hpp>
#include "httpdocrootsettings.h" #include "httpdocrootsettings.h"
#include "webapirequestmapper.h" #include "webapirequestmapper.h"
#include "SWGInstanceSummaryResponse.h" #include "SWGInstanceSummaryResponse.h"
@ -80,13 +82,23 @@ void WebAPIRequestMapper::service(qtwebapp::HttpRequest& request, qtwebapp::Http
} }
else else
{ {
std::smatch desc_match;
std::string pathStr(path.constData(), path.length());
if (std::regex_match(pathStr, desc_match, WebAPIAdapterInterface::devicesetURLRe)) {
deviceset(std::string(desc_match[1]), request, response);
}
else
{
QByteArray path = "/index.html";
m_staticFileController->service(path, response);
}
// QDirIterator it(":", QDirIterator::Subdirectories); // QDirIterator it(":", QDirIterator::Subdirectories);
// while (it.hasNext()) { // while (it.hasNext()) {
// qDebug() << "WebAPIRequestMapper::service: " << it.next(); // qDebug() << "WebAPIRequestMapper::service: " << it.next();
// } // }
QByteArray path = "/index.html";
m_staticFileController->service(path, response);
} }
} }
} }
@ -525,6 +537,40 @@ void WebAPIRequestMapper::instanceDeviceSetsService(qtwebapp::HttpRequest& reque
} }
} }
void WebAPIRequestMapper::deviceset(const std::string& indexStr, qtwebapp::HttpRequest& request, qtwebapp::HttpResponse& response)
{
Swagger::SWGErrorResponse errorResponse;
if (request.getMethod() == "GET")
{
try
{
Swagger::SWGDeviceSet normalResponse;
int deviceSetIndex = boost::lexical_cast<int>(indexStr);
int status = m_adapter->devicesetGet(deviceSetIndex, normalResponse, errorResponse);
response.setStatus(status);
if (status == 200) {
response.write(normalResponse.asJson().toUtf8());
} else {
response.write(errorResponse.asJson().toUtf8());
}
}
catch (const boost::bad_lexical_cast &e)
{
errorResponse.init();
*errorResponse.getMessage() = "Wrong integer conversion on device set index";
response.setStatus(400,"Invalid data");
response.write(errorResponse.asJson().toUtf8());
}
}
else
{
response.setStatus(405,"Invalid HTTP method");
response.write("Invalid HTTP method");
}
}
bool WebAPIRequestMapper::parseJsonBody(QString& jsonStr, qtwebapp::HttpResponse& response) bool WebAPIRequestMapper::parseJsonBody(QString& jsonStr, qtwebapp::HttpResponse& response)
{ {
Swagger::SWGErrorResponse errorResponse; Swagger::SWGErrorResponse errorResponse;

View File

@ -55,6 +55,8 @@ private:
void instancePresetService(qtwebapp::HttpRequest& request, qtwebapp::HttpResponse& response); void instancePresetService(qtwebapp::HttpRequest& request, qtwebapp::HttpResponse& response);
void instanceDeviceSetsService(qtwebapp::HttpRequest& request, qtwebapp::HttpResponse& response); void instanceDeviceSetsService(qtwebapp::HttpRequest& request, qtwebapp::HttpResponse& response);
void deviceset(const std::string& indexStr, qtwebapp::HttpRequest& request, qtwebapp::HttpResponse& response);
bool validatePresetTransfer(Swagger::SWGPresetTransfer& presetTransfer); bool validatePresetTransfer(Swagger::SWGPresetTransfer& presetTransfer);
bool validatePresetIdentifer(Swagger::SWGPresetIdentifier& presetIdentifier); bool validatePresetIdentifer(Swagger::SWGPresetIdentifier& presetIdentifier);

View File

@ -593,6 +593,27 @@ int WebAPIAdapterGUI::instanceDeviceSetsDelete(
} }
} }
int WebAPIAdapterGUI::devicesetGet(
int deviceSetIndex,
Swagger::SWGDeviceSet& response,
Swagger::SWGErrorResponse& error)
{
if ((deviceSetIndex >= 0) && (deviceSetIndex < (int) m_mainWindow.m_deviceUIs.size()))
{
const DeviceUISet *deviceSet = m_mainWindow.m_deviceUIs[deviceSetIndex];
getDeviceSet(&response, deviceSet, deviceSetIndex);
return 200;
}
else
{
error.init();
*error.getMessage() = QString("There is no device set with index %1").arg(deviceSetIndex);
return 404;
}
}
void WebAPIAdapterGUI::getDeviceSetList(Swagger::SWGDeviceSetList* deviceSetList) void WebAPIAdapterGUI::getDeviceSetList(Swagger::SWGDeviceSetList* deviceSetList)
{ {
deviceSetList->init(); deviceSetList->init();

View File

@ -110,6 +110,11 @@ public:
Swagger::SWGDeviceSetList& response, Swagger::SWGDeviceSetList& response,
Swagger::SWGErrorResponse& error); Swagger::SWGErrorResponse& error);
virtual int devicesetGet(
int deviceSetIndex,
Swagger::SWGDeviceSet& response,
Swagger::SWGErrorResponse& error);
private: private:
MainWindow& m_mainWindow; MainWindow& m_mainWindow;

View File

@ -550,6 +550,7 @@ definitions:
description: "Summarized information about attached hardware device" description: "Summarized information about attached hardware device"
required: required:
- hwType - hwType
- tx
properties: properties:
displayedName: displayedName:
description: "Displayable name that uniquely identifies this device instance" description: "Displayable name that uniquely identifies this device instance"
@ -581,7 +582,6 @@ definitions:
ChannelListItem: ChannelListItem:
description: "Summarized information about channel plugin" description: "Summarized information about channel plugin"
required: required:
- name
- id - id
properties: properties:
name: name:

View File

@ -792,7 +792,7 @@ margin-bottom: 20px;
"description" : "Channel summarized information" "description" : "Channel summarized information"
}; };
defs.ChannelListItem = { defs.ChannelListItem = {
"required" : [ "id", "name" ], "required" : [ "id" ],
"properties" : { "properties" : {
"name" : { "name" : {
"type" : "string", "type" : "string",
@ -848,7 +848,7 @@ margin-bottom: 20px;
"description" : "DV serial device details" "description" : "DV serial device details"
}; };
defs.DeviceListItem = { defs.DeviceListItem = {
"required" : [ "hwType" ], "required" : [ "hwType", "tx" ],
"properties" : { "properties" : {
"displayedName" : { "displayedName" : {
"type" : "string", "type" : "string",
@ -8445,7 +8445,7 @@ except ApiException as e:
</div> </div>
<div id="generator"> <div id="generator">
<div class="content"> <div class="content">
Generated 2017-11-26T00:25:44.253+01:00 Generated 2017-11-26T10:35:17.573+01:00
</div> </div>
</div> </div>
</div> </div>