mirror of
https://github.com/AlexandreRouma/SDRPlusPlus.git
synced 2025-01-24 00:34:44 +01:00
Switch spectran http source module to use the remoteconfig endpoint as per #1354
This commit is contained in:
parent
065a5b4c40
commit
12f7efed32
@ -144,9 +144,7 @@ private:
|
|||||||
_this->tryConnect();
|
_this->tryConnect();
|
||||||
}
|
}
|
||||||
else if (connected && SmGui::Button("Disconnect##spectran_http_source")) {
|
else if (connected && SmGui::Button("Disconnect##spectran_http_source")) {
|
||||||
_this->client->onCenterFrequencyChanged.unbind(_this->onFreqChangedId);
|
_this->disconnect();
|
||||||
_this->client->onCenterFrequencyChanged.unbind(_this->onSamplerateChangedId);
|
|
||||||
_this->client->close();
|
|
||||||
}
|
}
|
||||||
if (_this->running) { style::endDisabled(); }
|
if (_this->running) { style::endDisabled(); }
|
||||||
|
|
||||||
@ -173,6 +171,12 @@ private:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void disconnect() {
|
||||||
|
client->onCenterFrequencyChanged.unbind(onFreqChangedId);
|
||||||
|
client->onSamplerateChanged.unbind(onSamplerateChangedId);
|
||||||
|
client->close();
|
||||||
|
}
|
||||||
|
|
||||||
void onFreqChanged(double newFreq) {
|
void onFreqChanged(double newFreq) {
|
||||||
if (lastReportedFreq == newFreq) { return; }
|
if (lastReportedFreq == newFreq) { return; }
|
||||||
lastReportedFreq = newFreq;
|
lastReportedFreq = newFreq;
|
||||||
|
@ -11,12 +11,15 @@ SpectranHTTPClient::SpectranHTTPClient(std::string host, int port, dsp::stream<d
|
|||||||
sock = net::connect(host, port);
|
sock = net::connect(host, port);
|
||||||
http = net::http::Client(sock);
|
http = net::http::Client(sock);
|
||||||
|
|
||||||
// Make request
|
// Send sttream request
|
||||||
net::http::RequestHeader rqhdr(net::http::METHOD_GET, "/stream?format=float32", host);
|
net::http::RequestHeader rqhdr(net::http::METHOD_GET, "/stream?format=float32", host);
|
||||||
http.sendRequestHeader(rqhdr);
|
http.sendRequestHeader(rqhdr);
|
||||||
|
|
||||||
|
// Receive for response
|
||||||
net::http::ResponseHeader rshdr;
|
net::http::ResponseHeader rshdr;
|
||||||
http.recvResponseHeader(rshdr, 5000);
|
http.recvResponseHeader(rshdr, 5000);
|
||||||
|
|
||||||
|
// Check the status
|
||||||
if (rshdr.getStatusCode() != net::http::STATUS_CODE_OK) {
|
if (rshdr.getStatusCode() != net::http::STATUS_CODE_OK) {
|
||||||
flog::error("HTTP request did not return ok: {}", rshdr.getStatusString());
|
flog::error("HTTP request did not return ok: {}", rshdr.getStatusString());
|
||||||
throw std::runtime_error("HTTP request did not return ok");
|
throw std::runtime_error("HTTP request did not return ok");
|
||||||
@ -48,20 +51,29 @@ void SpectranHTTPClient::setCenterFrequency(uint64_t freq) {
|
|||||||
auto controlSock = net::connect(host, port);
|
auto controlSock = net::connect(host, port);
|
||||||
auto controlHttp = net::http::Client(controlSock);
|
auto controlHttp = net::http::Client(controlSock);
|
||||||
|
|
||||||
// Make request
|
// Encode request body
|
||||||
net::http::RequestHeader rqhdr(net::http::METHOD_PUT, "/control", host);
|
net::http::RequestHeader rqhdr(net::http::METHOD_PUT, "/remoteconfig", host);
|
||||||
char buf[1024];
|
char buf[1024];
|
||||||
sprintf(buf, "{\"frequencyCenter\":%" PRIu64 ",\"frequencySpan\":%" PRIu64 ",\"type\":\"capture\"}", freq, _samplerate);
|
sprintf(buf, "{\"receiverName\": \"Block_IQDemodulator_0\", \"simpleconfig\": {\"main\": {\"centerfreq\": %" PRIu64 ", \"samplerate\": %" PRIu64 ", \"spanfreq\": %" PRIu64 "}}}", freq, _samplerate, _samplerate);
|
||||||
std::string data = buf;
|
std::string data = buf;
|
||||||
char lenBuf[16];
|
char lenBuf[16];
|
||||||
sprintf(lenBuf, "%" PRIu64, (uint64_t)data.size());
|
sprintf(lenBuf, "%" PRIu64, (uint64_t)data.size());
|
||||||
|
|
||||||
|
// Setup request headers
|
||||||
rqhdr.setField("Content-Length", lenBuf);
|
rqhdr.setField("Content-Length", lenBuf);
|
||||||
|
|
||||||
|
// Send request
|
||||||
controlHttp.sendRequestHeader(rqhdr);
|
controlHttp.sendRequestHeader(rqhdr);
|
||||||
controlSock->sendstr(data);
|
controlSock->sendstr(data);
|
||||||
|
|
||||||
|
// Receive response
|
||||||
net::http::ResponseHeader rshdr;
|
net::http::ResponseHeader rshdr;
|
||||||
controlHttp.recvResponseHeader(rshdr, 5000);
|
controlHttp.recvResponseHeader(rshdr, 5000);
|
||||||
|
|
||||||
flog::debug("Response: {}", rshdr.getStatusString());
|
// Log error if there is one
|
||||||
|
if (rshdr.getStatusCode() < 200 || rshdr.getStatusCode() >= 300) {
|
||||||
|
flog::debug("Response: {}", rshdr.getStatusString());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SpectranHTTPClient::worker() {
|
void SpectranHTTPClient::worker() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user