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.
165 lines
4.9 KiB
165 lines
4.9 KiB
// --------------------------------------------------------------------------- |
|
// 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
|
|
|