// 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 #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(*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(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(new CPubKeyInfoRecord(rv2card, m_sidHandle, m_oa)); } // Access // Predicates // Static Variables