/* * * 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