diff options
Diffstat (limited to 'core/messageengine.cpp')
-rw-r--r-- | core/messageengine.cpp | 90 |
1 files changed, 0 insertions, 90 deletions
diff --git a/core/messageengine.cpp b/core/messageengine.cpp deleted file mode 100644 index 42fe95b..0000000 --- a/core/messageengine.cpp +++ /dev/null @@ -1,90 +0,0 @@ -/* - * Copyright (C) 2017-2020 Konsulko Group - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -#include <QJsonArray> -#include <QDebug> - -#include "message.h" -#include "messagefactory.h" -#include "messageengine.h" - - -MessageEngine::MessageEngine(const QUrl &url) : - QObject(Q_NULLPTR), - m_callid(0), - m_url(url) -{ - connect(&m_websocket, &QWebSocket::connected, this, &MessageEngine::onConnected); - connect(&m_websocket, &QWebSocket::disconnected, this, &MessageEngine::onDisconnected); - - m_websocket.open(url); -} - -bool MessageEngine::sendMessage(std::unique_ptr<Message> msg) -{ - if (!msg) - return false; - - unsigned int callid = m_callid++; - QByteArray forkeeps = msg->send(m_websocket, callid); - if (forkeeps.isEmpty()) - return false; - - std::lock_guard<std::mutex> localguard(m_mutex); - m_calls.insert(callid, forkeeps); - - return true; -} - -void MessageEngine::onConnected() -{ - connect(&m_websocket, &QWebSocket::textMessageReceived, this, &MessageEngine::onTextMessageReceived); - emit connected(); -} - -void MessageEngine::onDisconnected() -{ - disconnect(&m_websocket, &QWebSocket::textMessageReceived, this, &MessageEngine::onTextMessageReceived); - emit disconnected(); -} - -void MessageEngine::onTextMessageReceived(QString jsonStr) -{ - jsonStr = jsonStr.simplified(); - QJsonDocument jdoc(QJsonDocument::fromJson(jsonStr.toUtf8())); - if (jdoc.isEmpty()) { - qWarning() << "Received invalid JSON: empty appfw message"; - return; - } - - MessageId id = Message::isValid(jdoc); - if (id == MessageId::Invalid) { - qWarning() << "Received unknown message, discarding"; - return; - } - - std::shared_ptr<Message> message = MessageFactory::getInstance().createInboundMessage(id, jdoc); - - unsigned int callid; - if (message->isReply() && message->getCallId(&callid)) { - message->setAdditionalData(m_calls[callid]); - std::lock_guard<std::mutex> localguard(m_mutex); - m_calls.remove(callid); - } - - if (message->isComplete()) - emit messageReceived(message); -} |