// SPDX-License-Identifier: LGPL-3.0-or-later /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * nymea-mqtt * MQTT library for nymea * * Copyright (C) 2013 - 2024, nymea GmbH * Copyright (C) 2024 - 2025, chargebyte austria GmbH * * This file is part of nymea-mqtt. * * nymea-mqtt is free software: you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public License * as published by the Free Software Foundation, either version 3 * of the License, or (at your option) any later version. * * nymea-mqtt 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with nymea-mqtt. If not, see . * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include "mqtttcpclienttransport.h" MqttTcpClientTransport::MqttTcpClientTransport(const QString &hostName, quint16 port, bool useSsl, const QSslConfiguration &sslConfiguration, QObject *parent): MqttClientTransport(parent), m_hostName(hostName), m_port(port), m_useSsl(useSsl) { m_socket = new QSslSocket(this); m_socket->setSslConfiguration(sslConfiguration); connect(m_socket, &QTcpSocket::connected, this, &MqttClientTransport::connected); connect(m_socket, &QTcpSocket::disconnected, this, &MqttClientTransport::disconnected); connect(m_socket, &QTcpSocket::stateChanged, this, &MqttClientTransport::stateChanged); connect(m_socket, &QTcpSocket::readyRead, this, &MqttTcpClientTransport::onReadyRead); #if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0) connect(m_socket, &QSslSocket::sslErrors, this, &MqttClientTransport::sslErrors); #else typedef void (QSslSocket:: *sslErrorsSignal)(const QList &); connect(m_socket, static_cast(&QSslSocket::sslErrors), this, &MqttClientTransport::sslErrors); #endif #if QT_VERSION >= QT_VERSION_CHECK(5, 15, 0) connect(m_socket, &QTcpSocket::errorOccurred, this, &MqttClientTransport::errorSignal); #else typedef void (QSslSocket:: *errorSignal)(QAbstractSocket::SocketError); connect(m_socket, static_cast(&QSslSocket::error), this, &MqttClientTransport::errorSignal); #endif } void MqttTcpClientTransport::connectToHost() { if (m_useSsl) { m_socket->connectToHostEncrypted(m_hostName, m_port); } else { m_socket->connectToHost(m_hostName, m_port); } } void MqttTcpClientTransport::abort() { m_socket->abort(); } bool MqttTcpClientTransport::isOpen() const { return m_socket->isOpen(); } bool MqttTcpClientTransport::write(const QByteArray &data) { int ret = m_socket->write(data); return ret == data.length(); } void MqttTcpClientTransport::flush() { m_socket->flush(); } void MqttTcpClientTransport::disconnectFromHost() { m_socket->disconnectFromHost(); } QAbstractSocket::SocketState MqttTcpClientTransport::state() const { return m_socket->state(); } void MqttTcpClientTransport::ignoreSslErrors() { m_socket->ignoreSslErrors(); } void MqttTcpClientTransport::onReadyRead() { QByteArray data = m_socket->readAll(); emit dataReceived(data); }