// CardInfo.h: interface for the CCardInfo class. // // (c) Copyright Schlumberger Technology Corp., unpublished work, created // 1999. This computer program includes Confidential, Proprietary // Information and is a Trade Secret of Schlumberger Technology Corp. All // use, disclosure, and/or reproduction is prohibited unless authorized // in writing. All Rights Reserved. ////////////////////////////////////////////////////////////////////// #if !defined(AFX_CARDINFO_H__F4AD08D3_143B_11D3_A587_00104BD32DA8__INCLUDED_) #define AFX_CARDINFO_H__F4AD08D3_143B_11D3_A587_00104BD32DA8__INCLUDED_ #if _MSC_VER > 1000 #pragma once #endif // _MSC_VER > 1000 #include #include #include "slbCci.h" namespace cci { class CCard; class CCardInfo { public: CCardInfo(iop::CSmartCard &rCard); virtual ~CCardInfo(); void UpdateCache(); void Reset(); Date PersonalizationDate() { return m_PersoDate; }; void PersonalizationDate(Date const &rdtPerso); Format FormatVersion() { return m_Format; }; unsigned short LabelSize() { return m_sLabelSize; }; BYTE UsagePolicy() { return m_bUsagePolicy; }; BYTE NumRSA512Keys() { return m_bNum512Pri; }; BYTE NumRSA768Keys() { return m_bNum768Pri; }; BYTE NumRSA1024Keys() { return m_bNum1024Pri; }; BYTE AllocatePrivateKey(BYTE bKeyType); void FreePrivateKey(BYTE bKeyType, BYTE bKeyNum); void Label(std::string const &rLabel); std::string Label(); private: unsigned short UsageBlockSize() { return (m_sRSA512MaskSize + m_sRSA768MaskSize + m_sRSA1024MaskSize);}; iop::CSmartCard &m_rSmartCard; Date m_PersoDate; Format m_Format; unsigned short m_sLabelSize; BYTE m_bUsagePolicy; BYTE m_bNum512Pri; BYTE m_bNum768Pri; BYTE m_bNum1024Pri; scu::AutoArrayPtr m_aabRSA512Keys; scu::AutoArrayPtr m_aabRSA768Keys; scu::AutoArrayPtr m_aabRSA1024Keys; unsigned short m_sRSA512MaskOffset; unsigned short m_sRSA512MaskSize; unsigned short m_sRSA768MaskOffset; unsigned short m_sRSA768MaskSize; unsigned short m_sRSA1024MaskOffset; unsigned short m_sRSA1024MaskSize; }; const unsigned short CardDateLoc = 0; const unsigned short CardVersionMajorLoc = 3; const unsigned short CardVersionMinorLoc = 4; const unsigned short CardUsagePolicyLoc = 5; const unsigned short CardLabelSizeLoc = 8; const unsigned short CardNumRSA512PublLoc = 20; const unsigned short CardNumRSA512PrivLoc = 21; const unsigned short CardNumRSA768PublLoc = 22; const unsigned short CardNumRSA768PrivLoc = 23; const unsigned short CardNumRSA1024PublLoc = 24; const unsigned short CardNumRSA1024PrivLoc = 25; const unsigned short CardMasterBlkSize = 42; const BYTE CardCryptoAPIEnabledFlag = 0; const BYTE CardPKCS11EnabledFlag = 1; const BYTE CardEntrustEnabledFlag = 2; const BYTE CardProtectedWriteFlag = 3; const BYTE CardKeyGenSupportedFlag = 7; const BYTE CardKeyTypeNone = 0; const BYTE CardKeyTypeRSA512 = 1; const BYTE CardKeyTypeRSA768 = 2; const BYTE CardKeyTypeRSA1024 = 3; const char CardInfoFilePath[] = "/3f00/3f11/0020"; } #endif // !defined(AFX_CARDINFO_H__F4AD08D3_143B_11D3_A587_00104BD32DA8__INCLUDED_)