mirror of https://github.com/tongzx/nt5src
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.
212 lines
5.8 KiB
212 lines
5.8 KiB
// CryptCtx.h -- Cryptographic Context class header
|
|
|
|
// (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(SLBCSP_CRYPTCTX_H)
|
|
#define SLBCSP_CRYPTCTX_H
|
|
|
|
#include <memory> // for auto_ptr
|
|
|
|
#include <windef.h>
|
|
#include <wincrypt.h> // required by cspdk.h
|
|
#include <cspdk.h> // for CRYPT_RETURN_HWND &
|
|
// PVTableProvStruc
|
|
|
|
#include <handles.h>
|
|
|
|
#include <scuArrayP.h>
|
|
|
|
#include "Lockable.h"
|
|
#include "HAdptvCntr.h"
|
|
#include "CntrEnum.h"
|
|
#include "AuxContext.h"
|
|
#include "LoginId.h"
|
|
#include "Blob.h"
|
|
#include "AlignedBlob.h"
|
|
|
|
class CSpec;
|
|
class CHashContext;
|
|
class CKeyContext;
|
|
class CPublicKeyContext;
|
|
class CSessionKeyContext;
|
|
|
|
// Maintains the context acquired and used to access a CAPI container.
|
|
class CryptContext
|
|
: public CHandle,
|
|
public Lockable
|
|
{
|
|
public:
|
|
// Types
|
|
// C'tors/D'tors
|
|
CryptContext(CSpec const &CntrSpec,
|
|
PVTableProvStruc const pVTable,
|
|
bool fGuiEnabled,
|
|
bool fCreateContainer = false,
|
|
bool fEphemeralContainer = false);
|
|
~CryptContext();
|
|
|
|
// Operators
|
|
// Operations
|
|
|
|
HCRYPTHASH
|
|
Add(std::auto_ptr<CHashContext> &rapHashCtx);
|
|
|
|
HCRYPTKEY
|
|
Add(std::auto_ptr<CKeyContext> &rapKeyCtx);
|
|
|
|
HCRYPTKEY
|
|
Add(std::auto_ptr<CPublicKeyContext> &rapPublicKeyCtx);
|
|
|
|
HCRYPTKEY
|
|
Add(std::auto_ptr<CSessionKeyContext> &rapSessionKeyCtx);
|
|
|
|
std::auto_ptr<CHashContext>
|
|
CloseHash(HCRYPTHASH const hHash);
|
|
|
|
std::auto_ptr<CKeyContext>
|
|
CloseKey(HCRYPTKEY const hKey);
|
|
|
|
void
|
|
CntrEnumerator(ContainerEnumerator const &rce);
|
|
|
|
void
|
|
EnumAlgorithms(DWORD dwPara,
|
|
DWORD dwFlags,
|
|
bool fPostAdvanceIterator,
|
|
AlignedBlob &rabAlgInfo);
|
|
|
|
HCRYPTKEY
|
|
GenerateKey(ALG_ID algid,
|
|
DWORD dwFlags);
|
|
|
|
std::auto_ptr<CPublicKeyContext>
|
|
ImportPrivateKey(Blob const &rblbMsPrivateKey,
|
|
DWORD dwKeySpec,
|
|
bool fExportable,
|
|
HCRYPTKEY hEncKey);
|
|
|
|
std::auto_ptr<CPublicKeyContext>
|
|
ImportPublicKey(Blob const &rblbMsPublicKey,
|
|
DWORD dwKeySpec);
|
|
|
|
void
|
|
Login(LoginIdentity const &rlid);
|
|
|
|
void
|
|
Pin(LoginIdentity const &rlid,
|
|
char const *pszPin);
|
|
|
|
void
|
|
RemoveContainer();
|
|
|
|
std::auto_ptr<CSessionKeyContext>
|
|
UseSessionKey(BYTE const *pbKeyBlob,
|
|
DWORD cbKeyBlobLen,
|
|
HCRYPTKEY hAuxImpKey,
|
|
DWORD dwFlags);
|
|
// Access
|
|
HAdaptiveContainer
|
|
AdaptiveContainer() const;
|
|
|
|
HCRYPTPROV
|
|
AuxContext() const;
|
|
|
|
ContainerEnumerator
|
|
CntrEnumerator(bool fReset);
|
|
|
|
CHashContext *
|
|
LookupHash(HCRYPTHASH hHash);
|
|
|
|
CKeyContext *
|
|
LookupKey(HCRYPTKEY hKey);
|
|
|
|
CPublicKeyContext *
|
|
LookupPublicKey(HCRYPTKEY hKey);
|
|
|
|
CSessionKeyContext *
|
|
LookupSessionKey(HCRYPTKEY hKey);
|
|
|
|
HWND
|
|
Window() const;
|
|
|
|
// Predicates
|
|
bool
|
|
GuiEnabled() const;
|
|
|
|
bool
|
|
IsEphemeral() const;
|
|
|
|
|
|
protected:
|
|
// Types
|
|
// C'tors/D'tors
|
|
// Operators
|
|
// Operations
|
|
// Access
|
|
// Predicates
|
|
// Variables
|
|
|
|
private:
|
|
// Types
|
|
// C'tors/D'tors
|
|
// Operators
|
|
// Operations
|
|
void
|
|
CreateNewContainer(CSpec const &rcspec);
|
|
|
|
void
|
|
DeleteContainer(Secured<HCardContext> &rhscardctx,
|
|
cci::CContainer &rhcntr);
|
|
|
|
void
|
|
Login(LoginIdentity const &rlid,
|
|
Secured<HCardContext> &rhscardctx);
|
|
|
|
void
|
|
OkDeletingCredentials() const;
|
|
|
|
// Access
|
|
|
|
HCardContext
|
|
CardContext() const;
|
|
|
|
CKeyContext *
|
|
LookupChecked(HCRYPTKEY hKey,
|
|
DWORD const dwKeyType);
|
|
|
|
void
|
|
OpenExistingContainer(CSpec const &rcspec);
|
|
|
|
// Predicates
|
|
// Variables
|
|
|
|
// Id of thread that created this context, making it the owner
|
|
DWORD const m_dwOwnerThreadId;
|
|
|
|
HAdaptiveContainer m_hacntr;
|
|
|
|
// If CRYPT_VERIFYCONTEXT was used when creating this context.
|
|
bool const m_fEphemeralContainer;
|
|
|
|
// If the client specified the GUI was enabled/disabled using CRYPT_SILENT
|
|
bool const m_fGuiEnabled;
|
|
|
|
// Window to use when interacting with the user
|
|
HWND m_hwnd;
|
|
|
|
// Hashes and keys (both session and those on the card) created/acquired
|
|
// in this context.
|
|
CHandleList m_hlHashes;
|
|
CHandleList m_hlKeys;
|
|
|
|
::AuxContext const m_auxcontext;
|
|
|
|
ContainerEnumerator m_ce; // used by CPGetProvParam
|
|
std::auto_ptr<AlignedBlob> m_apabCachedAlg;
|
|
};
|
|
|
|
#endif // SLBCSP_CRYPTCTX_H
|