1 /* Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd All Rights Reserved
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
7 * http://www.apache.org/licenses/LICENSE-2.0
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License
16 * @file client-manager-impl.h
17 * @author Bartlomiej Grzelewski (b.grzelewski@samsung.com)
19 * @brief Manager implementation.
23 #include <data-type.h>
24 #include <client-common.h>
25 #include <ckm/ckm-type.h>
26 #include <ckm/ckm-key.h>
27 #include <ckm/ckm-manager.h>
31 class ManagerImpl : public Manager {
34 virtual ~ManagerImpl(){}
36 int saveKey(const Alias &alias, const KeyShPtr &key, const Policy &policy);
37 int getKey(const Alias &alias, const Password &password, KeyShPtr &key);
38 int getKeyAliasVector(AliasVector &aliasVector);
40 int saveCertificate(const Alias &alias, const CertificateShPtr &cert, const Policy &policy);
41 int getCertificate(const Alias &alias, const Password &password, CertificateShPtr &cert);
42 int getCertificateAliasVector(AliasVector &aliasVector);
44 int saveData(const Alias &alias, const RawBuffer &rawData, const Policy &policy);
45 int getData(const Alias &alias, const Password &password, RawBuffer &cert);
46 int getDataAliasVector(AliasVector &aliasVector);
50 const PKCS12ShPtr &pkcs,
51 const Policy &keyPolicy,
52 const Policy &certPolicy);
53 int getPKCS12(const Alias &alias, PKCS12ShPtr &pkcs);
54 int getPKCS12(const Alias &alias, const Password &keyPass, const Password &certPass, PKCS12ShPtr &pkcs);
56 int removeAlias(const Alias &alias);
59 const int size, // size in bits [1024, 2048, 4096]
60 const Alias &privateKeyAlias,
61 const Alias &publicKeyAlias,
62 const Policy &policyPrivateKey = Policy(),
63 const Policy &policyPublicKey = Policy());
66 const int size, // size in bits [1024, 2048, 3072, 4096]
67 const Alias &privateKeyAlias,
68 const Alias &publicKeyAlias,
69 const Policy &policyPrivateKey = Policy(),
70 const Policy &policyPublicKey = Policy());
72 int createKeyPairECDSA(
74 const Alias &privateKeyAlias,
75 const Alias &publicKeyAlias,
76 const Policy &policyPrivateKey = Policy(),
77 const Policy &policyPublicKey = Policy());
79 int getCertificateChain(
80 const CertificateShPtr &certificate,
81 const CertificateShPtrVector &untrustedCertificates,
82 const CertificateShPtrVector &trustedCertificates,
83 bool useTrustedSystemCertificates,
84 CertificateShPtrVector &certificateChainVector);
86 int getCertificateChain(
87 const CertificateShPtr &certificate,
88 const AliasVector &untrustedCertificates,
89 const AliasVector &trustedCertificates,
90 bool useTrustedSystemCertificates,
91 CertificateShPtrVector &certificateChainVector);
94 const Alias &privateKeyAlias,
95 const Password &password, // password for private_key
96 const RawBuffer &message,
97 const HashAlgorithm hash,
98 const RSAPaddingAlgorithm padding,
99 RawBuffer &signature);
102 const Alias &publicKeyOrCertAlias,
103 const Password &password, // password for public_key (optional)
104 const RawBuffer &message,
105 const RawBuffer &signature,
106 const HashAlgorithm hash,
107 const RSAPaddingAlgorithm padding);
109 int ocspCheck(const CertificateShPtrVector &certificateChain, int &ocspCheck);
111 int setPermission(const Alias &alias, const Label &accessor, PermissionMask permissionMask);
117 const RawBuffer &rawData,
118 const Policy &policy);
122 DataType sendDataType,
123 const Password &password,
124 DataType &recvDataType,
127 int getBinaryDataAliasVector(
128 DataType sendDataType,
129 AliasVector &aliasVector);
132 const KeyType key_type,
133 const int additional_param, // key size for [RSA|DSA], elliptic curve type for ECDSA
134 const Alias &privateKeyAlias,
135 const Alias &publicKeyAlias,
136 const Policy &policyPrivateKey,
137 const Policy &policyPublicKey);
140 CKM::ServiceConnection m_storageConnection;
141 CKM::ServiceConnection m_ocspConnection;