// V1PubKey.cpp: implementation of the CV1PubKey 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 #include "cciExc.h" #include "cciCard.h" #include "TransactionWrap.h" #include "V1Cont.h" #include "V1ContRec.h" #include "V1PubKey.h" using namespace std; using namespace cci; using namespace iop; /////////////////////////// LOCAL/HELPER ///////////////////////////////// /////////////////////////// PUBLIC ///////////////////////////////// // Types // C'tors/D'tors CV1PublicKey::CV1PublicKey(CV1Card const &rv1card, KeySpec ks) : CAbstractPublicKey(rv1card, oaPublicAccess), m_ks(ks), m_apKeyBlob() {} CV1PublicKey::~CV1PublicKey() {} // Operators // Operations void CV1PublicKey::AssociateWith(KeySpec ks) { CTransactionWrap wrap(m_hcard); m_ks = ks; Store(); } void CV1PublicKey::CKInvisible(bool flag) { throw Exception(ccNotImplemented); } void CV1PublicKey::CredentialID(string const &rstrID) { throw Exception(ccNotImplemented); } void CV1PublicKey::Derive(bool flag) { throw Exception(ccNotImplemented); } void CV1PublicKey::ID(string const &rstrID) { throw Exception(ccNotImplemented); } void CV1PublicKey::EndDate(Date const &rdtEnd) { throw Exception(ccNotImplemented); } void CV1PublicKey::Encrypt(bool flag) { throw Exception(ccNotImplemented); } void CV1PublicKey::Exponent(string const &rstrExp) { CTransactionWrap wrap(m_hcard); if (!m_apKeyBlob.get()) // preserve the modulus, if previously cached { m_apKeyBlob = auto_ptr(new CPublicKeyBlob); Clear(*m_apKeyBlob.get()); } // Security: guard against buffer overrun if (rstrExp.length() > (sizeof m_apKeyBlob->bExponent / sizeof *m_apKeyBlob->bExponent)) throw cci::Exception(ccBadLength); CopyMemory(m_apKeyBlob->bExponent, reinterpret_cast(rstrExp.data()), rstrExp.length()); if (ksNone != m_ks) Store(); } void CV1PublicKey::Label(string const &rstrLabel) { throw Exception(ccNotImplemented); } void CV1PublicKey::Local(bool flag) { throw Exception(ccNotImplemented); } CV1PublicKey * CV1PublicKey::Make(CV1Card const &rv1card, KeySpec ks) { CTransactionWrap wrap(rv1card); return new CV1PublicKey(rv1card, ks); } void CV1PublicKey::Modifiable(bool flag) { throw Exception(ccNotImplemented); } void CV1PublicKey::Modulus(string const &rstrMod) { CTransactionWrap wrap(m_hcard); if (!m_apKeyBlob.get()) // preserve the exponent, if previously cached { m_apKeyBlob = auto_ptr(new CPublicKeyBlob); Clear(*m_apKeyBlob.get()); } CopyMemory(m_apKeyBlob->bModulus, reinterpret_cast(rstrMod.data()), rstrMod.length()); m_apKeyBlob->bModulusLength = static_cast(rstrMod.length()); if (ksNone != m_ks) Store(); } void CV1PublicKey::StartDate(Date const &rdtStart) { throw Exception(ccNotImplemented); } void CV1PublicKey::Subject(string const &rstrSubject) { throw Exception(ccNotImplemented); } void CV1PublicKey::Verify(bool flag) { throw Exception(ccNotImplemented); } void CV1PublicKey::VerifyRecover(bool flag) { throw Exception(ccNotImplemented); } void CV1PublicKey::Wrap(bool flag) { throw Exception(ccNotImplemented); } // Access bool CV1PublicKey::CKInvisible() { return false; } string CV1PublicKey::CredentialID() { throw Exception(ccNotImplemented); return string(); } bool CV1PublicKey::Derive() { return true; } bool CV1PublicKey::Encrypt() { return true; } Date CV1PublicKey::EndDate() { throw Exception(ccNotImplemented); return Date(); } string CV1PublicKey::Exponent() { CTransactionWrap wrap(m_hcard); if (!m_apKeyBlob.get()) Load(); return string(reinterpret_cast(m_apKeyBlob->bExponent), sizeof m_apKeyBlob->bExponent); } string CV1PublicKey::ID() { throw Exception(ccNotImplemented); return string(); } string CV1PublicKey::Label() { throw Exception(ccNotImplemented); } bool CV1PublicKey::Local() { return false; } bool CV1PublicKey::Modifiable() { return true; } string CV1PublicKey::Modulus() { CTransactionWrap wrap(m_hcard); if (!m_apKeyBlob.get()) Load(); return string(reinterpret_cast(m_apKeyBlob.get()->bModulus), m_apKeyBlob.get()->bModulusLength); } bool CV1PublicKey::Private() { return false; } Date CV1PublicKey::StartDate() { throw Exception(ccNotImplemented); return Date(); } string CV1PublicKey::Subject() { throw Exception(ccNotImplemented); return string(); } bool CV1PublicKey::Verify() { return true; } bool CV1PublicKey::VerifyRecover() { throw true; } bool CV1PublicKey::Wrap() { return true; } // Predicates // Static Variables /////////////////////////// PROTECTED ///////////////////////////////// // C'tors/D'tors // Operators // Operations void CV1PublicKey::DoDelete() { if (ksNone != m_ks) { CContainer hcntr(m_hcard->DefaultContainer()); if (!hcntr) throw Exception(ccInvalidParameter); CV1Container &rv1cntr = scu::DownCast(*hcntr); CPublicKeyBlob KeyBlob; Clear(KeyBlob); rv1cntr.Record().Write(m_ks, KeyBlob); } else throw Exception(ccInvalidParameter); } // Access // Predicates bool CV1PublicKey::DoEquals(CAbstractPublicKey const &rhs) const { CV1PublicKey const &rv1rhs = scu::DownCast(rhs); return rv1rhs.m_ks == m_ks; } // Static Variables /////////////////////////// PRIVATE ///////////////////////////////// // C'tors/D'tors // Operators // Operations void CV1PublicKey::Load() { if (ksNone != m_ks) { CV1Card &rv1card = scu::DownCast(*m_hcard); CV1ContainerRecord CntrRec(rv1card, CV1ContainerRecord::DefaultName(), CV1ContainerRecord::cmNever); m_apKeyBlob = auto_ptr(new CPublicKeyBlob); CntrRec.Read(m_ks, *m_apKeyBlob.get()); } else throw Exception(ccInvalidParameter); } void CV1PublicKey::Store() { if (ksNone != m_ks) { if (m_apKeyBlob.get()) { CV1Card &rv1card = scu::DownCast(*m_hcard); CV1ContainerRecord CntrRec(rv1card, CV1ContainerRecord::DefaultName(), CV1ContainerRecord::cmNever); CntrRec.Write(m_ks, *m_apKeyBlob.get()); } } else throw Exception(ccInvalidParameter); } // Access // Predicates // Static Variables