Simpliefied public headers names.
[platform/core/security/key-manager.git] / src / manager / client / client-manager-impl.h
1 /* Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd All Rights Reserved
2  *
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
6  *
7  *      http://www.apache.org/licenses/LICENSE-2.0
8  *
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
14  *
15  *
16  * @file        client-manager-impl.h
17  * @author      Bartlomiej Grzelewski (b.grzelewski@samsung.com)
18  * @version     1.0
19  * @brief       Manager implementation.
20  */
21 #pragma once
22
23 #include <protocols.h>
24
25 #include <ckm/ckm-type.h>
26 #include <ckm/ckm-manager.h>
27
28 namespace CKM {
29
30 class Manager::ManagerImpl {
31 public:
32     ManagerImpl();
33     virtual ~ManagerImpl(){}
34
35     int saveKey(const Alias &alias, const Key &key, const Policy &policy);
36     int removeKey(const Alias &alias);
37     int getKey(const Alias &alias, const std::string &password, Key &key);
38     int getKeyAliasVector(AliasVector &aliasVector);
39
40     int saveCertificate(const Alias &alias, const Certificate &cert, const Policy &policy);
41     int removeCertificate(const Alias &alias);
42     int getCertificate(const Alias &alias, const std::string &password, Certificate &cert);
43     int getCertificateAliasVector(AliasVector &aliasVector);
44
45     int saveData(const Alias &alias, const RawBuffer &rawData, const Policy &policy);
46     int removeData(const Alias &alias);
47     int getData(const Alias &alias, const std::string &password, RawBuffer &cert);
48     int getDataAliasVector(AliasVector &aliasVector);
49
50     int createKeyPairRSA(
51         const int size,              // size in bits [1024, 2048, 4096]
52         const Alias &privateKeyAlias,
53         const Alias &publicKeyAlias,
54         const Policy &policyPrivateKey = Policy(),
55         const Policy &policyPublicKey = Policy());
56
57     int createKeyPairECDSA(
58         ElipticCurve type,
59         const Alias &privateKeyAlias,
60         const Alias &publicKeyAlias,
61         const Policy &policyPrivateKey = Policy(),
62         const Policy &policyPublicKey = Policy());
63
64     int getCertificateChain(
65         const Certificate &certificate,
66         const CertificateVector &untrustedCertificates,
67         CertificateVector &certificateChainVector);
68
69     int getCertificateChain(
70         const Certificate &certificate,
71         const AliasVector &untrustedCertificates,
72         CertificateVector &certificateChainVector);
73
74     int createSignature(
75         const Alias &privateKeyAlias,
76         const std::string &password,           // password for private_key
77         const RawBuffer &message,
78         const HashAlgorithm hash,
79         const RSAPaddingAlgorithm padding,
80         RawBuffer &signature);
81
82     int verifySignature(
83         const Alias &publicKeyOrCertAlias,
84         const std::string &password,           // password for public_key (optional)
85         const RawBuffer &message,
86         const RawBuffer &signature,
87         const HashAlgorithm hash,
88         const RSAPaddingAlgorithm padding);
89
90 protected:
91     int saveBinaryData(
92         const Alias &alias,
93         DBDataType dataType,
94         const RawBuffer &rawData,
95         const Policy &policy);
96
97     int removeBinaryData(
98         const Alias &alias,
99         DBDataType dataType);
100
101     int getBinaryData(
102         const Alias &alias,
103         DBDataType sendDataType,
104         const std::string &password,
105         DBDataType &recvDataType,
106         RawBuffer &rawData);
107
108     int getBinaryDataAliasVector(
109         DBDataType sendDataType,
110         AliasVector &aliasVector);
111
112     int m_counter;
113     static bool s_isInit;
114 };
115
116 } // namespace CKM
117