1*1c60b9acSAndroid Build Coastguard Worker /*
2*1c60b9acSAndroid Build Coastguard Worker  * lws-minimal-http-server-tls-80
3*1c60b9acSAndroid Build Coastguard Worker  *
4*1c60b9acSAndroid Build Coastguard Worker  * Written in 2010-2019 by Andy Green <[email protected]>
5*1c60b9acSAndroid Build Coastguard Worker  *
6*1c60b9acSAndroid Build Coastguard Worker  * This file is made available under the Creative Commons CC0 1.0
7*1c60b9acSAndroid Build Coastguard Worker  * Universal Public Domain Dedication.
8*1c60b9acSAndroid Build Coastguard Worker  *
9*1c60b9acSAndroid Build Coastguard Worker  * This demonstrates the most minimal http server you can make with lws,
10*1c60b9acSAndroid Build Coastguard Worker  * with three extra lines giving it tls (ssl) capabilities, which in
11*1c60b9acSAndroid Build Coastguard Worker  * turn allow operation with HTTP/2 if lws was configured for it.
12*1c60b9acSAndroid Build Coastguard Worker  *
13*1c60b9acSAndroid Build Coastguard Worker  * In addition, it runs a vhost on port 80 with the job of redirecting
14*1c60b9acSAndroid Build Coastguard Worker  * and upgrading http clients that came in on port 80 to https on port 443.
15*1c60b9acSAndroid Build Coastguard Worker  *
16*1c60b9acSAndroid Build Coastguard Worker  * To keep it simple, it serves stuff from the subdirectory
17*1c60b9acSAndroid Build Coastguard Worker  * "./mount-origin" of the directory it was started in.
18*1c60b9acSAndroid Build Coastguard Worker  *
19*1c60b9acSAndroid Build Coastguard Worker  * You can change that by changing mount.origin below.
20*1c60b9acSAndroid Build Coastguard Worker  */
21*1c60b9acSAndroid Build Coastguard Worker 
22*1c60b9acSAndroid Build Coastguard Worker #include <libwebsockets.h>
23*1c60b9acSAndroid Build Coastguard Worker #include <string.h>
24*1c60b9acSAndroid Build Coastguard Worker #include <signal.h>
25*1c60b9acSAndroid Build Coastguard Worker 
26*1c60b9acSAndroid Build Coastguard Worker static int interrupted;
27*1c60b9acSAndroid Build Coastguard Worker 
28*1c60b9acSAndroid Build Coastguard Worker static const struct lws_http_mount mount80 = {
29*1c60b9acSAndroid Build Coastguard Worker 	/* .mount_next */		NULL,		/* linked-list "next" */
30*1c60b9acSAndroid Build Coastguard Worker 	/* .mountpoint */		"/",		/* mountpoint URL */
31*1c60b9acSAndroid Build Coastguard Worker 	/* .origin */			"localhost/",
32*1c60b9acSAndroid Build Coastguard Worker 	/* .def */			"/",	/* default filename */
33*1c60b9acSAndroid Build Coastguard Worker 	/* .protocol */			NULL,
34*1c60b9acSAndroid Build Coastguard Worker 	/* .cgienv */			NULL,
35*1c60b9acSAndroid Build Coastguard Worker 	/* .extra_mimetypes */		NULL,
36*1c60b9acSAndroid Build Coastguard Worker 	/* .interpret */		NULL,
37*1c60b9acSAndroid Build Coastguard Worker 	/* .cgi_timeout */		0,
38*1c60b9acSAndroid Build Coastguard Worker 	/* .cache_max_age */		0,
39*1c60b9acSAndroid Build Coastguard Worker 	/* .auth_mask */		0,
40*1c60b9acSAndroid Build Coastguard Worker 	/* .cache_reusable */		0,
41*1c60b9acSAndroid Build Coastguard Worker 	/* .cache_revalidate */		0,
42*1c60b9acSAndroid Build Coastguard Worker 	/* .cache_intermediaries */	0,
43*1c60b9acSAndroid Build Coastguard Worker 	/* .origin_protocol */		LWSMPRO_REDIR_HTTPS, /* https redir */
44*1c60b9acSAndroid Build Coastguard Worker 	/* .mountpoint_len */		1,		/* char count */
45*1c60b9acSAndroid Build Coastguard Worker 	/* .basic_auth_login_file */	NULL,
46*1c60b9acSAndroid Build Coastguard Worker };
47*1c60b9acSAndroid Build Coastguard Worker 
48*1c60b9acSAndroid Build Coastguard Worker static const struct lws_http_mount mount = {
49*1c60b9acSAndroid Build Coastguard Worker 	/* .mount_next */		NULL,		/* linked-list "next" */
50*1c60b9acSAndroid Build Coastguard Worker 	/* .mountpoint */		"/",		/* mountpoint URL */
51*1c60b9acSAndroid Build Coastguard Worker 	/* .origin */			"./mount-origin", /* serve from dir */
52*1c60b9acSAndroid Build Coastguard Worker 	/* .def */			"index.html",	/* default filename */
53*1c60b9acSAndroid Build Coastguard Worker 	/* .protocol */			NULL,
54*1c60b9acSAndroid Build Coastguard Worker 	/* .cgienv */			NULL,
55*1c60b9acSAndroid Build Coastguard Worker 	/* .extra_mimetypes */		NULL,
56*1c60b9acSAndroid Build Coastguard Worker 	/* .interpret */		NULL,
57*1c60b9acSAndroid Build Coastguard Worker 	/* .cgi_timeout */		0,
58*1c60b9acSAndroid Build Coastguard Worker 	/* .cache_max_age */		0,
59*1c60b9acSAndroid Build Coastguard Worker 	/* .auth_mask */		0,
60*1c60b9acSAndroid Build Coastguard Worker 	/* .cache_reusable */		0,
61*1c60b9acSAndroid Build Coastguard Worker 	/* .cache_revalidate */		0,
62*1c60b9acSAndroid Build Coastguard Worker 	/* .cache_intermediaries */	0,
63*1c60b9acSAndroid Build Coastguard Worker 	/* .origin_protocol */		LWSMPRO_FILE,	/* files in a dir */
64*1c60b9acSAndroid Build Coastguard Worker 	/* .mountpoint_len */		1,		/* char count */
65*1c60b9acSAndroid Build Coastguard Worker 	/* .basic_auth_login_file */	NULL,
66*1c60b9acSAndroid Build Coastguard Worker };
67*1c60b9acSAndroid Build Coastguard Worker 
sigint_handler(int sig)68*1c60b9acSAndroid Build Coastguard Worker void sigint_handler(int sig)
69*1c60b9acSAndroid Build Coastguard Worker {
70*1c60b9acSAndroid Build Coastguard Worker 	interrupted = 1;
71*1c60b9acSAndroid Build Coastguard Worker }
72*1c60b9acSAndroid Build Coastguard Worker 
main(int argc,const char ** argv)73*1c60b9acSAndroid Build Coastguard Worker int main(int argc, const char **argv)
74*1c60b9acSAndroid Build Coastguard Worker {
75*1c60b9acSAndroid Build Coastguard Worker 	struct lws_context_creation_info info;
76*1c60b9acSAndroid Build Coastguard Worker 	struct lws_context *context;
77*1c60b9acSAndroid Build Coastguard Worker 	const char *p;
78*1c60b9acSAndroid Build Coastguard Worker 	int n = 0, logs = LLL_USER | LLL_ERR | LLL_WARN | LLL_NOTICE
79*1c60b9acSAndroid Build Coastguard Worker 			/* for LLL_ verbosity above NOTICE to be built into lws,
80*1c60b9acSAndroid Build Coastguard Worker 			 * lws must have been configured and built with
81*1c60b9acSAndroid Build Coastguard Worker 			 * -DCMAKE_BUILD_TYPE=DEBUG instead of =RELEASE */
82*1c60b9acSAndroid Build Coastguard Worker 			/* | LLL_INFO */ /* | LLL_PARSER */ /* | LLL_HEADER */
83*1c60b9acSAndroid Build Coastguard Worker 			/* | LLL_EXT */ /* | LLL_CLIENT */ /* | LLL_LATENCY */
84*1c60b9acSAndroid Build Coastguard Worker 			/* | LLL_DEBUG */;
85*1c60b9acSAndroid Build Coastguard Worker 
86*1c60b9acSAndroid Build Coastguard Worker 	if ((p = lws_cmdline_option(argc, argv, "-d")))
87*1c60b9acSAndroid Build Coastguard Worker 		logs = atoi(p);
88*1c60b9acSAndroid Build Coastguard Worker 
89*1c60b9acSAndroid Build Coastguard Worker 	lws_set_log_level(logs, NULL);
90*1c60b9acSAndroid Build Coastguard Worker 	lwsl_user("LWS minimal http server TLS + 80 | visit https://localhost\n");
91*1c60b9acSAndroid Build Coastguard Worker 	lwsl_user(" Run as ROOT so can listen on 443\n");
92*1c60b9acSAndroid Build Coastguard Worker 
93*1c60b9acSAndroid Build Coastguard Worker 	signal(SIGINT, sigint_handler);
94*1c60b9acSAndroid Build Coastguard Worker 
95*1c60b9acSAndroid Build Coastguard Worker 	memset(&info, 0, sizeof info); /* otherwise uninitialized garbage */
96*1c60b9acSAndroid Build Coastguard Worker 
97*1c60b9acSAndroid Build Coastguard Worker 	info.options = LWS_SERVER_OPTION_DO_SSL_GLOBAL_INIT |
98*1c60b9acSAndroid Build Coastguard Worker 		       LWS_SERVER_OPTION_EXPLICIT_VHOSTS |
99*1c60b9acSAndroid Build Coastguard Worker 		LWS_SERVER_OPTION_HTTP_HEADERS_SECURITY_BEST_PRACTICES_ENFORCE;
100*1c60b9acSAndroid Build Coastguard Worker 
101*1c60b9acSAndroid Build Coastguard Worker 	context = lws_create_context(&info);
102*1c60b9acSAndroid Build Coastguard Worker 	if (!context) {
103*1c60b9acSAndroid Build Coastguard Worker 		lwsl_err("lws init failed\n");
104*1c60b9acSAndroid Build Coastguard Worker 		return 1;
105*1c60b9acSAndroid Build Coastguard Worker 	}
106*1c60b9acSAndroid Build Coastguard Worker 
107*1c60b9acSAndroid Build Coastguard Worker 
108*1c60b9acSAndroid Build Coastguard Worker 	info.port = 80;
109*1c60b9acSAndroid Build Coastguard Worker 	info.mounts = &mount80;
110*1c60b9acSAndroid Build Coastguard Worker 	info.vhost_name = "localhost80";
111*1c60b9acSAndroid Build Coastguard Worker 
112*1c60b9acSAndroid Build Coastguard Worker 	if (!lws_create_vhost(context, &info)) {
113*1c60b9acSAndroid Build Coastguard Worker 		lwsl_err("Failed to create tls vhost\n");
114*1c60b9acSAndroid Build Coastguard Worker 		goto bail;
115*1c60b9acSAndroid Build Coastguard Worker 	}
116*1c60b9acSAndroid Build Coastguard Worker 
117*1c60b9acSAndroid Build Coastguard Worker 	info.port = 443;
118*1c60b9acSAndroid Build Coastguard Worker 	info.mounts = &mount;
119*1c60b9acSAndroid Build Coastguard Worker 	info.error_document_404 = "/404.html";
120*1c60b9acSAndroid Build Coastguard Worker 	info.ssl_cert_filepath = "localhost-100y.cert";
121*1c60b9acSAndroid Build Coastguard Worker 	info.ssl_private_key_filepath = "localhost-100y.key";
122*1c60b9acSAndroid Build Coastguard Worker 	info.vhost_name = "localhost";
123*1c60b9acSAndroid Build Coastguard Worker 
124*1c60b9acSAndroid Build Coastguard Worker 	if (!lws_create_vhost(context, &info)) {
125*1c60b9acSAndroid Build Coastguard Worker 		lwsl_err("Failed to create tls vhost\n");
126*1c60b9acSAndroid Build Coastguard Worker 		goto bail;
127*1c60b9acSAndroid Build Coastguard Worker 	}
128*1c60b9acSAndroid Build Coastguard Worker 
129*1c60b9acSAndroid Build Coastguard Worker 	while (n >= 0 && !interrupted)
130*1c60b9acSAndroid Build Coastguard Worker 		n = lws_service(context, 0);
131*1c60b9acSAndroid Build Coastguard Worker 
132*1c60b9acSAndroid Build Coastguard Worker bail:
133*1c60b9acSAndroid Build Coastguard Worker 	lws_context_destroy(context);
134*1c60b9acSAndroid Build Coastguard Worker 
135*1c60b9acSAndroid Build Coastguard Worker 	return 0;
136*1c60b9acSAndroid Build Coastguard Worker }
137