3d4154f0876442476221b5138c3995aa88f14359
[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/key-manager.h>
27
28 namespace CKM {
29
30 class Manager::ManagerImpl {
31 public:
32     ManagerImpl()
33       : m_counter(0)
34     {}
35     virtual ~ManagerImpl(){}
36
37     int saveKey(const Alias &alias, const Key &key, const Policy &policy);
38     int removeKey(const Alias &alias);
39     int getKey(const Alias &alias, const std::string &password, Key &key);
40     int getKeyAliasVector(AliasVector &aliasVector);
41
42     int saveCertificate(const Alias &alias, const Certificate &cert, const Policy &policy);
43     int removeCertificate(const Alias &alias);
44     int getCertificate(const Alias &alias, const std::string &password, Certificate &cert);
45     int getCertificateAliasVector(AliasVector &aliasVector);
46
47     int saveData(const Alias &alias, const RawBuffer &rawData, const Policy &policy);
48     int removeData(const Alias &alias);
49     int getData(const Alias &alias, const std::string &password, RawBuffer &cert);
50     int getDataAliasVector(AliasVector &aliasVector);
51     
52     int createKeyPairRSA(
53         const int size,              // size in bits [1024, 2048, 4096]
54         const Alias &privateKeyAlias,
55         const Alias &publicKeyAlias,
56         const Policy &policyPrivateKey = Policy(),
57         const Policy &policyPublicKey = Policy());
58
59     int createKeyPairECDSA(
60         ElipticCurve type,
61         const Alias &privateKeyAlias,
62         const Alias &publicKeyAlias,
63         const Policy &policyPrivateKey = Policy(),
64         const Policy &policyPublicKey = Policy());
65
66     int getCertificateChain(
67         const Certificate &certificate,
68         const CertificateVector &untrustedCertificates,
69         CertificateVector &certificateChainVector);
70
71     int getCertificateChain(
72         const Certificate &certificate,
73         const AliasVector &untrustedCertificates,
74         CertificateVector &certificateChainVector);
75
76     int createSignature(
77         const Alias &privateKeyAlias,
78         const std::string &password,           // password for private_key
79         const RawBuffer &message,
80         const HashAlgorithm hash,
81         const RSAPaddingAlgorithm padding,
82         RawBuffer &signature);
83
84     int verifySignature(
85         const Alias &publicKeyOrCertAlias,
86         const std::string &password,           // password for public_key (optional)
87         const RawBuffer &message,
88         const RawBuffer &signature,
89         const HashAlgorithm hash,
90         const RSAPaddingAlgorithm padding);
91
92 protected:
93     int saveBinaryData(
94         const Alias &alias,
95         DBDataType dataType,
96         const RawBuffer &rawData,
97         const Policy &policy);
98
99     int removeBinaryData(
100         const Alias &alias,
101         DBDataType dataType);
102
103     int getBinaryData(
104         const Alias &alias,
105         DBDataType sendDataType,
106         const std::string &password,
107         DBDataType &recvDataType,
108         RawBuffer &rawData);
109
110     int getBinaryDataAliasVector(
111         DBDataType sendDataType,
112         AliasVector &aliasVector);
113
114     int m_counter;
115 };
116
117 } // namespace CKM
118