⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sisprof.h

📁 转化为DIB位图再显示出来的dicom文件C++代码
💻 H
字号:
/* * *  Copyright (C) 1998-2005, OFFIS * *  This software and supporting documentation were developed by * *    Kuratorium OFFIS e.V. *    Healthcare Information and Communication Systems *    Escherweg 2 *    D-26121 Oldenburg, Germany * *  THIS SOFTWARE IS MADE AVAILABLE,  AS IS,  AND OFFIS MAKES NO  WARRANTY *  REGARDING  THE  SOFTWARE,  ITS  PERFORMANCE,  ITS  MERCHANTABILITY  OR *  FITNESS FOR ANY PARTICULAR USE, FREEDOM FROM ANY COMPUTER DISEASES  OR *  ITS CONFORMITY TO ANY SPECIFICATION. THE ENTIRE RISK AS TO QUALITY AND *  PERFORMANCE OF THE SOFTWARE IS WITH THE USER. * *  Module: dcmsign * *  Author: Norbert Loxen, Marco Eichelberg * *  Purpose: *    classes: SiSecurityProfile * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:04:45 $ *  CVS/RCS Revision: $Revision: 1.6 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef SISPROF_H#define SISPROF_H#include "dcmtk/config/osconfig.h"#include "dcmtk/dcmsign/sitypes.h"  /* for E_KeyType */#ifdef WITH_OPENSSL#include "dcmtk/dcmdata/dcxfer.h"   /* for E_TransferSyntax */class SiAlgorithm;class DcmItem;class DcmAttributeTag;class SiMAC;class DcmTagKey;/** abstract base class for all security profiles. */class SiSecurityProfile{public:  /// default constructor  SiSecurityProfile() { }  /// destructor  virtual ~SiSecurityProfile() { }    /** checks whether the given MAC type can be used with this security profile.   *  @param macType MAC type to be checked   *  @return true if MAC type is allowable for this profile, false otherwise.   */  virtual OFBool isAllowableMACType(E_MACType macType) const = 0;  /** checks whether the given MAC object can be used with this security profile.   *  @param macType object to be checked   *  @return true if object is allowable for this profile, false otherwise.   */  virtual OFBool isAllowableMAC(const SiMAC& mac) const;  /** checks whether the given public/private key algorithm can be used with this security profile.   *  @param keyType public key algorithm type to be checked   *  @return true if public key algorithm is allowable for this profile, false otherwise.   */  virtual OFBool isAllowableAlgorithmType(E_KeyType keyType) const = 0;    /** checks whether the given public/private key object can be used with this security profile.   *  @param algo object to be checked   *  @return true if object is allowable for this profile, false otherwise.   */  virtual OFBool isAllowableAlgorithm(const SiAlgorithm& algo) const;  /** checks whether the given transfer syntax can be used with this security profile   *  @param xfer transfer syntax to be checked   *  @return true if transfer syntax is allowable for this profile, false otherwise.   */  virtual OFBool isAllowableTransferSyntax(E_TransferSyntax xfer) const = 0;    /** checks whether an attribute with the given tag is required to be signed   *  for the current security profile.   *  @param key tag key to be checked   *  @return true if required, false otherwise.   */  virtual OFBool attributeRequired(const DcmTagKey& key) const = 0;  /** checks whether an attribute with the given tag must not be signed   *  for the current security profile.   *  @param key tag key to be checked   *  @return true if attribute must not be signed, false otherwise.   */  virtual OFBool attributeForbidden(const DcmTagKey& key) const = 0;    /** updates the given list of attribute tags according to the   *  requirements of the current security profile. For all elements present in the   *  dataset, the attribute tag is inserted or removed from the list if required by the profile.   *  @param item dataset to be handled   *  @param tagList attribute tag list to be updated   *  @return status code   */  virtual OFCondition updateAttributeList(DcmItem &item, DcmAttributeTag& tagList);  /** checks whether the given list of attribute tags fulfils the requirements   *  of the current security profile for the given dataset.    *  @param item dataset to be checked   *  @param tagList attribute tag list.    *  @return true if minimum requirements for profile are fulfilled, false otherwise.   */   virtual OFBool checkAttributeList(DcmItem &item, DcmAttributeTag& tagList);  /** checks if the given tag key is contained in the given list.   *  @param tagList list of tag keys   *  @param key tag key   *  @return true if tag key is present in list, false otherwise.   */  static OFBool containsTag(DcmAttributeTag& tagList, const DcmTagKey& key);private:  /// private undefined copy constructor  SiSecurityProfile(SiSecurityProfile& arg);  /// private undefined copy assignment operator  SiSecurityProfile& operator=(SiSecurityProfile& arg);};#endif#endif/* *  $Log: sisprof.h,v $ *  Revision 1.6  2005/12/08 16:04:45  meichel *  Changed include path schema for all DCMTK header files * *  Revision 1.5  2003/06/04 14:21:03  meichel *  Simplified include structure to avoid preprocessor limitation *    (max 32 #if levels) on MSVC5 with STL. * *  Revision 1.4  2001/11/16 15:50:50  meichel *  Adapted digital signature code to final text of supplement 41. * *  Revision 1.3  2001/09/26 14:30:22  meichel *  Adapted dcmsign to class OFCondition * *  Revision 1.2  2001/06/01 15:50:51  meichel *  Updated copyright header * *  Revision 1.1  2000/11/07 16:48:59  meichel *  Initial release of dcmsign module for DICOM Digital Signatures * * */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -