/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of Qt Creator. ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3 as published by the Free Software ** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-3.0.html. ** ****************************************************************************/ #pragma once #include "sshconnection.h" #include "sshexception_p.h" #include "sshincomingpacket_p.h" #include "sshsendfacility_p.h" #include #include #include #include #include #include #include QT_BEGIN_NAMESPACE class QTcpSocket; QT_END_NAMESPACE namespace QSsh { class SftpChannel; class SshRemoteProcess; class SshDirectTcpIpTunnel; class SshTcpIpForwardServer; namespace Internal { class SshChannelManager; // NOTE: When you add stuff here, don't forget to update m_packetHandlers. enum SshStateInternal { SocketUnconnected, // initial and after disconnect SocketConnecting, // After connectToHost() SocketConnected, // After socket's connected() signal UserAuthServiceRequested, WaitingForAgentKeys, UserAuthRequested, ConnectionEstablished // After service has been started // ... }; enum SshKeyExchangeState { NoKeyExchange, KexInitSent, DhInitSent, NewKeysSent, KeyExchangeSuccess // After server's DH_REPLY message }; class SshConnectionPrivate : public QObject { Q_OBJECT friend class QSsh::SshConnection; public: SshConnectionPrivate(SshConnection *conn, const SshConnectionParameters &serverInfo); ~SshConnectionPrivate(); void connectToHost(); void closeConnection(SshErrorCode sshError, SshError userError, const QByteArray &serverErrorString, const QString &userErrorString); QSharedPointer createRemoteProcess(const QByteArray &command); QSharedPointer createRemoteShell(); QSharedPointer createSftpChannel(); QSharedPointer createDirectTunnel(const QString &originatingHost, quint16 originatingPort, const QString &remoteHost, quint16 remotePort); QSharedPointer createForwardServer(const QString &remoteHost, quint16 remotePort); SshStateInternal state() const { return m_state; } SshError errorState() const { return m_error; } QString errorString() const { return m_errorString; } signals: void connected(); void disconnected(); void dataAvailable(const QString &message); void error(QSsh::SshError); private: void handleSocketConnected(); void handleIncomingData(); void handleSocketError(); void handleSocketDisconnected(); void handleTimeout(); void sendKeepAlivePacket(); void handleAgentKeysUpdated(); void handleSignatureFromAgent(const QByteArray &key, const QByteArray &signature, uint token); void tryAllAgentKeys(); void authenticateWithPublicKey(); void setAgentError(); void handleServerId(); void handlePackets(); void handleCurrentPacket(); void handleKeyExchangeInitPacket(); void handleKeyExchangeReplyPacket(); void handleNewKeysPacket(); void handleServiceAcceptPacket(); void handlePasswordExpiredPacket(); void handleUserAuthInfoRequestPacket(); void handleUserAuthSuccessPacket(); void handleUserAuthFailurePacket(); void handleUserAuthKeyOkPacket(); void handleUserAuthBannerPacket(); void handleUnexpectedPacket(); void handleGlobalRequest(); void handleDebugPacket(); void handleUnimplementedPacket(); void handleChannelRequest(); void handleChannelOpen(); void handleChannelOpenFailure(); void handleChannelOpenConfirmation(); void handleChannelSuccess(); void handleChannelFailure(); void handleChannelWindowAdjust(); void handleChannelData(); void handleChannelExtendedData(); void handleChannelEof(); void handleChannelClose(); void handleDisconnect(); void handleRequestSuccess(); void handleRequestFailure(); bool canUseSocket() const; void createPrivateKey(); void sendData(const QByteArray &data); uint tokenForAgent() const; typedef void (SshConnectionPrivate::*PacketHandler)(); typedef QList StateList; void setupPacketHandlers(); void setupPacketHandler(SshPacketType type, const StateList &states, PacketHandler handler); typedef QPair HandlerInStates; QHash m_packetHandlers; static const quint64 InvalidSeqNr; QTcpSocket *m_socket; SshStateInternal m_state; SshKeyExchangeState m_keyExchangeState; SshIncomingPacket m_incomingPacket; SshSendFacility m_sendFacility; SshChannelManager * const m_channelManager; const SshConnectionParameters m_connParams; QByteArray m_incomingData; SshError m_error; QString m_errorString; QScopedPointer m_keyExchange; QTimer m_timeoutTimer; QTimer m_keepAliveTimer; bool m_ignoreNextPacket; SshConnection *m_conn; quint64 m_lastInvalidMsgSeqNr; QByteArray m_serverId; QByteArray m_agentSignature; QQueue m_pendingKeyChecks; QByteArray m_agentKeyToUse; bool m_serverHasSentDataBeforeId; bool m_triedAllPasswordBasedMethods; bool m_agentKeysUpToDate; }; } // namespace Internal } // namespace QSsh