From fe12b36fcef3fbf99dbe8a680614e04a08f18b73 Mon Sep 17 00:00:00 2001 From: Andreas Ganske Date: Mon, 19 Aug 2019 20:25:16 +0200 Subject: [PATCH] Make origin in schema-image optional (#610) * Make origin in schema-image optional ... like in `color` and `effect` schemes. * use origin if available --- libsrc/api/JSONRPC_schema/schema-image.json | 4 +++- libsrc/api/JsonAPI.cpp | 7 ++++--- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/libsrc/api/JSONRPC_schema/schema-image.json b/libsrc/api/JSONRPC_schema/schema-image.json index 50674717..51d058da 100644 --- a/libsrc/api/JSONRPC_schema/schema-image.json +++ b/libsrc/api/JSONRPC_schema/schema-image.json @@ -18,7 +18,9 @@ }, "origin": { "type": "string", - "required": true + "minLength" : 4, + "maxLength" : 20, + "required": false }, "duration": { "type": "integer", diff --git a/libsrc/api/JsonAPI.cpp b/libsrc/api/JsonAPI.cpp index 8efd5120..1b8239e9 100644 --- a/libsrc/api/JsonAPI.cpp +++ b/libsrc/api/JsonAPI.cpp @@ -210,7 +210,7 @@ void JsonAPI::handleColorCommand(const QJsonObject& message, const QString& comm // extract parameters int priority = message["priority"].toInt(); int duration = message["duration"].toInt(-1); - const QString origin = message["origin"].toString("Empty") + "@"+_peerAddress; + const QString origin = message["origin"].toString("JsonRpc") + "@"+_peerAddress; const QJsonArray & jsonColor = message["color"].toArray(); const ColorRgb color = {uint8_t(jsonColor.at(0).toInt()),uint8_t(jsonColor.at(1).toInt()),uint8_t(jsonColor.at(2).toInt())}; @@ -228,6 +228,7 @@ void JsonAPI::handleImageCommand(const QJsonObject& message, const QString& comm // extract parameters int priority = message["priority"].toInt(); + const QString origin = message["origin"].toString("JsonRpc") + "@"+_peerAddress; int duration = message["duration"].toInt(-1); int width = message["imagewidth"].toInt(); int height = message["imageheight"].toInt(); @@ -244,7 +245,7 @@ void JsonAPI::handleImageCommand(const QJsonObject& message, const QString& comm Image image(width, height); memcpy(image.memptr(), data.data(), data.size()); - _hyperion->registerInput(priority, hyperion::COMP_IMAGE, "JsonRpc@"+_peerAddress); + _hyperion->registerInput(priority, hyperion::COMP_IMAGE, origin); _hyperion->setInputImage(priority, image, duration); // send reply @@ -259,7 +260,7 @@ void JsonAPI::handleEffectCommand(const QJsonObject &message, const QString &com int priority = message["priority"].toInt(); int duration = message["duration"].toInt(-1); QString pythonScript = message["pythonScript"].toString(); - QString origin = message["origin"].toString("Empty") + "@"+_peerAddress; + QString origin = message["origin"].toString("JsonRpc") + "@"+_peerAddress; const QJsonObject & effect = message["effect"].toObject(); const QString & effectName = effect["name"].toString(); const QString & data = message["imageData"].toString("").toUtf8();