c71d106bb1d9aba79d0bc0aba9b861e8fd3b1488
[platform/core/security/key-manager.git] / src / manager / crypto / sw-backend / internals.h
1 /*
2  *  Copyright (c) 2000 - 2015 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  *  Licensed under the Apache License, Version 2.0 (the "License");
5  *  you may not use this file except in compliance with the License.
6  *  You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  *  Unless required by applicable law or agreed to in writing, software
11  *  distributed under the License is distributed on an "AS IS" BASIS,
12  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  *  See the License for the specific language governing permissions and
14  *  limitations under the License
15  */
16 /*
17  * @file       internals.h
18  * @author
19  * @version    1.0
20  */
21 #pragma once
22
23 #include <key-impl.h>
24 #include <certificate-impl.h>
25 #include <ckm/ckm-type.h>
26 #include <openssl/evp.h>
27 #include <token.h>
28 #include <sw-backend/key.h>
29
30 #define EVP_SUCCESS 1   // DO NOTCHANGE THIS VALUE
31 #define EVP_FAIL    0   // DO NOTCHANGE THIS VALUE
32
33 #define CKM_CRYPTO_INIT_SUCCESS 1
34 #define CKM_CRYPTO_CREATEKEY_SUCCESS 2
35 #define CKM_VERIFY_CHAIN_SUCCESS 5
36 #define NOT_DEFINED -1
37
38 namespace CKM {
39 namespace Crypto {
40 namespace SW {
41 namespace Internals {
42
43 TokenPair createKeyPairRSA(CryptoBackend backendId, const int size);
44 TokenPair createKeyPairDSA(CryptoBackend backendId, const int size);
45 TokenPair createKeyPairECDSA(CryptoBackend backendId, ElipticCurve type1);
46 Token     createKeyAES(CryptoBackend backendId, const int sizeBits);
47
48 TokenPair generateAKey(CryptoBackend backendId, const CryptoAlgorithm &algorithm);
49 Token generateSKey(CryptoBackend backendId, const CryptoAlgorithm &algorithm);
50
51 RawBuffer symmetricEncrypt(const RawBuffer &key,
52                            const CryptoAlgorithm &alg,
53                            const RawBuffer &data);
54 RawBuffer symmetricDecrypt(const RawBuffer &key,
55                            const CryptoAlgorithm &alg,
56                            const RawBuffer &cipher);
57 RawBuffer asymmetricEncrypt(const EvpShPtr &key,
58                             const CryptoAlgorithm &alg,
59                             const RawBuffer &data);
60 RawBuffer asymmetricDecrypt(const EvpShPtr &key,
61                             const CryptoAlgorithm &alg,
62                             const RawBuffer &data);
63
64 std::pair<RawBuffer, RawBuffer> encryptDataAesGcm(const RawBuffer &key,
65     const RawBuffer &data,
66     const RawBuffer &iv,
67     int tagSize,
68     const RawBuffer &aad = RawBuffer());
69
70 RawBuffer decryptDataAesGcm(const RawBuffer &key,
71     const RawBuffer &data,
72     const RawBuffer &iv,
73     const RawBuffer &tag,
74     const RawBuffer &aad = RawBuffer());
75
76 RawBuffer encryptDataAes(AlgoType type,
77     const RawBuffer &key,
78     const RawBuffer &data,
79     const RawBuffer &iv);
80
81 RawBuffer decryptDataAes(AlgoType type,
82     const RawBuffer &key,
83     const RawBuffer &data,
84     const RawBuffer &iv);
85
86 RawBuffer sign(EVP_PKEY *pkey,
87     const CryptoAlgorithm &alg,
88     const RawBuffer &message);
89
90 int verify(EVP_PKEY *pkey,
91     const CryptoAlgorithm &alg,
92     const RawBuffer &message,
93     const RawBuffer &signature);
94
95 const EVP_MD *getMdAlgo(const HashAlgorithm hashAlgo);
96 int getRsaPadding(const RSAPaddingAlgorithm padAlgo);
97
98 RawBuffer signMessage(EVP_PKEY *privKey,
99     const RawBuffer &message,
100     const int rsa_padding);
101
102 RawBuffer digestSignMessage(EVP_PKEY *privKey,
103     const RawBuffer &message,
104     const EVP_MD *md_algo,
105     const int rsa_padding);
106
107 int verifyMessage(EVP_PKEY *pubKey,
108     const RawBuffer &message,
109     const RawBuffer &signature,
110     const int rsa_padding);
111
112 int digestVerifyMessage(EVP_PKEY *pubKey,
113     const RawBuffer &message,
114     const RawBuffer &signature,
115     const EVP_MD *md_algo,
116     const int rsa_padding);
117
118 } // namespace Internals
119 } // namespace SW
120 } // namespace Crypto
121 } // namespace CKM
122