// --------------------------------------------------------------------------- // Name: actIToken.h // Product: cv act library // Purpose: The IToken interface represents the profile and the application // supported by a token. // // Copyright: (c) 2002 cv cryptovision GmbH // all rights reserved // Licence: The conditions for the use of this software are regulated // in the cv act library licence agreement. // // Autor: Dr. Xiangdong Wang (XWG) // Date: 03/22/2002 // --------------------------------------------------------------------------- #ifndef ACT_IToken_h #define ACT_IToken_h #include "actBlob.h" #include "actBasics.h" #include "actTokenBase.h" #include "actISynchronize.h" #include "actITokenFileCache.h" #include "actIAccessCondition.h" namespace act { class IKey; class IEMSAAlg; class ICertificate; class IAuthIdRef; class ITokenPIN; class ITokenAuth; class ITokenFile; class ITokenFileMap; class ITokenConfig; class ITokenKeyIterator; class ISecurityManager; class ITokenAuthIterator; struct CertEntry { int usage; Blob certblob; }; // // ITokenView class ITokenView { protected: virtual ~ITokenView() { } public: virtual IToken* GetToken() = 0; virtual ITokenView* GetPrev() const = 0; virtual ITokenView* GetNext() const = 0; virtual ITokenFile* GetPath() const = 0; virtual ITokenFileMap* GetFileMap() const = 0; virtual bool Equals(const ITokenView* other) const = 0; // Divide view into partitions, based on type[PATH|PIN] virtual size_t Split(paramid_t type) = 0; virtual ITokenView* SetDefault() = 0; }; // // IToken class IToken : public IRefCounted , public IAcConverter , public ISynchronize { protected: virtual ~IToken() { } public: virtual ITokenView* GetView() const = 0; virtual ITokenConfig* GetConfig() const = 0; virtual ITokenFile* GetTokenFile(const Blob& path) = 0; virtual int GetStatus() const = 0; virtual int GetType() const = 0; virtual ProfileType GetProfileType() = 0; virtual const char* GetName() const = 0; // Returns the serial number, which may (!) be empty or equal the hardware serial! virtual Blob GetSerialNumber() const = 0; virtual Blob GetCardholderName() const = 0; virtual Blob GetRandom(const unsigned long count) const = 0; virtual void SetSeed(const Blob& seed) = 0; // Generate a new key virtual IKey* NewKey(int key_type) = 0; // Add key to token, takes ownership - even on exception! virtual void AddKey(IKey* key) = 0; virtual bool RemoveKey(IKey* key) = 0; // Write/Import a (soft) key to token virtual IKey* WriteKey(const IKey* key) = 0; // Get a token key instance from matching certificate virtual IKey* CreateKey(const Blob& cert) const = 0; virtual IKey* CreateKey(const ICertificate* cert) const = 0; // Key Objects virtual int GetKeyNumber() const = 0; virtual IKey* GetKey(int pos) const = 0; virtual ITokenKeyIterator* GetKeyIterator(KeyType type, const Blob& authId = Blob()) = 0; // Certificate Objects virtual int GetCertificateNumber() const = 0; virtual CertEntry GetCertificate(int pos) const = 0; // Write/Delete a certificate (corresponding to a key) to token virtual void WriteCertificate(const Blob& cert, IKey* key = 0) = 0; virtual void DeleteCertificate(const Blob& cert, IKey* key = 0) = 0; // Authentication Objects virtual ITokenAuth* GetAuth() const = 0; virtual ISecurityManager* SecurityManager(int authManagerType) = 0; virtual ITokenAuthIterator* GetAuthIterator(int type, const Blob& authId = Blob()) = 0; virtual int GetPinNumber() const = 0; virtual ITokenPIN* GetPin(const IAuthIdRef* authIdRef, const ITokenFile* location) const = 0; virtual ITokenPIN* GetPin(int pos, const ITokenFile* location) const = 0; virtual ITokenPIN* GetPin(const char* pin_name) const = 0; virtual ITokenPIN* GetPin(const Blob& authId) const = 0; virtual ITokenPIN* GetUserPin() const = 0; virtual ITokenPIN* GetSOPin() const = 0; virtual void VerifyUserPin(const Blob& pinvalue) = 0; virtual void ChangeUserPin(const Blob& oldpin, const Blob& newpin) = 0; virtual void UnlockUserPin(const Blob& so_pin, const Blob& new_userpin) = 0; virtual void VerifySOPin(const Blob& pinvalue) = 0; virtual void ChangeSOPin(const Blob& oldpin, const Blob& newpin) = 0; virtual bool ResetSecurityState() const = 0; // Token specific virtual void SelectDataPath() const = 0; // TODO: MTE: To be removed soon! virtual ISCardOS* GetOS() const = 0; // TODO: MTE: To be removed soon! // Delete a key pair from token with matching token key or certificate virtual void DeleteKeyPair(const IKey* key) = 0; virtual void DeleteKeyPair(const Blob& cert) = 0; virtual bool IsPKCS15() const = 0; virtual bool IsReadOnly() const = 0; virtual bool LoginRequired() const = 0; virtual bool IsLocked() const = 0; virtual Blob GetCardId() const = 0; virtual Blob GetCardCF() const = 0; }; } // namespace act #endif // ACT_IToken_h