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.
 
 
 
 
 
 

246 lines
7.0 KiB

// V2KeyPair.cpp: implementation of the CV2KeyPair 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 "NoWarning.h"
#include <scuCast.h>
#include "slbCci.h"
#include "cciCard.h"
#include "TransactionWrap.h"
#include "V2Cert.h"
#include "V2PriKey.h"
#include "V2PubKey.h"
#include "V2Cont.h"
#include "V2KeyPair.h"
#include "ContainerInfoRecord.h"
using namespace std;
using namespace cci;
/////////////////////////// LOCAL/HELPER /////////////////////////////////
/////////////////////////// PUBLIC /////////////////////////////////
// Types
// C'tors/D'tors
CV2KeyPair::CV2KeyPair(CV2Card const &rv2card,
CContainer const &rhcont,
KeySpec ks)
: CAbstractKeyPair(rv2card, rhcont, ks),
m_bPubKeyAccess(oaNoAccess),
m_bPriKeyAccess(oaNoAccess),
m_bCertificateAccess(oaNoAccess),
m_bPubKeyHandle(0),
m_bPriKeyHandle(0),
m_bCertificateHandle(0)
{
CContainerInfoRecord &rcir =
(scu::DownCast<CV2Container &,
CAbstractContainer &>(*m_hcont)).CIR();
rcir.Read();
m_bPubKeyHandle = rcir.GetKeyPair(ks).bPubKeyHandle;
m_bPriKeyHandle = rcir.GetKeyPair(ks).bPriKeyHandle;
m_bCertificateHandle = rcir.GetKeyPair(ks).bCertificateHandle;
m_bPubKeyAccess = rcir.GetKeyPair(ks).bPubKeyAccess;
m_bPriKeyAccess = rcir.GetKeyPair(ks).bPriKeyAccess;
m_bCertificateAccess = rcir.GetKeyPair(ks).bCertificateAccess;
}
CV2KeyPair::~CV2KeyPair() throw()
{}
// Operators
// Operations
// After I update any of these, I'd better be sure that the
// key pair is marked as valid and that the indices in the
// container are updated.
void
CV2KeyPair::Certificate(CCertificate const &rcert)
{
CTransactionWrap wrap(m_hcard);
if (!rcert)
{
m_bCertificateAccess = oaNoAccess;
m_bCertificateHandle = 0;
}
else
{
CV2Certificate const &rv2cert =
scu::DownCast<CV2Certificate const &, CAbstractCertificate const &>(*rcert);
m_bCertificateAccess = rv2cert.Access();
m_bCertificateHandle = rv2cert.Handle();
}
Update();
}
void
CV2KeyPair::PrivateKey(CPrivateKey const &rprikey)
{
CTransactionWrap wrap(m_hcard);
if (!rprikey)
{
m_bPriKeyAccess = oaNoAccess;
m_bPriKeyHandle = 0;
}
else
{
CV2PrivateKey const &rv2prikey =
scu::DownCast<CV2PrivateKey const &, CAbstractPrivateKey const &>(*rprikey);
m_bPriKeyAccess = rv2prikey.Access();
m_bPriKeyHandle = rv2prikey.Handle();
}
Update();
}
void
CV2KeyPair::PublicKey(CPublicKey const &rpubkey)
{
CTransactionWrap wrap(m_hcard);
if (!rpubkey)
{
m_bPubKeyAccess = oaNoAccess;
m_bPubKeyHandle = 0;
}
else
{
CV2PublicKey const &rv2pubkey =
scu::DownCast<CV2PublicKey const &, CAbstractPublicKey const &>(*rpubkey);
m_bPubKeyAccess = rv2pubkey.Access();
m_bPubKeyHandle = rv2pubkey.Handle();
}
Update();
}
// Access
CCertificate
CV2KeyPair::Certificate() const
{
CTransactionWrap wrap(m_hcard);
CCertificate aCert;
if (m_bCertificateHandle)
{
CV2Card const &rv2card =
scu::DownCast<CV2Card &, CAbstractCard &>(*m_hcard);
aCert = CCertificate(CV2Certificate::Make(rv2card,
m_bCertificateHandle,
m_bCertificateAccess));
}
else
aCert = CCertificate();
return aCert;
}
CPrivateKey
CV2KeyPair::PrivateKey() const
{
CTransactionWrap wrap(m_hcard);
CPrivateKey aKey;
if (m_bPriKeyHandle)
{
CV2Card const &rv2card =
scu::DownCast<CV2Card &, CAbstractCard &>(*m_hcard);
aKey = CPrivateKey(CV2PrivateKey::Make(rv2card, m_bPriKeyHandle,
m_bPriKeyAccess));
}
else
aKey = CPrivateKey();
return aKey;
}
CPublicKey
CV2KeyPair::PublicKey() const
{
CTransactionWrap wrap(m_hcard);
CPublicKey aKey;
if (m_bPubKeyHandle)
{
CV2Card const &rv2card =
scu::DownCast<CV2Card &, CAbstractCard &>(*m_hcard);
aKey = CPublicKey(CV2PublicKey::Make(rv2card, m_bPubKeyHandle,
m_bPubKeyAccess));
}
else
aKey = CPublicKey();
return aKey;
}
// Predicates
bool
CV2KeyPair::DoEquals(CAbstractKeyPair const &rhs) const
{
CV2KeyPair const &rv2rhs =
scu::DownCast<CV2KeyPair const &, CAbstractKeyPair const &>(rhs);
return (rv2rhs.m_bPubKeyAccess == m_bPubKeyAccess) &&
(rv2rhs.m_bPriKeyAccess == m_bPriKeyAccess) &&
(rv2rhs.m_bCertificateAccess == m_bCertificateAccess) &&
(rv2rhs.m_bPubKeyHandle == m_bPubKeyHandle) &&
(rv2rhs.m_bPriKeyHandle == m_bPriKeyHandle) &&
(rv2rhs.m_bCertificateHandle == m_bCertificateHandle);
}
// Static Variables
/////////////////////////// PROTECTED /////////////////////////////////
// C'tors/D'tors
// Operators
// Operations
// Access
// Predicates
// Static Variables
/////////////////////////// PRIVATE /////////////////////////////////
// C'tors/D'tors
// Operators
// Operations
void
CV2KeyPair::Update()
{
KPItems kp;
kp.bPubKeyAccess = m_bPubKeyAccess;
kp.bPriKeyAccess = m_bPriKeyAccess;
kp.bCertificateAccess = m_bCertificateAccess;
kp.bPubKeyHandle = m_bPubKeyHandle;
kp.bPriKeyHandle = m_bPriKeyHandle;
kp.bCertificateHandle = m_bCertificateHandle;
CContainerInfoRecord &rcir =
(scu::DownCast<CV2Container &,
CAbstractContainer &>(*m_hcont)).CIR();
rcir.SetKeyPair(m_ks, kp);
}
// Access
// Predicates
// Static Variables