372 lines
7.8 KiB
C++
372 lines
7.8 KiB
C++
|
// V2PubKey.cpp: implementation of the CV2PubKey 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.
|
||
|
//////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
#include <scuCast.h>
|
||
|
|
||
|
#include "cciCard.h"
|
||
|
#include "TransactionWrap.h"
|
||
|
|
||
|
#include "V2PubKey.h"
|
||
|
#include "PubKeyInfoRecord.h"
|
||
|
|
||
|
using namespace std;
|
||
|
using namespace cci;
|
||
|
|
||
|
/////////////////////////// LOCAL/HELPER /////////////////////////////////
|
||
|
|
||
|
/////////////////////////// PUBLIC /////////////////////////////////
|
||
|
|
||
|
// Types
|
||
|
// C'tors/D'tors
|
||
|
CV2PublicKey::CV2PublicKey(CV2Card const &rv2card,
|
||
|
ObjectAccess oa)
|
||
|
: CAbstractPublicKey(rv2card, oa),
|
||
|
m_sidHandle(0),
|
||
|
m_apcir()
|
||
|
{
|
||
|
|
||
|
m_sidHandle =
|
||
|
rv2card.ObjectInfoFile(m_oa).AddObject(otPublicKeyObject,
|
||
|
PublInfoRecordSize);
|
||
|
|
||
|
Setup(rv2card);
|
||
|
|
||
|
// write new public key object into info file
|
||
|
m_apcir->Clear();
|
||
|
m_apcir->Write();
|
||
|
}
|
||
|
|
||
|
CV2PublicKey::CV2PublicKey(CV2Card const &rv2card,
|
||
|
SymbolID sidHandle,
|
||
|
ObjectAccess oa)
|
||
|
: CAbstractPublicKey(rv2card, oa),
|
||
|
m_sidHandle(sidHandle),
|
||
|
m_apcir()
|
||
|
{
|
||
|
Setup(rv2card);
|
||
|
}
|
||
|
|
||
|
CV2PublicKey::~CV2PublicKey()
|
||
|
{}
|
||
|
|
||
|
|
||
|
// Operators
|
||
|
// Operations
|
||
|
void
|
||
|
CV2PublicKey::CKInvisible(bool flag)
|
||
|
{
|
||
|
m_apcir->Flag(PublCKInvisibleFlag, flag);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::CredentialID(string const &rstrID)
|
||
|
{
|
||
|
m_apcir->Symbol(&m_apcir->m_bCredentialID, rstrID);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Derive(bool flag)
|
||
|
{
|
||
|
m_apcir->Flag(PublDeriveFlag, flag);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::ID(string const &rstrID)
|
||
|
{
|
||
|
m_apcir->Symbol(&m_apcir->m_bID, rstrID);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::EndDate(Date const &rdtEnd)
|
||
|
{
|
||
|
CTransactionWrap wrap(m_hcard);
|
||
|
m_apcir->Read();
|
||
|
m_apcir->m_dtEnd = rdtEnd;
|
||
|
m_apcir->Write();
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
CV2PublicKey::Encrypt()
|
||
|
{
|
||
|
return m_apcir->Flag(PublEncryptFlag);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Exponent(string const &rstrExp)
|
||
|
{
|
||
|
m_apcir->Symbol(&m_apcir->m_bPublExponent, rstrExp);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Label(string const &rstrLabel)
|
||
|
{
|
||
|
m_apcir->Symbol(&m_apcir->m_bLabel, rstrLabel);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Local(bool flag)
|
||
|
{
|
||
|
m_apcir->Flag(PublLocalFlag, flag);
|
||
|
}
|
||
|
|
||
|
CV2PublicKey *
|
||
|
CV2PublicKey::Make(CV2Card const &rv2card,
|
||
|
SymbolID sidHandle,
|
||
|
ObjectAccess oa)
|
||
|
{
|
||
|
return new CV2PublicKey(rv2card, sidHandle, oa);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Modifiable(bool flag)
|
||
|
{
|
||
|
m_apcir->Flag(PublModifiableFlag, flag);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Modulus(string const &rstrMod)
|
||
|
{
|
||
|
CTransactionWrap wrap(m_hcard);
|
||
|
|
||
|
m_apcir->Read();
|
||
|
|
||
|
m_apcir->Symbol(&m_apcir->m_bModulus, rstrMod);
|
||
|
|
||
|
if (rstrMod.size() == 0x80)
|
||
|
m_apcir->m_bKeyType = CardKeyTypeRSA1024;
|
||
|
else if (rstrMod.size() == 0x60)
|
||
|
m_apcir->m_bKeyType = CardKeyTypeRSA768;
|
||
|
else if (rstrMod.size() == 0x40)
|
||
|
m_apcir->m_bKeyType = CardKeyTypeRSA512;
|
||
|
else
|
||
|
m_apcir->m_bKeyType = CardKeyTypeNone;
|
||
|
|
||
|
m_apcir->Write();
|
||
|
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::StartDate(Date const &rdtStart)
|
||
|
{
|
||
|
CTransactionWrap wrap(m_hcard);
|
||
|
m_apcir->Read();
|
||
|
m_apcir->m_dtStart = rdtStart;
|
||
|
m_apcir->Write();
|
||
|
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Subject(string const &rstrSubject)
|
||
|
{
|
||
|
m_apcir->Symbol(&m_apcir->m_bSubject, rstrSubject);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Verify(bool flag)
|
||
|
{
|
||
|
m_apcir->Flag(PublVerifyFlag, flag);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::VerifyRecover(bool flag)
|
||
|
{
|
||
|
m_apcir->Flag(PublVerifyRecoverFlag, flag);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Wrap(bool flag)
|
||
|
{
|
||
|
m_apcir->Flag(PublWrapFlag, flag);
|
||
|
}
|
||
|
|
||
|
// Access
|
||
|
bool
|
||
|
CV2PublicKey::CKInvisible()
|
||
|
{
|
||
|
return m_apcir->Flag(PublCKInvisibleFlag);
|
||
|
}
|
||
|
|
||
|
string
|
||
|
CV2PublicKey::CredentialID()
|
||
|
{
|
||
|
return m_apcir->Symbol(&m_apcir->m_bCredentialID);
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
CV2PublicKey::Derive()
|
||
|
{
|
||
|
return m_apcir->Flag(PublDeriveFlag);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
CV2PublicKey::Encrypt(bool flag)
|
||
|
{
|
||
|
m_apcir->Flag(PublEncryptFlag, flag);
|
||
|
}
|
||
|
|
||
|
Date
|
||
|
CV2PublicKey::EndDate()
|
||
|
{
|
||
|
CTransactionWrap wrap(m_hcard);
|
||
|
m_apcir->Read();
|
||
|
return m_apcir->m_dtEnd;
|
||
|
}
|
||
|
|
||
|
string
|
||
|
CV2PublicKey::Exponent()
|
||
|
{
|
||
|
return m_apcir->Symbol(&m_apcir->m_bPublExponent);
|
||
|
}
|
||
|
|
||
|
SymbolID
|
||
|
CV2PublicKey::Handle() const
|
||
|
{
|
||
|
return m_sidHandle;
|
||
|
}
|
||
|
|
||
|
string
|
||
|
CV2PublicKey::ID()
|
||
|
{
|
||
|
return m_apcir->Symbol(&m_apcir->m_bID);
|
||
|
}
|
||
|
|
||
|
string
|
||
|
CV2PublicKey::Label()
|
||
|
{
|
||
|
return m_apcir->Symbol(&m_apcir->m_bLabel);
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
CV2PublicKey::Local()
|
||
|
{
|
||
|
return m_apcir->Flag(PublLocalFlag);
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
CV2PublicKey::Modifiable()
|
||
|
{
|
||
|
return m_apcir->Flag(PublModifiableFlag);
|
||
|
}
|
||
|
|
||
|
string
|
||
|
CV2PublicKey::Modulus()
|
||
|
{
|
||
|
return m_apcir->Symbol(&m_apcir->m_bModulus);
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
CV2PublicKey::Private()
|
||
|
{
|
||
|
return m_apcir->Private();
|
||
|
}
|
||
|
|
||
|
Date
|
||
|
CV2PublicKey::StartDate()
|
||
|
{
|
||
|
CTransactionWrap wrap(m_hcard);
|
||
|
m_apcir->Read();
|
||
|
return m_apcir->m_dtStart;
|
||
|
}
|
||
|
|
||
|
string
|
||
|
CV2PublicKey::Subject()
|
||
|
{
|
||
|
return m_apcir->Symbol(&m_apcir->m_bSubject);
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
CV2PublicKey::Verify()
|
||
|
{
|
||
|
return m_apcir->Flag(PublVerifyFlag);
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
CV2PublicKey::VerifyRecover()
|
||
|
{
|
||
|
return m_apcir->Flag(PublVerifyRecoverFlag);
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
CV2PublicKey::Wrap()
|
||
|
{
|
||
|
return m_apcir->Flag(PublWrapFlag);
|
||
|
}
|
||
|
|
||
|
|
||
|
// Predicates
|
||
|
// Static Variables
|
||
|
|
||
|
/////////////////////////// PROTECTED /////////////////////////////////
|
||
|
|
||
|
// C'tors/D'tors
|
||
|
// Operators
|
||
|
// Operations
|
||
|
void
|
||
|
CV2PublicKey::DoDelete()
|
||
|
{
|
||
|
CV2Card &rv2card = scu::DownCast<CV2Card &, CAbstractCard &>(*m_hcard);
|
||
|
|
||
|
CObjectInfoFile &roif = rv2card.ObjectInfoFile(m_oa);
|
||
|
|
||
|
m_apcir->Read();
|
||
|
|
||
|
// Remove allocation of entry in private key file
|
||
|
|
||
|
if (m_apcir->m_bLabel)
|
||
|
roif.RemoveSymbol(m_apcir->m_bLabel);
|
||
|
if (m_apcir->m_bID)
|
||
|
roif.RemoveSymbol(m_apcir->m_bID);
|
||
|
if (m_apcir->m_bCredentialID)
|
||
|
roif.RemoveSymbol(m_apcir->m_bCredentialID);
|
||
|
if (m_apcir->m_bSubject)
|
||
|
roif.RemoveSymbol(m_apcir->m_bSubject);
|
||
|
if (m_apcir->m_bModulus)
|
||
|
roif.RemoveSymbol(m_apcir->m_bModulus);
|
||
|
if (m_apcir->m_bPublExponent)
|
||
|
roif.RemoveSymbol(m_apcir->m_bPublExponent);
|
||
|
|
||
|
// Delete info record
|
||
|
|
||
|
roif.RemoveObject(otPublicKeyObject, m_sidHandle);
|
||
|
|
||
|
}
|
||
|
|
||
|
// Access
|
||
|
// Predicates
|
||
|
bool
|
||
|
CV2PublicKey::DoEquals(CAbstractPublicKey const &rhs) const
|
||
|
{
|
||
|
CV2PublicKey const &rv2rhs =
|
||
|
scu::DownCast<CV2PublicKey const &, CAbstractPublicKey const &>(rhs);
|
||
|
|
||
|
return (rv2rhs.m_sidHandle == m_sidHandle);
|
||
|
}
|
||
|
|
||
|
// Static Variables
|
||
|
|
||
|
|
||
|
/////////////////////////// PRIVATE /////////////////////////////////
|
||
|
|
||
|
// C'tors/D'tors
|
||
|
// Operators
|
||
|
// Operations
|
||
|
void
|
||
|
CV2PublicKey::Setup(CV2Card const &rv2card)
|
||
|
{
|
||
|
|
||
|
m_apcir =
|
||
|
auto_ptr<CPubKeyInfoRecord>(new CPubKeyInfoRecord(rv2card,
|
||
|
m_sidHandle,
|
||
|
m_oa));
|
||
|
}
|
||
|
|
||
|
// Access
|
||
|
// Predicates
|
||
|
// Static Variables
|