]>
git.saurik.com Git - apple/security.git/blob - OSX/libsecurity_cdsa_client/lib/keyclient.cpp
2 * Copyright (c) 2000-2001,2011-2014 Apple 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((uint32
)keyData
.Length
, csp
->allocator().alloc
<uint8
>((UInt32
)keyData
.Length
))
44 memcpy(KeyData
.Data
, keyData
.Data
, keyData
.Length
);
55 return; // Prevent re-throw of exception [function-try-block]
59 KeyImpl::deleteKey(const CSSM_ACCESS_CREDENTIALS
*cred
)
61 StLock
<Mutex
> _(mActivateMutex
);
65 check(CSSM_FreeKey(csp()->handle(), cred
, this, CSSM_TRUE
));
70 KeyImpl::sizeInBits() const
73 check(CSSM_QueryKeySizeInBits(csp()->handle(), CSSM_INVALID_HANDLE
, this, &size
));
78 KeyImpl::getAcl(AutoAclEntryInfoList
&aclInfos
, const char *selectionTag
) const
80 aclInfos
.allocator(allocator());
81 check(CSSM_GetKeyAcl(csp()->handle(), this, reinterpret_cast<const CSSM_STRING
*>(selectionTag
), aclInfos
, aclInfos
));
85 KeyImpl::changeAcl(const CSSM_ACL_EDIT
&aclEdit
,
86 const CSSM_ACCESS_CREDENTIALS
*accessCred
)
88 check(CSSM_ChangeKeyAcl(csp()->handle(),
89 AccessCredentials::needed(accessCred
), &aclEdit
, this));
93 KeyImpl::getOwner(AutoAclOwnerPrototype
&owner
) const
95 owner
.allocator(allocator());
96 check(CSSM_GetKeyOwner(csp()->handle(), this, owner
));
100 KeyImpl::changeOwner(const CSSM_ACL_OWNER_PROTOTYPE
&newOwner
,
101 const CSSM_ACCESS_CREDENTIALS
*accessCred
)
103 check(CSSM_ChangeKeyOwner(csp()->handle(),
104 AccessCredentials::needed(accessCred
), this, &newOwner
));
107 void KeyImpl::activate()
109 StLock
<Mutex
> _(mActivateMutex
);
113 void KeyImpl::deactivate()
115 StLock
<Mutex
> _(mActivateMutex
);
119 check(CSSM_FreeKey(csp()->handle(), NULL
, this, CSSM_FALSE
));