mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-07-20 15:57:13 +02:00
bin
module
vendor
CPR
ConcurrentQueue
Fmt
MaxmindDB
POCO
ApacheConnector
CppParser
CppUnit
Crypto
cmake
include
Poco
Crypto
Cipher.h
CipherFactory.h
CipherImpl.h
CipherKey.h
CipherKeyImpl.h
Crypto.h
CryptoException.h
CryptoStream.h
CryptoTransform.h
DigestEngine.h
ECDSADigestEngine.h
ECKey.h
ECKeyImpl.h
EVPPKey.h
KeyPair.h
KeyPairImpl.h
OpenSSLInitializer.h
PKCS12Container.h
RSACipherImpl.h
RSADigestEngine.h
RSAKey.h
RSAKeyImpl.h
X509Certificate.h
samples
src
testsuite
CMakeLists.txt
Crypto.progen
Crypto_VS90.sln
Crypto_VS90.vcproj
Crypto_vs140.sln
Crypto_vs140.vcxproj
Crypto_vs140.vcxproj.filters
Crypto_vs150.sln
Crypto_vs150.vcxproj
Crypto_vs150.vcxproj.filters
Crypto_vs160.sln
Crypto_vs160.vcxproj
Crypto_vs160.vcxproj.filters
Makefile
dependencies
Data
Encodings
Foundation
JSON
JWT
MongoDB
Net
NetSSL_OpenSSL
NetSSL_Win
PDF
PageCompiler
PocoDoc
ProGen
Redis
SevenZip
Util
XML
Zip
appveyor
build
cmake
contrib
doc
packaging
patches
release
travis
.gitattributes
.gitignore
.gitmodules
.travis.yml
CHANGELOG
CMakeLists.txt
CODE_OF_CONDUCT.md
CONTRIBUTING.md
CONTRIBUTORS
LICENSE
Makefile
NEWS
README
README.md
VERSION
appveyor.yml
build_cmake.cmd
build_cmake.sh
build_vs140.cmd
build_vs150.cmd
build_vs160.cmd
buildwin.cmd
buildwin.ps1
components
configure
cppignore.lnx
cppignore.win
env.bat
env.sh
libversion
SimpleIni
Squirrel
TinyDir
CMakeLists.txt
.gitignore
.gitmodules
CMakeLists.txt
LICENSE
README.md
Switched to POCO library for unified platform/library interface. Deprecated the external module API. It was creating more problems than solving. Removed most built-in libraries in favor of system libraries for easier maintenance. Cleaned and secured code with help from static analyzers.
141 lines
3.4 KiB
C++
141 lines
3.4 KiB
C++
//
|
|
// RSAKeyImpl.h
|
|
//
|
|
// Library: Crypto
|
|
// Package: RSA
|
|
// Module: RSAKeyImpl
|
|
//
|
|
// Definition of the RSAKeyImpl class.
|
|
//
|
|
// Copyright (c) 2008, Applied Informatics Software Engineering GmbH.
|
|
// and Contributors.
|
|
//
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
//
|
|
|
|
|
|
#ifndef Crypto_RSAKeyImplImpl_INCLUDED
|
|
#define Crypto_RSAKeyImplImpl_INCLUDED
|
|
|
|
|
|
#include "Poco/Crypto/Crypto.h"
|
|
#include "Poco/Crypto/EVPPKey.h"
|
|
#include "Poco/Crypto/KeyPairImpl.h"
|
|
#include "Poco/Crypto/OpenSSLInitializer.h"
|
|
#include "Poco/RefCountedObject.h"
|
|
#include "Poco/AutoPtr.h"
|
|
#include <istream>
|
|
#include <ostream>
|
|
#include <vector>
|
|
|
|
|
|
struct bignum_st;
|
|
struct rsa_st;
|
|
typedef struct bignum_st BIGNUM;
|
|
typedef struct rsa_st RSA;
|
|
|
|
|
|
namespace Poco {
|
|
namespace Crypto {
|
|
|
|
|
|
class X509Certificate;
|
|
class PKCS12Container;
|
|
|
|
|
|
class RSAKeyImpl: public KeyPairImpl
|
|
/// class RSAKeyImpl
|
|
{
|
|
public:
|
|
using Ptr = Poco::AutoPtr<RSAKeyImpl>;
|
|
using ByteVec = std::vector<unsigned char>;
|
|
|
|
RSAKeyImpl(const EVPPKey& key);
|
|
/// Constructs ECKeyImpl by extracting the EC key.
|
|
|
|
RSAKeyImpl(const X509Certificate& cert);
|
|
/// Extracts the RSA public key from the given certificate.
|
|
|
|
RSAKeyImpl(const PKCS12Container& cert);
|
|
/// Extracts the EC private key from the given certificate.
|
|
|
|
RSAKeyImpl(int keyLength, unsigned long exponent);
|
|
/// Creates the RSAKey. Creates a new public/private keypair using the given parameters.
|
|
/// Can be used to sign data and verify signatures.
|
|
|
|
RSAKeyImpl(const std::string& publicKeyFile, const std::string& privateKeyFile, const std::string& privateKeyPassphrase);
|
|
/// Creates the RSAKey, by reading public and private key from the given files and
|
|
/// using the given passphrase for the private key. Can only by used for signing if
|
|
/// a private key is available.
|
|
|
|
RSAKeyImpl(std::istream* pPublicKeyStream, std::istream* pPrivateKeyStream, const std::string& privateKeyPassphrase);
|
|
/// Creates the RSAKey. Can only by used for signing if pPrivKey
|
|
/// is not null. If a private key file is specified, you don't need to
|
|
/// specify a public key file. OpenSSL will auto-create it from the private key.
|
|
|
|
~RSAKeyImpl();
|
|
/// Destroys the RSAKeyImpl.
|
|
|
|
RSA* getRSA();
|
|
/// Returns the OpenSSL RSA object.
|
|
|
|
const RSA* getRSA() const;
|
|
/// Returns the OpenSSL RSA object.
|
|
|
|
int size() const;
|
|
/// Returns the RSA modulus size.
|
|
|
|
ByteVec modulus() const;
|
|
/// Returns the RSA modulus.
|
|
|
|
ByteVec encryptionExponent() const;
|
|
/// Returns the RSA encryption exponent.
|
|
|
|
ByteVec decryptionExponent() const;
|
|
/// Returns the RSA decryption exponent.
|
|
|
|
void save(const std::string& publicKeyFile,
|
|
const std::string& privateKeyFile = "",
|
|
const std::string& privateKeyPassphrase = "") const;
|
|
/// Exports the public and private keys to the given files.
|
|
///
|
|
/// If an empty filename is specified, the corresponding key
|
|
/// is not exported.
|
|
|
|
void save(std::ostream* pPublicKeyStream,
|
|
std::ostream* pPrivateKeyStream = 0,
|
|
const std::string& privateKeyPassphrase = "") const;
|
|
/// Exports the public and private key to the given streams.
|
|
///
|
|
/// If a null pointer is passed for a stream, the corresponding
|
|
/// key is not exported.
|
|
|
|
private:
|
|
RSAKeyImpl();
|
|
|
|
void freeRSA();
|
|
static ByteVec convertToByteVec(const BIGNUM* bn);
|
|
|
|
RSA* _pRSA;
|
|
};
|
|
|
|
|
|
//
|
|
// inlines
|
|
//
|
|
inline RSA* RSAKeyImpl::getRSA()
|
|
{
|
|
return _pRSA;
|
|
}
|
|
|
|
|
|
inline const RSA* RSAKeyImpl::getRSA() const
|
|
{
|
|
return _pRSA;
|
|
}
|
|
|
|
|
|
} } // namespace Poco::Crypto
|
|
|
|
|
|
#endif // Crypto_RSAKeyImplImpl_INCLUDED
|