#ifndef _H_CDSA_CLIENT_KEYCLIENT
#define _H_CDSA_CLIENT_KEYCLIENT 1
#include <security_cdsa_client/aclclient.h>
#include <security_cdsa_client/cspclient.h>
namespace Security
{
namespace CssmClient
{
class KeyImpl : public ObjectImpl, public AclBearer, public CssmKey
{
public:
KeyImpl(const CSP &csp);
KeyImpl(const CSP &csp, const CSSM_KEY &key, bool copy = false);
KeyImpl(const CSP &csp, const CSSM_DATA &keyData);
virtual ~KeyImpl();
CSP csp() const { return parent<CSP>(); }
void deleteKey(const CSSM_ACCESS_CREDENTIALS *cred);
CssmKeySize sizeInBits() const;
void getAcl(AutoAclEntryInfoList &aclInfos, const char *selectionTag = NULL) const;
void changeAcl(const CSSM_ACL_EDIT &aclEdit,
const CSSM_ACCESS_CREDENTIALS *accessCred);
void getOwner(AutoAclOwnerPrototype &owner) const;
void changeOwner(const CSSM_ACL_OWNER_PROTOTYPE &newOwner,
const CSSM_ACCESS_CREDENTIALS *accessCred = NULL);
void activate();
protected:
void deactivate();
};
class Key : public Object
{
public:
typedef KeyImpl Impl;
explicit Key(Impl *impl) : Object(impl) {}
Key() : Object(NULL) {}
Key(const CSP &csp, const CSSM_KEY &key, bool copy = false) : Object(new Impl(csp, key, copy)) {}
Key(const CSP &csp, const CSSM_DATA &keyData) : Object(new Impl(csp, keyData)) {}
Key(const CSP &csp) : Object(new Impl(csp)) {}
Impl *operator ->() const { return (*this) ? &impl<Impl>() : NULL; }
Impl &operator *() const { return impl<Impl>(); }
operator const CssmKey * () const { return (*this) ? &(**this) : NULL; }
operator const CssmKey & () const { return **this; }
CssmKey::Header &header() const { return (*this)->header(); }
CssmKey *makeNewKey(const CSP &csp) { (*this) = Key(csp); return &(**this); }
CssmKeySize sizeInBits() const { return (*this)->sizeInBits(); }
};
struct KeySpec {
CSSM_KEYUSE usage;
CSSM_KEYATTR_FLAGS attributes;
const CssmData *label;
KeySpec(CSSM_KEYUSE u, CSSM_KEYATTR_FLAGS a) : usage(u), attributes(a), label(NULL) { }
KeySpec(CSSM_KEYUSE u, CSSM_KEYATTR_FLAGS a, const CssmData &l) : usage(u), attributes(a), label(&l) { }
};
}
}
#endif // _H_CDSA_CLIENT_KEYCLIENT