/usr/include/gdcm-2.6/gdcmCAPICryptographicMessageSyntax.h is in libgdcm2-dev 2.6.6-3.
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 | /*=========================================================================
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 GDCMCAPICRYPTOGRAPHICMESSAGESYNTAX_H
#define GDCMCAPICRYPTOGRAPHICMESSAGESYNTAX_H
#include "gdcmCryptographicMessageSyntax.h"
#include <windows.h>
#include <wincrypt.h>
#include <vector>
namespace gdcm
{
class GDCM_EXPORT CAPICryptographicMessageSyntax : public CryptographicMessageSyntax
{
public:
CAPICryptographicMessageSyntax();
~CAPICryptographicMessageSyntax();
// X.509
bool ParseCertificateFile( const char *filename );
bool ParseKeyFile( const char *filename );
// PBE
bool SetPassword(const char * pass, size_t passLen);
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 CMS envelopedData structure
bool Decrypt(char *output, size_t &outlen, const char *array, size_t len) const;
bool GetInitialized() const
{
return initialized;
}
private:
bool Initialize();
static ALG_ID GetAlgIdByObjId(const char * pszObjId);
const char *GetCipherObjId() const;
static void ReverseBytes(BYTE* data, DWORD len);
static bool LoadFile(const char * filename, BYTE* & buffer, DWORD & bufLen);
private:
bool initialized;
HCRYPTPROV hProv;
std::vector<PCCERT_CONTEXT> certifList;
HCRYPTKEY hRsaPrivK;
CipherTypes cipherType;
};
} // end namespace gdcm
#endif //GDCMCAPICRYPTOGRAPHICMESSAGESYNTAX_H
|