blob: 7d45d1c7070ff6ab5989c053e1b9216413a6aa38 [file] [log] [blame]
/* Copyright (c) 2014, Google Inc.
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
* SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */
#ifndef OPENSSL_HEADER_TOOL_TRANSPORT_COMMON_H
#define OPENSSL_HEADER_TOOL_TRANSPORT_COMMON_H
#include <openssl/ssl.h>
#include <string.h>
#include <string>
// InitSocketLibrary calls the Windows socket init functions, if needed.
bool InitSocketLibrary();
// Connect sets |*out_sock| to be a socket connected to the destination given
// in |hostname_and_port|, which should be of the form "www.example.com:123".
// It returns true on success and false otherwise.
bool Connect(int *out_sock, const std::string &hostname_and_port);
class Listener {
public:
Listener() {}
~Listener();
// Init initializes the listener to listen on |port|, which should be of the
// form "123".
bool Init(const std::string &port);
// Accept sets |*out_sock| to be a socket connected to the listener.
bool Accept(int *out_sock);
private:
int server_sock_ = -1;
Listener(const Listener &) = delete;
Listener &operator=(const Listener &) = delete;
};
bool VersionFromString(uint16_t *out_version, const std::string &version);
void PrintConnectionInfo(BIO *bio, const SSL *ssl);
bool SocketSetNonBlocking(int sock, bool is_non_blocking);
// PrintSSLError prints information about the most recent SSL error to stderr.
// |ssl_err| must be the output of |SSL_get_error| and the |SSL| object must be
// connected to socket from |Connect|.
void PrintSSLError(FILE *file, const char *msg, int ssl_err, int ret);
bool TransferData(SSL *ssl, int sock);
// DoSMTPStartTLS performs the SMTP STARTTLS mini-protocol over |sock|. It
// returns true on success and false otherwise.
bool DoSMTPStartTLS(int sock);
// DoHTTPTunnel sends an HTTP CONNECT request over |sock|. It returns true on
// success and false otherwise.
bool DoHTTPTunnel(int sock, const std::string &hostname_and_port);
#endif // !OPENSSL_HEADER_TOOL_TRANSPORT_COMMON_H