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