sync with tizen_2.0
[platform/framework/native/appfw.git] / src / security / cert / FSecCert_CertSignature.h
1 //
2 // Open Service Platform
3 // Copyright (c) 2012 Samsung Electronics Co., Ltd.
4 //
5 // Licensed under the Apache License, Version 2.0 (the License);
6 // you may not use this file except in compliance with the License.
7 // You may obtain a copy of the License at
8 //
9 //     http://www.apache.org/licenses/LICENSE-2.0
10 //
11 // Unless required by applicable law or agreed to in writing, software
12 // distributed under the License is distributed on an "AS IS" BASIS,
13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 // See the License for the specific language governing permissions and
15 // limitations under the License.
16 //
17
18 /**
19  * @file        FSecCert_CertSignature.h
20  * @brief       This header file contains the declarations of certificate signature verification.
21  *
22  * This header file contains the declarations of certificate signature verification.
23  */
24
25 #ifndef _FSEC_CERT_INTERNAL_CERT_SIGNATURE_H_
26 #define _FSEC_CERT_INTERNAL_CERT_SIGNATURE_H_
27
28 #include <unique_ptr.h>
29 #include "FSecCert_CertTypes.h"
30
31 namespace Tizen { namespace Security { namespace Cert
32 {
33
34 class _CertSignature
35 {
36 public:
37         _CertSignature(void);
38
39         _CertSignature(const char* pSigAlgId, int len, byte* pValue);
40
41         virtual ~_CertSignature(void);
42
43         void SetSignature(const char* pSigAlgId, int len, byte* pValue);
44
45         result Verify(byte* data, int dataLen, byte* pModulus, int keyLen, byte* pExponent, int expLen);
46
47         byte* GetSignatureInfo(int& sigLen);
48
49         char* GetSignatureAlgo(void);
50
51 private:
52         _CertSignature(const _CertSignature& rhs);
53
54         _CertSignature& operator =(const _CertSignature& rhs);
55
56 private:
57         int __signLen;
58         std::unique_ptr<byte[]> __pSignValue;
59         std::unique_ptr<char[]> __pSignatureAlgId;
60
61 }; //_CertSignature
62
63 } } } //Tizen::Security::Cert
64
65 #endif // _FSEC_CERT_INTERNAL_CERT_SIGNATURE_H_