Files
DefaultVPN/client/protocols/vpnprotocol.cpp

129 lines
3.1 KiB
C++
Raw Normal View History

2020-12-26 15:03:51 +03:00
#include <QDebug>
#include <QTimer>
#include "vpnprotocol.h"
2021-01-09 19:55:16 +03:00
#include "core/errorstrings.h"
2021-06-03 20:27:46 +03:00
#include "protocols/protocols_defs.h"
2020-12-26 15:03:51 +03:00
VpnProtocol::VpnProtocol(const QJsonObject &configuration, QObject* parent)
2020-12-26 15:03:51 +03:00
: QObject(parent),
m_connectionState(ConnectionState::Unknown),
m_rawConfig(configuration),
2020-12-26 23:17:20 +03:00
m_timeoutTimer(new QTimer(this)),
m_receivedBytes(0),
m_sentBytes(0)
2020-12-26 15:03:51 +03:00
{
m_timeoutTimer->setSingleShot(true);
connect(m_timeoutTimer, &QTimer::timeout, this, &VpnProtocol::onTimeout);
}
2021-01-06 17:12:24 +03:00
void VpnProtocol::setLastError(ErrorCode lastError)
2020-12-26 23:17:20 +03:00
{
2021-01-06 17:12:24 +03:00
m_lastError = lastError;
2021-01-09 19:55:16 +03:00
if (lastError){
setConnectionState(ConnectionState::Error);
2021-01-09 19:55:16 +03:00
}
qCritical().noquote() << "VpnProtocol error, code" << m_lastError << errorString(m_lastError);
2020-12-26 23:17:20 +03:00
}
2021-01-06 17:12:24 +03:00
ErrorCode VpnProtocol::lastError() const
2020-12-26 23:17:20 +03:00
{
return m_lastError;
}
2020-12-26 15:03:51 +03:00
void VpnProtocol::onTimeout()
{
qDebug() << "Timeout";
emit timeoutTimerEvent();
stop();
}
void VpnProtocol::startTimeoutTimer()
{
m_timeoutTimer->start(30000);
}
void VpnProtocol::stopTimeoutTimer()
{
m_timeoutTimer->stop();
}
VpnProtocol::ConnectionState VpnProtocol::connectionState() const
{
return m_connectionState;
}
void VpnProtocol::setBytesChanged(quint64 receivedBytes, quint64 sentBytes)
{
2020-12-26 23:17:20 +03:00
emit bytesChanged(receivedBytes - m_receivedBytes, sentBytes - m_sentBytes);
m_receivedBytes = receivedBytes;
m_sentBytes = sentBytes;
2020-12-26 15:03:51 +03:00
}
void VpnProtocol::setConnectionState(VpnProtocol::ConnectionState state)
{
qDebug() << "VpnProtocol::setConnectionState" << textConnectionState(state);
2020-12-26 15:03:51 +03:00
if (m_connectionState == state) {
return;
}
if (m_connectionState == ConnectionState::Disconnected && state == ConnectionState::Disconnecting) {
return;
}
2020-12-26 15:03:51 +03:00
m_connectionState = state;
2020-12-26 23:17:20 +03:00
if (m_connectionState == ConnectionState::Disconnected) {
m_receivedBytes = 0;
m_sentBytes = 0;
}
qDebug().noquote() << QString("Connection state: '%1'").arg(textConnectionState());
2020-12-26 15:03:51 +03:00
emit connectionStateChanged(m_connectionState);
}
QString VpnProtocol::vpnGateway() const
{
return m_vpnGateway;
}
QString VpnProtocol::routeGateway() const
{
return m_routeGateway;
}
2020-12-26 15:03:51 +03:00
QString VpnProtocol::textConnectionState(ConnectionState connectionState)
{
switch (connectionState) {
2021-01-08 16:51:58 +03:00
case ConnectionState::Unknown: return tr("Unknown");
case ConnectionState::Disconnected: return tr("Disconnected");
case ConnectionState::Preparing: return tr("Preparing");
2021-01-09 19:55:16 +03:00
case ConnectionState::Connecting: return tr("Connecting...");
2021-01-08 16:51:58 +03:00
case ConnectionState::Connected: return tr("Connected");
2021-01-09 19:55:16 +03:00
case ConnectionState::Disconnecting: return tr("Disconnecting...");
case ConnectionState::Reconnecting: return tr("Reconnecting...");
2021-01-08 16:51:58 +03:00
case ConnectionState::Error: return tr("Error");
2020-12-26 15:03:51 +03:00
default:
;
}
return QString();
}
QString VpnProtocol::textConnectionState() const
{
return textConnectionState(m_connectionState);
}
bool VpnProtocol::isConnected() const
2020-12-26 15:03:51 +03:00
{
return m_connectionState == ConnectionState::Connected;
}
bool VpnProtocol::isDisconnected() const
2020-12-26 15:03:51 +03:00
{
return m_connectionState == ConnectionState::Disconnected;
}