// cciV2Card.h: interface for the CV2Card 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. ////////////////////////////////////////////////////////////////////// // Note: This header file should only be included by the CCI. The // client gets the declarations via cciCard.h #if !defined(CCI_V2CARD_H) #define CCI_V2CARD_H #include // for auto_ptr #include #include #include #include #include "ACard.h" #include "cciCont.h" #include "CardInfo.h" #include "SymbolTable.h" #include "ObjectInfoFile.h" #include "cciCert.h" #include "cciPubKey.h" #include "cciPriKey.h" #include "cciDataObj.h" namespace cci { class CV2Container; class CV2Card // concrete class : public CAbstractCard { friend CAbstractCard * CAbstractCard::Make(std::string const &rstrReaderName); public: // Types // C'tors/D'tors virtual ~CV2Card() throw(); // Operators // Operations virtual void ChangePIN(scu::SecureArray const &rstrOldPIN, scu::SecureArray const &rstrNewPIN); virtual void DefaultContainer(CContainer const &rcont); virtual std::pair GenerateKeyPair(KeyType kt, std::string const &rsExponent, ObjectAccess oaPrivateKey = oaPrivateAccess); virtual void InitCard(); virtual void InvalidateCache(); virtual void Label(std::string const &rstrLabel); virtual void VerifyKey(std::string const &rstrKey, BYTE bKeyNum); // Access size_t AvailableStringSpace(ObjectAccess oa) const; CCardInfo & CardInfo() const; virtual CContainer DefaultContainer() const; virtual std::vector EnumContainers() const; virtual std::vector EnumCertificates(ObjectAccess access) const; virtual std::vector EnumPublicKeys(ObjectAccess access) const; virtual std::vector EnumPrivateKeys(ObjectAccess access) const; virtual std::vector EnumDataObjects(ObjectAccess access) const; virtual std::string Label() const; BYTE MaxKeys(KeyType kt) const; size_t MaxStringSpace(ObjectAccess oa) const; CObjectInfoFile & ObjectInfoFile(ObjectAccess oa) const; virtual std::string PrivateKeyPath(KeyType kt) const; virtual std::string const & RootPath() const; virtual bool SupportedKeyFunction(KeyType kt, CardOperation oper) const; virtual scu::Marker MarkerOnCard() const; // Predicates virtual bool IsCAPIEnabled() const; virtual bool IsPKCS11Enabled() const; virtual bool IsEntrustEnabled() const; virtual bool IsProtectedMode() const; virtual bool IsKeyGenEnabled() const; virtual BYTE MajorVersion() const; virtual bool IsMarkerOnCard() const; protected: // Types // C'tors/D'tors CV2Card(std::string const &rstrReaderName, std::auto_ptr &rapiop, std::auto_ptr &rapSmartCard); // Note/TO DO: CardInfo is likely to be specific to the // CV2Card's format version. Therefore, the extent that a // subclass can be defined for CV2Card is limited by the // ability of that subclass to utilize CV2Card's CardInfo. A // concept to revisit. // Operators // Operations void DoSetup(); virtual CAbstractCertificate * MakeCertificate(ObjectAccess oa) const; virtual CAbstractContainer * MakeContainer() const; virtual CAbstractDataObject * MakeDataObject(ObjectAccess oa) const; virtual CAbstractKeyPair * MakeKeyPair(CContainer const &rhcont, KeySpec ks) const; virtual CAbstractPrivateKey * MakePrivateKey(ObjectAccess oa) const; virtual CAbstractPublicKey * MakePublicKey(ObjectAccess oa) const; // Access // Predicates // Variables private: // Types typedef CAbstractCard SuperClass; // C'tors/D'tors // Operators // Operations static std::auto_ptr DoMake(std::string const &rstrReaderName, std::auto_ptr &rapiop, std::auto_ptr &rapSmartCard); // Access // Predicates // Variables std::auto_ptr m_apCardInfo; std::auto_ptr mutable m_apPublicObjectInfoFile; std::auto_ptr mutable m_apPrivateObjectInfoFile; ArchivedSymbol mutable m_asLabel; }; } #endif