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 <protocols.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 removeKey(const Alias &alias);
38 int getKey(const Alias &alias, const Password &password, KeyShPtr &key);
39 int getKeyAliasVector(AliasVector &aliasVector);
41 int saveCertificate(const Alias &alias, const CertificateShPtr &cert, const Policy &policy);
42 int removeCertificate(const Alias &alias);
43 int getCertificate(const Alias &alias, const Password &password, CertificateShPtr &cert);
44 int getCertificateAliasVector(AliasVector &aliasVector);
46 int saveData(const Alias &alias, const RawBuffer &rawData, const Policy &policy);
47 int removeData(const Alias &alias);
48 int getData(const Alias &alias, const Password &password, RawBuffer &cert);
49 int getDataAliasVector(AliasVector &aliasVector);
52 const int size, // size in bits [1024, 2048, 4096]
53 const Alias &privateKeyAlias,
54 const Alias &publicKeyAlias,
55 const Policy &policyPrivateKey = Policy(),
56 const Policy &policyPublicKey = Policy());
58 int createKeyPairECDSA(
60 const Alias &privateKeyAlias,
61 const Alias &publicKeyAlias,
62 const Policy &policyPrivateKey = Policy(),
63 const Policy &policyPublicKey = Policy());
65 int getCertificateChain(
66 const CertificateShPtr &certificate,
67 const CertificateShPtrVector &untrustedCertificates,
68 CertificateShPtrVector &certificateChainVector);
70 int getCertificateChain(
71 const CertificateShPtr &certificate,
72 const AliasVector &untrustedCertificates,
73 CertificateShPtrVector &certificateChainVector);
76 const Alias &privateKeyAlias,
77 const Password &password, // password for private_key
78 const RawBuffer &message,
79 const HashAlgorithm hash,
80 const RSAPaddingAlgorithm padding,
81 RawBuffer &signature);
84 const Alias &publicKeyOrCertAlias,
85 const Password &password, // password for public_key (optional)
86 const RawBuffer &message,
87 const RawBuffer &signature,
88 const HashAlgorithm hash,
89 const RSAPaddingAlgorithm padding);
91 int ocspCheck(const CertificateShPtrVector &certificateChain, int &ocspCheck);
97 const RawBuffer &rawData,
98 const Policy &policy);
100 int removeBinaryData(
102 DBDataType dataType);
106 DBDataType sendDataType,
107 const Password &password,
108 DBDataType &recvDataType,
111 int getBinaryDataAliasVector(
112 DBDataType sendDataType,
113 AliasVector &aliasVector);
116 static bool s_isInit;