Modify encryption scheme
[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 <sw-backend/obj.h>
28
29 #define EVP_SUCCESS 1   // DO NOTCHANGE THIS VALUE
30 #define EVP_FAIL    0   // DO NOTCHANGE THIS VALUE
31
32 #define CKM_CRYPTO_INIT_SUCCESS 1
33 #define CKM_CRYPTO_CREATEKEY_SUCCESS 2
34 #define CKM_VERIFY_CHAIN_SUCCESS 5
35 #define NOT_DEFINED -1
36
37 namespace CKM {
38 namespace Crypto {
39 namespace SW {
40 namespace Internals {
41
42 // TODO replace it with DataContainer
43 struct Data {
44     DataType type;
45     RawBuffer buffer;
46 };
47
48 typedef std::pair<Data,Data> DataPair;
49
50 DataPair createKeyPairRSA(const int size);
51 DataPair createKeyPairDSA(const int size);
52 DataPair createKeyPairECDSA(ElipticCurve type1);
53 Data     createKeyAES(const int sizeBits);
54
55 DataPair generateAKey(const CryptoAlgorithm &algorithm);
56 Data generateSKey(const CryptoAlgorithm &algorithm);
57
58 RawBuffer symmetricEncrypt(const RawBuffer &key,
59                            const CryptoAlgorithm &alg,
60                            const RawBuffer &data);
61 RawBuffer symmetricDecrypt(const RawBuffer &key,
62                            const CryptoAlgorithm &alg,
63                            const RawBuffer &cipher);
64 RawBuffer asymmetricEncrypt(const EvpShPtr &key,
65                             const CryptoAlgorithm &alg,
66                             const RawBuffer &data);
67 RawBuffer asymmetricDecrypt(const EvpShPtr &key,
68                             const CryptoAlgorithm &alg,
69                             const RawBuffer &data);
70
71 std::pair<RawBuffer, RawBuffer> encryptDataAesGcm(const RawBuffer &key,
72     const RawBuffer &data,
73     const RawBuffer &iv,
74     int tagSize,
75     const RawBuffer &aad = RawBuffer());
76
77 RawBuffer decryptDataAesGcm(const RawBuffer &key,
78     const RawBuffer &data,
79     const RawBuffer &iv,
80     const RawBuffer &tag,
81     const RawBuffer &aad = RawBuffer());
82
83 RawBuffer encryptDataAes(AlgoType type,
84     const RawBuffer &key,
85     const RawBuffer &data,
86     const RawBuffer &iv);
87
88 RawBuffer decryptDataAes(AlgoType type,
89     const RawBuffer &key,
90     const RawBuffer &data,
91     const RawBuffer &iv);
92
93 RawBuffer sign(EVP_PKEY *pkey,
94     const CryptoAlgorithm &alg,
95     const RawBuffer &message);
96
97 int verify(EVP_PKEY *pkey,
98     const CryptoAlgorithm &alg,
99     const RawBuffer &message,
100     const RawBuffer &signature);
101
102 const EVP_MD *getMdAlgo(const HashAlgorithm hashAlgo);
103 int getRsaPadding(const RSAPaddingAlgorithm padAlgo);
104
105 RawBuffer signMessage(EVP_PKEY *privKey,
106     const RawBuffer &message,
107     const int rsa_padding);
108
109 RawBuffer digestSignMessage(EVP_PKEY *privKey,
110     const RawBuffer &message,
111     const EVP_MD *md_algo,
112     const int rsa_padding);
113
114 int verifyMessage(EVP_PKEY *pubKey,
115     const RawBuffer &message,
116     const RawBuffer &signature,
117     const int rsa_padding);
118
119 int digestVerifyMessage(EVP_PKEY *pubKey,
120     const RawBuffer &message,
121     const RawBuffer &signature,
122     const EVP_MD *md_algo,
123     const int rsa_padding);
124
125 } // namespace Internals
126 } // namespace SW
127 } // namespace Crypto
128 } // namespace CKM
129