72 lines
3.0 KiB
C++
72 lines
3.0 KiB
C++
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
*
|
|
* Copyright 2013 - 2021, nymea GmbH
|
|
* Contact: contact@nymea.io
|
|
*
|
|
* This file is part of nymea.
|
|
* This project including source code and documentation is protected by copyright law, and
|
|
* remains the property of nymea GmbH. All rights, including reproduction, publication,
|
|
* editing and translation, are reserved. The use of this project is subject to the terms of a
|
|
* license agreement to be concluded with nymea GmbH in accordance with the terms
|
|
* of use of nymea GmbH, available under https://nymea.io/license
|
|
*
|
|
* GNU General Public License Usage
|
|
* Alternatively, this project may be redistributed and/or modified under
|
|
* the terms of the GNU General Public License as published by the Free Software Foundation,
|
|
* GNU version 3. this project is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with this project.
|
|
* If not, see <https://www.gnu.org/licenses/>.
|
|
*
|
|
* For any further details and any questions please contact us under contact@nymea.io
|
|
* or see our FAQ/Licensing Information on https://nymea.io/license/faq
|
|
*
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
#include "tunnelproxyhandler.h"
|
|
|
|
#include "engine.h"
|
|
#include "jsontypes.h"
|
|
#include "loggingcategories.h"
|
|
|
|
#include "tunnelproxy/tunnelproxymanager.h"
|
|
|
|
namespace remoteproxy {
|
|
|
|
TunnelProxyHandler::TunnelProxyHandler(QObject *parent) : JsonHandler(parent)
|
|
{
|
|
// Methods
|
|
QVariantMap params; QVariantMap returns;
|
|
|
|
params.clear(); returns.clear();
|
|
setDescription("RegisterServer", "Register a new TunnelProxy server on this instance. Multiple TunnelProxy clients can be connected to the registered server on success.");
|
|
params.insert("uuid", JsonTypes::basicTypeToString(JsonTypes::String));
|
|
params.insert("name", JsonTypes::basicTypeToString(JsonTypes::String));
|
|
setParams("RegisterServer", params);
|
|
returns.insert("tunnelProxyError", JsonTypes::tunnelProxyErrorRef());
|
|
setReturns("RegisterServer", returns);
|
|
|
|
}
|
|
|
|
QString TunnelProxyHandler::name() const
|
|
{
|
|
return "TunnelProxy";
|
|
}
|
|
|
|
JsonReply *TunnelProxyHandler::RegisterServer(const QVariantMap ¶ms, TransportClient *transportClient)
|
|
{
|
|
qCDebug(dcJsonRpc()) << name() << "register server" << params << transportClient;
|
|
QUuid serverUuid = params.value("uuid").toUuid();
|
|
QString serverName = params.value("name").toString();
|
|
|
|
TunnelProxyManager::Error error = Engine::instance()->tunnelProxyManager()->registerServer(transportClient->clientId(), serverUuid, serverName);
|
|
|
|
QVariantMap response;
|
|
response.insert("tunnelProxyError", JsonTypes::tunnelProxyErrorToString(error));
|
|
return createReply("RegisterServer", response);
|
|
}
|
|
|
|
}
|