Modify the supporting information for RSA padding algorithms
[platform/core/security/key-manager.git] / src / manager / client / client-certificate-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-certificate-impl.h
17  * @author      Barlomiej Grzelewski (b.grzelewski@samsung.com)
18  * @version     1.0
19  * @brief       Certificate Implmentation.
20  */
21
22 #pragma once
23
24 #include <memory>
25 #include <vector>
26 #include <ckm/ckm-type.h>
27 #include <ckm/key-manager.h>
28
29 extern "C" {
30 struct x509_st;
31 typedef struct x509_st X509;
32 }
33
34 namespace CKM {
35
36 class CertificateImpl {
37 public:
38     CertificateImpl(){}
39     CertificateImpl(const RawBuffer &data, Certificate::Format format);
40     CertificateImpl& operator=(const CertificateImpl &);
41     RawBuffer getDER() const;
42     bool empty() const;
43
44     ~CertificateImpl();
45
46 protected:
47     X509* m_x509;
48 };
49
50 typedef std::vector<CertificateImpl> CertificateImplVector;
51
52 } // namespace CKM
53