Make GStore members pure virtual
[platform/core/security/key-manager.git] / src / manager / crypto / generic-backend / gstore.h
1 /*
2  *  Copyright (c) 2015-2019 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/gobj.h>
26 #include <generic-backend/encryption-params.h>
27 #include <ckm/ckm-type.h>
28 #include <crypto-backend.h>
29 #include <token.h>
30
31 namespace CKM {
32 namespace Crypto {
33
34 // Data is very generic and does not say anything about content.
35 struct Data {
36         Data() {};
37         Data(const DataType &t, RawBuffer d) : type(t), data(std::move(d)) {}
38         DataType type;
39         RawBuffer data; // buffer will be better?
40 };
41
42 class GStore {
43 public:
44         virtual GObjUPtr getObject(const Token &, const Password &) = 0;
45         virtual TokenPair generateAKey(const CryptoAlgorithm &,
46                                        const Password &,
47                                        const Password &) = 0;
48         virtual Token generateSKey(const CryptoAlgorithm &, const Password &) = 0;
49
50         /*
51          * EncryptionParams parameter makes sense only on device with built-in key.
52          * EncryptionParams parameter is used for decryption of Data.
53          * If Data is not encrypted it's ok to pass empty EncryptionParams.
54          */
55         virtual Token import(const Data &, const Password &, const EncryptionParams &) = 0;
56         virtual void destroy(const Token &) = 0;
57         virtual ~GStore() {}
58
59 protected:
60         explicit GStore(CryptoBackend backendId) :
61                 m_backendId(backendId)
62         {
63         }
64
65         CryptoBackend m_backendId;
66 };
67
68 } // namespace Crypto
69 } // namespace CKM