]> git.saurik.com Git - apple/security.git/blame - OSX/libsecurity_cdsa_client/lib/keyclient.cpp
Security-58286.240.4.tar.gz
[apple/security.git] / OSX / libsecurity_cdsa_client / lib / keyclient.cpp
CommitLineData
b1ab9ed8 1/*
d8f41ccd 2 * Copyright (c) 2000-2001,2011-2014 Apple Inc. All Rights Reserved.
b1ab9ed8
A
3 *
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
8 * using this file.
9 *
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.
16 */
17
18
19//
20// keyclient
21//
22#include <security_cdsa_client/keyclient.h>
23#include <security_cdsa_utilities/cssmdata.h>
24
25
26using namespace CssmClient;
27
28
29KeyImpl::KeyImpl(const CSP &csp) : ObjectImpl(csp), CssmKey()
30{
31 mActive=false;
32}
33
34KeyImpl::KeyImpl(const CSP &csp, const CSSM_KEY &key, bool copy) : ObjectImpl(csp), CssmKey(key)
35{
36 if (copy)
37 keyData() = CssmAutoData(csp.allocator(), keyData()).release();
38 mActive=true;
39}
40
41KeyImpl::KeyImpl(const CSP &csp, const CSSM_DATA &keyData) : ObjectImpl(csp),
427c49bc 42CssmKey((uint32)keyData.Length, csp->allocator().alloc<uint8>((UInt32)keyData.Length))
b1ab9ed8
A
43{
44 memcpy(KeyData.Data, keyData.Data, keyData.Length);
45 mActive=true;
46}
47
48KeyImpl::~KeyImpl()
c2a06e24
A
49try
50{
427c49bc 51 deactivate();
c2a06e24
A
52}
53catch (...)
b1ab9ed8 54{
6b200bc3 55 return; // Prevent re-throw of exception [function-try-block]
b1ab9ed8
A
56}
57
58void
59KeyImpl::deleteKey(const CSSM_ACCESS_CREDENTIALS *cred)
60{
313fa17b 61 StLock<Mutex> _(mActivateMutex);
b1ab9ed8
A
62 if (mActive)
63 {
64 mActive=false;
65 check(CSSM_FreeKey(csp()->handle(), cred, this, CSSM_TRUE));
66 }
67}
68
69CssmKeySize
70KeyImpl::sizeInBits() const
71{
72 CssmKeySize size;
73 check(CSSM_QueryKeySizeInBits(csp()->handle(), CSSM_INVALID_HANDLE, this, &size));
74 return size;
75}
76
77void
78KeyImpl::getAcl(AutoAclEntryInfoList &aclInfos, const char *selectionTag) const
79{
80 aclInfos.allocator(allocator());
81 check(CSSM_GetKeyAcl(csp()->handle(), this, reinterpret_cast<const CSSM_STRING *>(selectionTag), aclInfos, aclInfos));
82}
83
84void
85KeyImpl::changeAcl(const CSSM_ACL_EDIT &aclEdit,
86 const CSSM_ACCESS_CREDENTIALS *accessCred)
87{
88 check(CSSM_ChangeKeyAcl(csp()->handle(),
89 AccessCredentials::needed(accessCred), &aclEdit, this));
90}
91
92void
93KeyImpl::getOwner(AutoAclOwnerPrototype &owner) const
94{
95 owner.allocator(allocator());
96 check(CSSM_GetKeyOwner(csp()->handle(), this, owner));
97}
98
99void
100KeyImpl::changeOwner(const CSSM_ACL_OWNER_PROTOTYPE &newOwner,
101 const CSSM_ACCESS_CREDENTIALS *accessCred)
102{
103 check(CSSM_ChangeKeyOwner(csp()->handle(),
104 AccessCredentials::needed(accessCred), this, &newOwner));
105}
106
107void KeyImpl::activate()
108{
313fa17b 109 StLock<Mutex> _(mActivateMutex);
b1ab9ed8
A
110 mActive=true;
111}
112
113void KeyImpl::deactivate()
114{
313fa17b 115 StLock<Mutex> _(mActivateMutex);
b1ab9ed8
A
116 if (mActive)
117 {
118 mActive=false;
119 check(CSSM_FreeKey(csp()->handle(), NULL, this, CSSM_FALSE));
120 }
121}