2017-01-23 01:08:16 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 Denys Vlasenko
|
|
|
|
*
|
|
|
|
* Licensed under GPLv2, see file LICENSE in this source tree.
|
|
|
|
*/
|
|
|
|
//config:config SSL_CLIENT
|
2017-07-18 22:01:24 +02:00
|
|
|
//config: bool "ssl_client (23 kb)"
|
2017-01-23 01:08:16 +01:00
|
|
|
//config: default y
|
|
|
|
//config: select TLS
|
|
|
|
//config: help
|
2017-07-21 09:50:55 +02:00
|
|
|
//config: This tool pipes data to/from a socket, TLS-encrypting it.
|
2017-01-23 01:08:16 +01:00
|
|
|
|
|
|
|
//applet:IF_SSL_CLIENT(APPLET(ssl_client, BB_DIR_USR_BIN, BB_SUID_DROP))
|
|
|
|
|
|
|
|
//kbuild:lib-$(CONFIG_SSL_CLIENT) += ssl_client.o
|
|
|
|
|
|
|
|
//usage:#define ssl_client_trivial_usage
|
|
|
|
//usage: "-s FD [-r FD] [-n SNI]"
|
|
|
|
//usage:#define ssl_client_full_usage ""
|
|
|
|
|
|
|
|
#include "libbb.h"
|
|
|
|
|
|
|
|
int ssl_client_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
|
|
|
|
int ssl_client_main(int argc UNUSED_PARAM, char **argv)
|
|
|
|
{
|
|
|
|
tls_state_t *tls;
|
|
|
|
const char *sni = NULL;
|
|
|
|
int opt;
|
|
|
|
|
|
|
|
// INIT_G();
|
|
|
|
|
|
|
|
tls = new_tls_state();
|
|
|
|
opt = getopt32(argv, "s:#r:#n:", &tls->ofd, &tls->ifd, &sni);
|
|
|
|
if (!(opt & 2)) {
|
|
|
|
/* -r N defaults to -s N */
|
|
|
|
tls->ifd = tls->ofd;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(opt & 3)) {
|
|
|
|
if (!argv[1])
|
|
|
|
bb_show_usage();
|
|
|
|
/* Undocumented debug feature: without -s and -r, takes HOST arg and connects to it */
|
|
|
|
//
|
|
|
|
// Talk to kernel.org:
|
|
|
|
// printf "GET / HTTP/1.1\r\nHost: kernel.org\r\n\r\n" | ./busybox ssl_client kernel.org
|
|
|
|
if (!sni)
|
|
|
|
sni = argv[1];
|
|
|
|
tls->ifd = tls->ofd = create_and_connect_stream_or_die(argv[1], 443);
|
|
|
|
}
|
|
|
|
|
|
|
|
tls_handshake(tls, sni);
|
|
|
|
tls_run_copy_loop(tls);
|
|
|
|
|
|
|
|
return EXIT_SUCCESS;
|
|
|
|
}
|