/usr/include/gdcm-2.4/gdcmOpenSSLCryptographicMessageSyntax.h is in libgdcm2-dev 2.4.4-3+deb8u1.
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 | /*=========================================================================
Program: GDCM (Grassroots DICOM). A DICOM library
Copyright (c) 2006-2011 Mathieu Malaterre
All rights reserved.
See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
#ifndef GDCMOPENSSLCRYPTOGRAPHICMESSAGESYNTAX_H
#define GDCMOPENSSLCRYPTOGRAPHICMESSAGESYNTAX_H
#include "gdcmCryptographicMessageSyntax.h"
#include <openssl/cms.h>
#include <openssl/evp.h>
namespace gdcm
{
class GDCM_EXPORT OpenSSLCryptographicMessageSyntax : public CryptographicMessageSyntax
{
public:
OpenSSLCryptographicMessageSyntax();
~OpenSSLCryptographicMessageSyntax();
// X.509
bool ParseCertificateFile( const char *filename );
bool ParseKeyFile( const char *filename );
// PBE
bool SetPassword(const char * pass, size_t passLen);
/// Set Cipher Type.
/// Default is: AES256_CIPHER
void SetCipherType(CipherTypes type);
CipherTypes GetCipherType() const;
/// create a CMS envelopedData structure
bool Encrypt(char *output, size_t &outlen, const char *array, size_t len) const;
/// decrypt content from a PKCS#7 envelopedData structure
bool Decrypt(char *output, size_t &outlen, const char *array, size_t len) const;
private:
//#ifdef GDCM_HAVE_CMS_RECIPIENT_PASSWORD
// ::stack_st_X509 *recips;
//#else
STACK_OF(X509) *recips;
//#endif
::EVP_PKEY *pkey;
const EVP_CIPHER *internalCipherType;
char * password;
size_t passwordLength;
CipherTypes cipherType;
private:
OpenSSLCryptographicMessageSyntax(const OpenSSLCryptographicMessageSyntax&); // Not implemented.
void operator=(const OpenSSLCryptographicMessageSyntax&); // Not implemented.
const EVP_CIPHER *CreateCipher( CryptographicMessageSyntax::CipherTypes ciphertype);
};
} // end namespace gdcm
#endif //GDCMOPENSSLCRYPTOGRAPHICMESSAGESYNTAX_H
|