/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Copyright (C) 2018 Simon Stürz * * * * This file is part of nymea-remoteproxy. * * * * This program is free software: you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation, either version 3 of the License, or * * (at your option) any later version. * * * * This program 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 program. If not, see . * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include "engine.h" #include "proxyclient.h" #include namespace remoteproxy { ProxyClient::ProxyClient(TransportInterface *interface, const QUuid &clientId, const QHostAddress &address, QObject *parent) : QObject(parent), m_interface(interface), m_clientId(clientId), m_peerAddress(address) { m_creationTimeStamp = QDateTime::currentDateTime().toTime_t(); connect(&m_timer, &QTimer::timeout, this, &ProxyClient::timeoutOccured); m_timer.setSingleShot(true); m_timer.start(Engine::instance()->configuration()->inactiveTimeout()); } QUuid ProxyClient::clientId() const { return m_clientId; } QHostAddress ProxyClient::peerAddress() const { return m_peerAddress; } uint ProxyClient::creationTime() const { return m_creationTimeStamp; } QString ProxyClient::creationTimeString() const { return QDateTime::fromTime_t(creationTime()).toString("dd.MM.yyyy hh:mm:ss"); } bool ProxyClient::isAuthenticated() const { return m_authenticated; } void ProxyClient::setAuthenticated(bool isAuthenticated) { m_authenticated = isAuthenticated; if (m_authenticated) { m_timer.stop(); m_timer.start(Engine::instance()->configuration()->aloneTimeout()); emit authenticated(); } } bool ProxyClient::isTunnelConnected() const { return m_tunnelConnected; } void ProxyClient::setTunnelConnected(bool isTunnelConnected) { m_tunnelConnected = isTunnelConnected; if (m_tunnelConnected) { m_timer.stop(); emit tunnelConnected(); } } TransportInterface *ProxyClient::interface() const { return m_interface; } QString ProxyClient::uuid() const { return m_uuid; } void ProxyClient::setUuid(const QString &uuid) { m_uuid = uuid; } QString ProxyClient::name() const { return m_name; } void ProxyClient::setName(const QString &name) { m_name = name; } QString ProxyClient::token() const { return m_token; } void ProxyClient::setToken(const QString &token) { m_token = token; } void ProxyClient::sendData(const QByteArray &data) { if (!m_interface) return; m_interface->sendData(m_clientId, data); } void ProxyClient::killConnection(const QString &reason) { if (!m_interface) return; m_interface->killClientConnection(m_clientId, reason); } QDebug operator<<(QDebug debug, ProxyClient *proxyClient) { debug.nospace() << "ProxyClient("; if (!proxyClient->name().isEmpty()) { debug.nospace() << proxyClient->name() << ", "; } debug.nospace() << proxyClient->interface()->serverName(); debug.nospace() << ", " << proxyClient->clientId().toString(); debug.nospace() << ", " << proxyClient->peerAddress().toString(); debug.nospace() << ", " << proxyClient->creationTimeString() << ") "; return debug; } }