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