blob: d28d3f38806e8bd22a700410a3c7bda45e464bc7 [file] [log] [blame]
// 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();
};