| // Copyright 2021 The Pigweed Authors |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); you may not |
| // use this file except in compliance with the License. You may obtain a copy of |
| // the License at |
| // |
| // https://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| // License for the specific language governing permissions and limitations under |
| // the License. |
| |
| #pragma once |
| |
| #include "backend_interface.h" |
| #include "mbedtls/certs.h" |
| #include "mbedtls/ctr_drbg.h" |
| #include "mbedtls/debug.h" |
| #include "mbedtls/entropy.h" |
| #include "mbedtls/error.h" |
| #include "mbedtls/ssl.h" |
| |
| class MbedtlsBackend final : public TlsInterface { |
| public: |
| MbedtlsBackend(); |
| const char* Name() override { return "mbedtls"; } |
| int SetHostName(const char* host) override; |
| int Handshake(TransportInterface* transport) override; |
| int Write(const void* buffer, |
| size_t size, |
| TransportInterface* transport) override; |
| int Read(void* buffer, size_t size, TransportInterface* transport) override; |
| int LoadCACert(const void* buffer, |
| size_t size, |
| X509LoadFormat format) override; |
| int LoadCrl(const void* buffer, size_t size, X509LoadFormat format) override; |
| |
| private: |
| mbedtls_entropy_context entropy_; |
| mbedtls_ctr_drbg_context ctr_drbg_; |
| mbedtls_ssl_context ssl_; |
| mbedtls_ssl_config conf_; |
| mbedtls_x509_crt cacert_; |
| mbedtls_x509_crl cacrl_; |
| TransportInterface* mbedtls_io_ctx_ = nullptr; |
| |
| int Setup(); |
| }; |