81 lines
2.1 KiB
C
81 lines
2.1 KiB
C
|
/*
|
||
|
; Project: Open Vehicle Monitor System
|
||
|
; Date: 14th March 2017
|
||
|
;
|
||
|
; Changes:
|
||
|
; 1.0 Initial release
|
||
|
;
|
||
|
; (C) 2011 Michael Stegen / Stegen Electronics
|
||
|
; (C) 2011-2017 Mark Webb-Johnson
|
||
|
; (C) 2011 Sonny Chen @ EPRO/DX
|
||
|
;
|
||
|
; Permission is hereby granted, free of charge, to any person obtaining a copy
|
||
|
; of this software and associated documentation files (the "Software"), to deal
|
||
|
; in the Software without restriction, including without limitation the rights
|
||
|
; to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||
|
; copies of the Software, and to permit persons to whom the Software is
|
||
|
; furnished to do so, subject to the following conditions:
|
||
|
;
|
||
|
; The above copyright notice and this permission notice shall be included in
|
||
|
; all copies or substantial portions of the Software.
|
||
|
;
|
||
|
; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
|
; IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
|
; FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||
|
; AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||
|
; LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||
|
; OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||
|
; THE SOFTWARE.
|
||
|
*/
|
||
|
|
||
|
#ifndef __OVMS_TLS_H__
|
||
|
#define __OVMS_TLS_H__
|
||
|
|
||
|
#include <string>
|
||
|
#include <map>
|
||
|
|
||
|
struct mbedtls_x509_crt;
|
||
|
|
||
|
class OvmsTrustedCert
|
||
|
{
|
||
|
public:
|
||
|
OvmsTrustedCert(const unsigned char* cert, size_t length);
|
||
|
~OvmsTrustedCert();
|
||
|
|
||
|
public:
|
||
|
mbedtls_x509_crt* GetCert();
|
||
|
|
||
|
private:
|
||
|
mbedtls_x509_crt* m_cert;
|
||
|
};
|
||
|
|
||
|
typedef std::map<std::string, OvmsTrustedCert*> TrustedCert_t;
|
||
|
|
||
|
class OvmsTLS
|
||
|
{
|
||
|
public:
|
||
|
OvmsTLS();
|
||
|
~OvmsTLS();
|
||
|
|
||
|
public:
|
||
|
char* GetTrustedList();
|
||
|
int Count();
|
||
|
void Clear();
|
||
|
void Reload();
|
||
|
|
||
|
protected:
|
||
|
void BuildTrustedRaw();
|
||
|
void ClearTrustedRaw();
|
||
|
void UpdatedConfig(std::string event, void* data);
|
||
|
|
||
|
public:
|
||
|
TrustedCert_t m_trustlist;
|
||
|
|
||
|
protected:
|
||
|
char* m_trustedcache;
|
||
|
};
|
||
|
|
||
|
extern OvmsTLS MyOvmsTLS;
|
||
|
|
||
|
#endif //#ifndef __OVMS_TLS_H__
|