Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
// 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 <scuArrayP.h>
#include <iop.h>
#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<BYTE> m_aabRSA512Keys; scu::AutoArrayPtr<BYTE> m_aabRSA768Keys; scu::AutoArrayPtr<BYTE> 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_)
|