/usr/include/dcmtk/dcmsign/simaccon.h is in libdcmtk-dev 3.6.1~20160216-4.
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 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 | /*
*
* 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: Marco Eichelberg
*
* Purpose:
* classes: SiMACConstructor
*
*/
#ifndef SIMACCON_H
#define SIMACCON_H
#include "dcmtk/config/osconfig.h"
#include "dcmtk/dcmsign/sitypes.h"
#ifdef WITH_OPENSSL
#include "dcmtk/dcmdata/dcostrmb.h" /* for DcmOutputBufferStream */
#include "dcmtk/dcmdata/dcxfer.h" /* for E_TransferSyntax */
#include "dcmtk/dcmdata/dcdeftag.h"
#define INCLUDE_CSTDIO
#include "dcmtk/ofstd/ofstdinc.h"
class SiMAC;
class DcmItem;
class DcmElement;
class DcmAttributeTag;
/** a class that allows to feed selected parts of a DICOM dataset into the MAC generation code
*/
class DCMTK_DCMSIGN_EXPORT SiMACConstructor
{
public:
/// constructor
SiMACConstructor();
/// destructor
virtual ~SiMACConstructor();
/** encodes a DICOM dataset (or parts of it) as a byte stream in the format
* required for DICOM digital signatures and feeds the byte stream into
* the given MAC codec.
* If a dump file was set with setDumpFile(), the byte stream is written
* to file as well.
* @param item the DICOM dataset to be encoded
* @param mac the MAC codec into which the resulting byte stream is fed
* @param oxfer the transfer syntax to be used when encoding the dataset.
* The caller might wish to use DcmItem::canWriteXfer() to check beforehand
* whether this transfer syntax can be used.
* @param tagListOut upon return this parameter contains the list of attribute
* tags which were fed into the MAC codec. For sequences, only the sequence
* attribute tag is contained in this list; the items and elements within the items
* are not encoded.
* @param tagListIn optional parameter restricting the parts of the dataset
* to be encoded. Only elements which are present in this list of tags,
* which are signable (see DcmTagKey::isSignable()) and are present in the dataset
* are encoded. Upon verification of a signature the caller might wish to compare
* tagListIn and tagListOut after successful return to see whether the lists of
* attributes are the same.
* If parameter is absent or NULL, a global match is assumed, i.e. all elements
* of the dataset which are present and signable are encoded.
* @return status code
*/
OFCondition encodeDataset(
DcmItem& item,
SiMAC& mac,
E_TransferSyntax oxfer,
DcmAttributeTag &tagListOut,
DcmAttributeTag *tagListIn = NULL);
/** encodes the contents of the digital signature sequence
* except CertificateOfSigner, Signature, CertifiedTimestampType
* and CertifiedTimestamp as a byte stream in the format
* required for DICOM digital signatures and feeds the byte stream into
* the given MAC codec.
* If a dump file was set with setDumpFile(), the byte stream is written
* to file as well.
* @param signatureItem the DICOM digital signature item to be encoded
* @param mac the MAC codec into which the resulting byte stream is fed
* @param oxfer the transfer syntax to be used when encoding the dataset.
* The caller might wish to use DcmItem::canWriteXfer() to check beforehand
* whether this transfer syntax can be used.
* @return status code
*/
OFCondition encodeDigitalSignatureItem(
DcmItem& signatureItem,
SiMAC& mac,
E_TransferSyntax oxfer);
/** flushes all buffers inside this object, finalizing the MAC code
* @param mac the MAC codec into which the resulting byte stream is fed
* @return status code
*/
OFCondition flush(SiMAC& mac);
/** dump all data that is fed into the MAC algorithm into the given file,
* which must be opened and closed by caller.
* @param f pointer to file already opened for writing; may be NULL.
*/
void setDumpFile(FILE *f);
private:
/// private undefined copy constructor
SiMACConstructor(SiMACConstructor& arg);
/// private undefined copy assignment operator
SiMACConstructor& operator=(SiMACConstructor& arg);
/** flushes the internal buffer to the given MAC and to dumpFile if open
* @param mac MAC to which the buffer content is added
* @return error code from MAC
*/
OFCondition flushBuffer(SiMAC& mac);
/** feeds a DcmElement into the MAC data stream if is signable.
* If the element is a sequence, all signable elements from all items are added.
* @param element pointer to element, must not be NULL
* @param mac MAC to use
* @param oxfer transfer syntax in which data is encoded
* @return status code
*/
OFCondition encodeElement(DcmElement *element, SiMAC& mac, E_TransferSyntax oxfer);
/** checks whether the attribute tag of the given DcmElement is contained
* in the given list of tags. If the list is absent (NULL), a universal match
* is assumed, i.e. always returns true if element is nonzero.
* Does not check whether an element is signable.
* @param element pointer to element to check
* @param tagList pointer to list of attribute tags, may be NULL
* @return true if attribute is in tag list, false otherwise
*/
static OFBool inTagList(const DcmElement *element, DcmAttributeTag *tagList);
/// the buffer to which data is written
unsigned char *buf;
/// the internal buffer stream
DcmOutputBufferStream stream;
/** if nonzero, the data fed to the MAC algorithm
* is also stored in this file.
*/
FILE *dumpFile;
};
#endif
#endif
|