DYT/Tool/3rdParty_x64/include/dcmtk/dcmsign/siripemd.h

97 lines
2.3 KiB
C
Raw Normal View History

2024-11-22 15:19:31 +00:00
/*
*
* Copyright (C) 1998-2011, OFFIS e.V.
* All rights reserved. See COPYRIGHT file for details.
*
* This software and supporting documentation were developed by
*
* OFFIS e.V.
* R&D Division Health
* Escherweg 2
* D-26121 Oldenburg, Germany
*
*
* Module: dcmsign
*
* Author: Norbert Loxen, Marco Eichelberg
*
* Purpose:
* classes: SiRIPEMD160
*
*/
#ifndef SIRIPEMD_H
#define SIRIPEMD_H
#include "dcmtk/config/osconfig.h"
#include "dcmtk/dcmsign/simac.h"
#include "dcmtk/dcmsign/sitypes.h"
#ifdef WITH_OPENSSL
struct RIPEMD160state_st;
typedef struct RIPEMD160state_st RIPEMD160_CTX;
/**
* a class implementing the hash function RIPEMD160
*/
class DCMTK_DCMSIGN_EXPORT SiRIPEMD160 : public SiMAC
{
public:
/// default constructor
SiRIPEMD160();
/// destructor
virtual ~SiRIPEMD160();
/** initializes the MAC algorithm.
* @return status code
*/
virtual OFCondition initialize();
/** feeds data into the MAC algorithm
* @param data pointer to raw data to be fed into the MAC, must not be NULL
* @param length number of bytes in raw data array
* @return status code
*/
virtual OFCondition digest(const unsigned char *data, unsigned long length);
/** finalizes the MAC and writes it to the given output array,
* which must be at least getSize() bytes large.
* After a call to finalize, the MAC algorithm must be initialized
* again, see initialize().
* @param result pointer to array of getSize() bytes into which the MAC is written
* @return status code
*/
virtual OFCondition finalize(unsigned char *result);
/** returns the size of a MAC in bytes.
* @return block size for this MAC algorithm
*/
virtual unsigned long getSize() const;
/** returns the type of MAC algorithm computed by this object
* @return type of MAC algorithm
*/
virtual E_MACType macType() const;
/** returns the DICOM identifier for this MAC algorithm
* @return DICOM defined term for algorithm
*/
virtual const char *getDefinedTerm() const;
private:
/// private undefined copy constructor
SiRIPEMD160(SiRIPEMD160& arg);
/// private undefined copy assignment operator
SiRIPEMD160& operator=(SiRIPEMD160& arg);
/// OpenSSL RIPEMD 160 context
RIPEMD160_CTX *ctx;
};
#endif
#endif