638532d6e92b10af1b086019f17320374c430756
[platform/core/security/key-manager.git] / src / manager / crypto / generic-backend / gstore.h
1 /*
2  *  Copyright (c) 2015 - 2018 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       gstore.h
18  * @author     BartÅ‚omiej Grzelewski (b.grzelewski@samsung.com)
19  * @version    1.0
20  */
21 #pragma once
22
23 #include <memory>
24
25 #include <generic-backend/exception.h>
26 #include <generic-backend/gobj.h>
27 #include <generic-backend/encryption-params.h>
28 #include <ckm/ckm-type.h>
29 #include <crypto-backend.h>
30 #include <token.h>
31
32 namespace CKM {
33 namespace Crypto {
34
35 // Data is very generic and does not say anything about content.
36 struct Data {
37         Data() {};
38         Data(const DataType &t, RawBuffer d) : type(t), data(std::move(d)) {}
39         DataType type;
40         RawBuffer data; // buffer will be better?
41 };
42
43 class GStore {
44 public:
45         virtual GObjUPtr getObject(const Token &, const Password &)
46         {
47                 ThrowErr(Exc::Crypto::OperationNotSupported);
48         }
49         virtual TokenPair generateAKey(const CryptoAlgorithm &,
50                                        const Password &,
51                                        const Password &)
52         {
53                 ThrowErr(Exc::Crypto::OperationNotSupported);
54         }
55         virtual Token generateSKey(const CryptoAlgorithm &, const Password &)
56         {
57                 ThrowErr(Exc::Crypto::OperationNotSupported);
58         }
59
60         /*
61          * EncryptionParams parameter makes sense only on device with built-in key.
62          * EncryptionParams parameter is used for decryption of Data.
63          * If Data is not encrypted it's ok to pass empty EncryptionParams.
64          */
65         virtual Token import(const Data &, const Password &, const EncryptionParams &)
66         {
67                 ThrowErr(Exc::Crypto::OperationNotSupported);
68         }
69         virtual void destroy(const Token &)
70         {
71                 ThrowErr(Exc::Crypto::OperationNotSupported);
72         }
73         virtual ~GStore() {}
74
75 protected:
76         explicit GStore(CryptoBackend backendId) :
77                 m_backendId(backendId)
78         {
79         }
80
81         CryptoBackend m_backendId;
82 };
83
84 } // namespace Crypto
85 } // namespace CKM