/usr/include/sipxtapi/utl/UtlCryptoKeyRsa.h is in libsipxtapi-dev 3.3.0~test17-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 | //
// Copyright (C) 2008 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2008 SIPez LLC.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// Copyright (C) 2008 Mutualink, Inc.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
//////////////////////////////////////////////////////////////////////////////
// Author: Sergey Kostanbaev <Sergey DOT Kostanbaev AT sipez DOT com>
#ifndef _UtlCryptoKeyRsa_h_
#define _UtlCryptoKeyRsa_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include "utl/UtlCryptoKey.h"
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
/**
* @brief Rsa private/public keypairs.
*/
class UtlCryptoKeyRsa : public UtlCryptoKey
{
/* //////////////////////////////// PUBLIC //////////////////////////////// */
public:
/* =============================== CREATORS =============================== */
///@name Creators
//@{
/// Constructor
UtlCryptoKeyRsa();
/// Destructor
~UtlCryptoKeyRsa();
//@}
/* ============================= MANIPULATORS ============================= */
///@name Manipulators
//@{
int generateKey();
int importFromFile(const char* pFilename);
int getMaxEncryptedSize(int srcLen) const;
/// @copydoc UtlCryptoKey::encrypt
int encrypt(const unsigned char* pSrc,
int srcLen,
unsigned char* pDest,
int* pDestLen) const;
//UtlCryptoData* encrypt(const unsigned char* pSrc, int srcLen) const
//{ return UtlCryptoKey::encrypt(pSrc, srcLen); }
int getMaxDecryptedSize(int srcLen) const;
/// @copydoc UtlCryptoKey::decrypt
int decrypt(const unsigned char* pSrc,
int srcLen,
unsigned char* pDest,
int* pDestLen) const;
/// Returns the max size of a signature that sign() will return
int getMaxSignatureSize(int srcLen) const;
/// @copydoc UtlCryptoKey::sign
int sign(const unsigned char* pSrc,
int srcLen,
unsigned char* pDest,
int* pDestLen) const;
/// @copydoc UtlCryptoKey::verify
int verify(const unsigned char* pSrc,
int srcLen,
const unsigned char* pSig,
int sigLen) const;
/// Decrypts the given source data with the current PRIVATE key
int encryptPrivate(const unsigned char* pSrc,
int srcLen,
unsigned char* pDest,
int* pDestLen) const;
/**<
* @param[in] pSrc - Source data
* @param[in] srcLen - Source data len
* @param[out] pDest - Destination buffer
* @param[in,out] pDestLen - Size of destination buffer and
* actual decrypted size after operation
*
* @return Length of the encrypted data (0 on error)
*/
/// Decrypts the given source data with the current PRIVATE key
int decryptPrivate(const unsigned char* pSrc,
int srcLen,
unsigned char* pDest,
int* pDestLen) const;
/**<
* @param[in] pSrc - Source data
* @param[in] srcLen - Source data len
* @param[out] pDest - Destination buffer
* @param[in,out] pDestLen - Size of destination buffer and
* actual decrypted size after operation
*
* @return Length of the decrypted data (0 on error)
*/
/// Encrypts the given source data with the current PUBLIC key
int encryptPublic(const unsigned char* pSrc,
int srcLen,
unsigned char* pDest,
int* pDestLen) const;
/**<
* @param[in] pSrc - Source data
* @param[in] srcLen - Source data len
* @param[out] pDest - Destination buffer
* @param[in,out] pDestLen - Size of destination buffer and
* actual decrypted size after operation
*
* @return Length of the encrypted data (0 on error)
*/
/// Decrypts the given source data with the current PUBLIC key
int decryptPublic(const unsigned char* pSrc,
int srcLen,
unsigned char* pDest,
int* pDestLen) const;
/**<
* @param[in] pSrc - Source data
* @param[in] srcLen - Source data len
* @param[out] pDest - Destination buffer
* @param[in,out] pDestLen - Size of destination buffer and
* actual decrypted size after operation
*
* @return Length of the decrypted data (0 on error)
*/
//@}
/* ============================== ACCESSORS =============================== */
///@name Accessors
//@{
//@}
/* =============================== INQUIRY ================================ */
///@name Inquiry
//@{
/// Get humane-readable describe
UtlString output() const;
//@}
/* ////////////////////////////// PROTECTED /////////////////////////////// */
protected:
/* /////////////////////////////// PRIVATE //////////////////////////////// */
private:
void clearKey();
RSA* mpRsa; ///< Internal (transparent) openssl struct
};
/* ============================ INLINE METHODS ============================ */
#endif // _UtlCryptoKeyRsa_h_
|