]>
git.saurik.com Git - apple/security.git/blob - libsecurity_cdsa_client/lib/keyclient.cpp
2 * Copyright (c) 2000-2001 Apple Computer, Inc. All Rights Reserved.
4 * The contents of this file constitute Original Code as defined in and are
5 * subject to the Apple Public Source License Version 1.2 (the 'License').
6 * You may not use this file except in compliance with the License. Please obtain
7 * a copy of the License at http://www.apple.com/publicsource and read it before
10 * This Original Code and all software distributed under the License are
11 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS
12 * OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT
13 * LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
14 * PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. Please see the License for the
15 * specific language governing rights and limitations under the License.
22 #include <security_cdsa_client/keyclient.h>
23 #include <security_cdsa_utilities/cssmdata.h>
26 using namespace CssmClient
;
29 KeyImpl::KeyImpl(const CSP
&csp
) : ObjectImpl(csp
), CssmKey()
34 KeyImpl::KeyImpl(const CSP
&csp
, const CSSM_KEY
&key
, bool copy
) : ObjectImpl(csp
), CssmKey(key
)
37 keyData() = CssmAutoData(csp
.allocator(), keyData()).release();
41 KeyImpl::KeyImpl(const CSP
&csp
, const CSSM_DATA
&keyData
) : ObjectImpl(csp
),
42 CssmKey(keyData
.Length
, csp
->allocator().alloc
<uint8
>(keyData
.Length
))
44 memcpy(KeyData
.Data
, keyData
.Data
, keyData
.Length
);
58 KeyImpl::deleteKey(const CSSM_ACCESS_CREDENTIALS
*cred
)
60 StLock
<Mutex
> _(mActivateMutex
);
64 check(CSSM_FreeKey(csp()->handle(), cred
, this, CSSM_TRUE
));
69 KeyImpl::sizeInBits() const
72 check(CSSM_QueryKeySizeInBits(csp()->handle(), CSSM_INVALID_HANDLE
, this, &size
));
77 KeyImpl::getAcl(AutoAclEntryInfoList
&aclInfos
, const char *selectionTag
) const
79 aclInfos
.allocator(allocator());
80 check(CSSM_GetKeyAcl(csp()->handle(), this, reinterpret_cast<const CSSM_STRING
*>(selectionTag
), aclInfos
, aclInfos
));
84 KeyImpl::changeAcl(const CSSM_ACL_EDIT
&aclEdit
,
85 const CSSM_ACCESS_CREDENTIALS
*accessCred
)
87 check(CSSM_ChangeKeyAcl(csp()->handle(),
88 AccessCredentials::needed(accessCred
), &aclEdit
, this));
92 KeyImpl::getOwner(AutoAclOwnerPrototype
&owner
) const
94 owner
.allocator(allocator());
95 check(CSSM_GetKeyOwner(csp()->handle(), this, owner
));
99 KeyImpl::changeOwner(const CSSM_ACL_OWNER_PROTOTYPE
&newOwner
,
100 const CSSM_ACCESS_CREDENTIALS
*accessCred
)
102 check(CSSM_ChangeKeyOwner(csp()->handle(),
103 AccessCredentials::needed(accessCred
), this, &newOwner
));
106 void KeyImpl::activate()
108 StLock
<Mutex
> _(mActivateMutex
);
112 void KeyImpl::deactivate()
114 StLock
<Mutex
> _(mActivateMutex
);
118 check(CSSM_FreeKey(csp()->handle(), NULL
, this, CSSM_FALSE
));