/**************************************************************************** ** ** Copyright (C) 2015 The Qt Company Ltd. ** Contact: http://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 http://www.qt.io/terms-conditions. For further information ** use the contact form at http://www.qt.io/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 or version 3 as published by the Free ** Software Foundation and appearing in the file LICENSE.LGPLv21 and ** LICENSE.LGPLv3 included in the packaging of this file. Please review the ** following information to ensure the GNU Lesser General Public License ** requirements will be met: https://www.gnu.org/licenses/lgpl.html and ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, The Qt Company gives you certain additional ** rights. These rights are described in The Qt Company LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ****************************************************************************/ #ifndef SSHBOTANCONVERSIONS_P_H #define SSHBOTANCONVERSIONS_P_H #include "sshcapabilities_p.h" #include "sshexception_p.h" #include namespace QSsh { namespace Internal { inline const Botan::byte *convertByteArray(const QByteArray &a) { return reinterpret_cast(a.constData()); } inline Botan::byte *convertByteArray(QByteArray &a) { return reinterpret_cast(a.data()); } inline QByteArray convertByteArray(const Botan::SecureVector &v) { return QByteArray(reinterpret_cast(v.begin()), v.size()); } inline const char *botanKeyExchangeAlgoName(const QByteArray &rfcAlgoName) { if (rfcAlgoName == SshCapabilities::DiffieHellmanGroup1Sha1) return "modp/ietf/1024"; if (rfcAlgoName == SshCapabilities::DiffieHellmanGroup14Sha1) return "modp/ietf/2048"; if (rfcAlgoName == SshCapabilities::EcdhNistp256) return "secp256r1"; if (rfcAlgoName == SshCapabilities::EcdhNistp384) return "secp384r1"; if (rfcAlgoName == SshCapabilities::EcdhNistp521) return "secp521r1"; throw SshClientException(SshInternalError, SSH_TR("Unexpected key exchange algorithm \"%1\"") .arg(QString::fromLatin1(rfcAlgoName))); } inline const char *botanCryptAlgoName(const QByteArray &rfcAlgoName) { if (rfcAlgoName == SshCapabilities::CryptAlgoAes128Cbc || rfcAlgoName == SshCapabilities::CryptAlgoAes128Ctr) { return "AES-128"; } if (rfcAlgoName == SshCapabilities::CryptAlgo3DesCbc || rfcAlgoName == SshCapabilities::CryptAlgo3DesCtr) { return "TripleDES"; } if (rfcAlgoName == SshCapabilities::CryptAlgoAes192Ctr) { return "AES-192"; } if (rfcAlgoName == SshCapabilities::CryptAlgoAes256Ctr) { return "AES-256"; } throw SshClientException(SshInternalError, SSH_TR("Unexpected cipher \"%1\"") .arg(QString::fromLatin1(rfcAlgoName))); } inline const char *botanEmsaAlgoName(const QByteArray &rfcAlgoName) { if (rfcAlgoName == SshCapabilities::PubKeyDss) return "EMSA1(SHA-1)"; if (rfcAlgoName == SshCapabilities::PubKeyRsa) return "EMSA3(SHA-1)"; if (rfcAlgoName == SshCapabilities::PubKeyEcdsa) return "EMSA1_BSI(SHA-256)"; throw SshClientException(SshInternalError, SSH_TR("Unexpected host key algorithm \"%1\"") .arg(QString::fromLatin1(rfcAlgoName))); } inline const char *botanHMacAlgoName(const QByteArray &rfcAlgoName) { if (rfcAlgoName == SshCapabilities::HMacSha1) return "SHA-1"; if (rfcAlgoName == SshCapabilities::HMacSha256) return "SHA-256"; if (rfcAlgoName == SshCapabilities::HMacSha384) return "SHA-384"; if (rfcAlgoName == SshCapabilities::HMacSha512) return "SHA-512"; throw SshClientException(SshInternalError, SSH_TR("Unexpected hashing algorithm \"%1\"") .arg(QString::fromLatin1(rfcAlgoName))); } inline quint32 botanHMacKeyLen(const QByteArray &rfcAlgoName) { Q_ASSERT(rfcAlgoName == SshCapabilities::HMacSha1 || rfcAlgoName == SshCapabilities::HMacSha256); if (rfcAlgoName == SshCapabilities::HMacSha1) return 20; return 32; } } // namespace Internal } // namespace QSsh #endif // SSHBOTANCONVERSIONS_P_H