2018-06-20 23:44:47 +08:00
|
|
|
#include <atomic>
|
|
|
|
|
|
|
|
#include <gflags/gflags.h>
|
|
|
|
#include <glog/logging.h>
|
|
|
|
|
|
|
|
#include "communication/client.hpp"
|
|
|
|
#include "communication/server.hpp"
|
|
|
|
#include "utils/exceptions.hpp"
|
|
|
|
|
|
|
|
DEFINE_string(server_cert_file, "", "Server certificate file to use.");
|
|
|
|
DEFINE_string(server_key_file, "", "Server key file to use.");
|
|
|
|
DEFINE_string(server_ca_file, "", "Server CA file to use.");
|
|
|
|
DEFINE_bool(server_verify_peer, false, "Set to true to verify the peer.");
|
|
|
|
|
|
|
|
DEFINE_string(client_cert_file, "", "Client certificate file to use.");
|
|
|
|
DEFINE_string(client_key_file, "", "Client key file to use.");
|
|
|
|
|
|
|
|
const std::string message = "ssl echo test";
|
|
|
|
|
|
|
|
struct EchoData {};
|
|
|
|
|
|
|
|
class EchoSession {
|
|
|
|
public:
|
2018-09-03 21:29:06 +08:00
|
|
|
EchoSession(EchoData *, const io::network::Endpoint &,
|
|
|
|
communication::InputStream *input_stream,
|
|
|
|
communication::OutputStream *output_stream)
|
2018-06-20 23:44:47 +08:00
|
|
|
: input_stream_(input_stream), output_stream_(output_stream) {}
|
|
|
|
|
|
|
|
void Execute() {
|
2018-09-03 21:29:06 +08:00
|
|
|
if (input_stream_->size() < message.size()) return;
|
2018-06-20 23:44:47 +08:00
|
|
|
LOG(INFO) << "Server received message.";
|
2018-09-03 21:29:06 +08:00
|
|
|
if (!output_stream_->Write(input_stream_->data(), message.size())) {
|
2018-06-20 23:44:47 +08:00
|
|
|
throw utils::BasicException("Output stream write failed!");
|
|
|
|
}
|
|
|
|
LOG(INFO) << "Server sent message.";
|
2018-09-03 21:29:06 +08:00
|
|
|
input_stream_->Shift(message.size());
|
2018-06-20 23:44:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2018-09-03 21:29:06 +08:00
|
|
|
communication::InputStream *input_stream_;
|
|
|
|
communication::OutputStream *output_stream_;
|
2018-06-20 23:44:47 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
gflags::ParseCommandLineFlags(&argc, &argv, true);
|
|
|
|
google::InitGoogleLogging(argv[0]);
|
|
|
|
|
|
|
|
// Initialize the communication stack.
|
|
|
|
communication::Init();
|
|
|
|
|
|
|
|
// Initialize the server.
|
|
|
|
EchoData echo_data;
|
|
|
|
communication::ServerContext server_context(
|
|
|
|
FLAGS_server_key_file, FLAGS_server_cert_file, FLAGS_server_ca_file,
|
|
|
|
FLAGS_server_verify_peer);
|
|
|
|
communication::Server<EchoSession, EchoData> server(
|
2018-09-03 21:29:06 +08:00
|
|
|
{"127.0.0.1", 0}, &echo_data, &server_context, -1, "SSL", 1);
|
2018-10-16 16:58:41 +08:00
|
|
|
server.Start();
|
2018-06-20 23:44:47 +08:00
|
|
|
|
|
|
|
// Initialize the client.
|
|
|
|
communication::ClientContext client_context(FLAGS_client_key_file,
|
|
|
|
FLAGS_client_cert_file);
|
|
|
|
communication::Client client(&client_context);
|
|
|
|
|
|
|
|
// Connect to the server.
|
|
|
|
CHECK(client.Connect(server.endpoint())) << "Couldn't connect to server!";
|
|
|
|
|
|
|
|
// Perform echo.
|
|
|
|
CHECK(client.Write(message)) << "Client couldn't send message!";
|
|
|
|
LOG(INFO) << "Client sent message.";
|
|
|
|
CHECK(client.Read(message.size())) << "Client couldn't receive message!";
|
|
|
|
LOG(INFO) << "Client received message.";
|
|
|
|
CHECK(std::string(reinterpret_cast<const char *>(client.GetData()),
|
|
|
|
message.size()) == message)
|
|
|
|
<< "Received message isn't equal to sent message!";
|
|
|
|
|
2018-09-27 21:07:46 +08:00
|
|
|
// Shutdown the server.
|
|
|
|
server.Shutdown();
|
|
|
|
server.AwaitShutdown();
|
|
|
|
|
2018-06-20 23:44:47 +08:00
|
|
|
return 0;
|
|
|
|
}
|