2018-04-20 01:11:55 +08:00
|
|
|
/*
|
|
|
|
* FDBLibTLSSession.h
|
|
|
|
*
|
|
|
|
* This source file is part of the FoundationDB open source project
|
|
|
|
*
|
|
|
|
* Copyright 2013-2018 Apple Inc. and the FoundationDB project 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
|
|
|
|
*
|
|
|
|
* http://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.
|
|
|
|
*/
|
2018-04-13 03:28:52 +08:00
|
|
|
|
|
|
|
#ifndef FDB_LIBTLS_SESSION_H
|
|
|
|
#define FDB_LIBTLS_SESSION_H
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2018-10-20 09:53:09 +08:00
|
|
|
#include "fdbrpc/ITLSPlugin.h"
|
2019-05-21 06:12:28 +08:00
|
|
|
#include "flow/FastRef.h"
|
2018-04-13 03:28:52 +08:00
|
|
|
|
2018-10-20 09:53:09 +08:00
|
|
|
#include "FDBLibTLS/FDBLibTLSPolicy.h"
|
|
|
|
#include "FDBLibTLS/FDBLibTLSVerify.h"
|
|
|
|
#include "flow/IRandom.h"
|
2018-04-13 03:28:52 +08:00
|
|
|
|
|
|
|
#include <tls.h>
|
|
|
|
|
|
|
|
struct FDBLibTLSSession : ITLSSession, ReferenceCounted<FDBLibTLSSession> {
|
2021-03-11 02:06:03 +08:00
|
|
|
FDBLibTLSSession(Reference<FDBLibTLSPolicy> policy,
|
|
|
|
bool is_client,
|
|
|
|
const char* servername,
|
|
|
|
TLSSendCallbackFunc send_func,
|
|
|
|
void* send_ctx,
|
|
|
|
TLSRecvCallbackFunc recv_func,
|
|
|
|
void* recv_ctx,
|
|
|
|
void* uid);
|
2018-04-13 03:28:52 +08:00
|
|
|
virtual ~FDBLibTLSSession();
|
|
|
|
|
|
|
|
virtual void addref() { ReferenceCounted<FDBLibTLSSession>::addref(); }
|
|
|
|
virtual void delref() { ReferenceCounted<FDBLibTLSSession>::delref(); }
|
|
|
|
|
2018-05-09 07:27:21 +08:00
|
|
|
bool verify_peer();
|
2021-03-11 02:06:03 +08:00
|
|
|
std::tuple<bool, std::string> check_verify(Reference<FDBLibTLSVerify> verify, struct stack_st_X509* certs);
|
2018-04-13 03:28:52 +08:00
|
|
|
|
|
|
|
virtual int handshake();
|
|
|
|
virtual int read(uint8_t* data, int length);
|
|
|
|
virtual int write(const uint8_t* data, int length);
|
|
|
|
|
|
|
|
Reference<FDBLibTLSPolicy> policy;
|
|
|
|
|
2018-05-09 07:27:21 +08:00
|
|
|
bool is_client;
|
|
|
|
|
2021-03-11 02:06:03 +08:00
|
|
|
struct tls* tls_ctx;
|
|
|
|
struct tls* tls_sctx;
|
2018-04-13 03:28:52 +08:00
|
|
|
|
|
|
|
TLSSendCallbackFunc send_func;
|
|
|
|
void* send_ctx;
|
|
|
|
TLSRecvCallbackFunc recv_func;
|
|
|
|
void* recv_ctx;
|
|
|
|
|
|
|
|
bool handshake_completed;
|
|
|
|
|
2018-07-13 04:24:40 +08:00
|
|
|
UID uid;
|
2019-05-21 06:12:28 +08:00
|
|
|
double lastVerifyFailureLogged;
|
2018-04-13 03:28:52 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* FDB_LIBTLS_SESSION_H */
|