libwebsockets
Lightweight C library for HTML5 websockets
Loading...
Searching...
No Matches
lws-context-vhost.h
Go to the documentation of this file.
1/*
2 * libwebsockets - small server side websockets and web server implementation
3 *
4 * Copyright (C) 2010 - 2021 Andy Green <andy@warmcat.com>
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to
8 * deal in the Software without restriction, including without limitation the
9 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
22 * IN THE SOFTWARE.
23 */
24
39
40/*
41 * NOTE: These public enums are part of the abi. If you want to add one,
42 * add it at where specified so existing users are unaffected.
43 */
44
45
46#define LWS_SERVER_OPTION_REQUIRE_VALID_OPENSSL_CLIENT_CERT ((1ll << 1) | \
47 (1ll << 12))
48
51#define LWS_SERVER_OPTION_SKIP_SERVER_CANONICAL_NAME (1ll << 2)
53#define LWS_SERVER_OPTION_ALLOW_NON_SSL_ON_SSL_PORT ((1ll << 3) | \
54 (1ll << 12))
55
61#define LWS_SERVER_OPTION_LIBEV (1ll << 4)
63#define LWS_SERVER_OPTION_DISABLE_IPV6 (1ll << 5)
65#define LWS_SERVER_OPTION_DISABLE_OS_CA_CERTS (1ll << 6)
68#define LWS_SERVER_OPTION_PEER_CERT_NOT_REQUIRED (1ll << 7)
70#define LWS_SERVER_OPTION_VALIDATE_UTF8 (1ll << 8)
72#define LWS_SERVER_OPTION_SSL_ECDH ((1ll << 9) | \
73 (1ll << 12))
74
75#define LWS_SERVER_OPTION_LIBUV (1ll << 10)
77#define LWS_SERVER_OPTION_REDIRECT_HTTP_TO_HTTPS ((1ll << 11) |\
78 (1ll << 12))
79
88#define LWS_SERVER_OPTION_DO_SSL_GLOBAL_INIT (1ll << 12)
90#define LWS_SERVER_OPTION_EXPLICIT_VHOSTS (1ll << 13)
93#define LWS_SERVER_OPTION_UNIX_SOCK (1ll << 14)
95#define LWS_SERVER_OPTION_STS (1ll << 15)
98#define LWS_SERVER_OPTION_IPV6_V6ONLY_MODIFY (1ll << 16)
100#define LWS_SERVER_OPTION_IPV6_V6ONLY_VALUE (1ll << 17)
102#define LWS_SERVER_OPTION_UV_NO_SIGSEGV_SIGFPE_SPIN (1ll << 18)
108#define LWS_SERVER_OPTION_JUST_USE_RAW_ORIGIN (1ll << 19)
115#define LWS_SERVER_OPTION_FALLBACK_TO_RAW /* use below name */ (1ll << 20)
116#define LWS_SERVER_OPTION_FALLBACK_TO_APPLY_LISTEN_ACCEPT_CONFIG (1ll << 20)
128
129#define LWS_SERVER_OPTION_LIBEVENT (1ll << 21)
131
132#define LWS_SERVER_OPTION_ONLY_RAW /* Use below name instead */ (1ll << 22)
133#define LWS_SERVER_OPTION_ADOPT_APPLY_LISTEN_ACCEPT_CONFIG (1ll << 22)
146#define LWS_SERVER_OPTION_ALLOW_LISTEN_SHARE (1ll << 23)
152#define LWS_SERVER_OPTION_CREATE_VHOST_SSL_CTX (1ll << 24)
159#define LWS_SERVER_OPTION_SKIP_PROTOCOL_INIT (1ll << 25)
164#define LWS_SERVER_OPTION_IGNORE_MISSING_CERT (1ll << 26)
170#define LWS_SERVER_OPTION_VHOST_UPG_STRICT_HOST_CHECK (1ll << 27)
181#define LWS_SERVER_OPTION_HTTP_HEADERS_SECURITY_BEST_PRACTICES_ENFORCE (1ll << 28)
197
198#define LWS_SERVER_OPTION_ALLOW_HTTP_ON_HTTPS_LISTENER (1ll << 29)
206#define LWS_SERVER_OPTION_FAIL_UPON_UNABLE_TO_BIND (1ll << 30)
210
211#define LWS_SERVER_OPTION_H2_JUST_FIX_WINDOW_UPDATE_OVERFLOW (1ll << 31)
214
215#define LWS_SERVER_OPTION_VH_H2_HALF_CLOSED_LONG_POLL (1ll << 32)
220
221#define LWS_SERVER_OPTION_GLIB (1ll << 33)
223
224#define LWS_SERVER_OPTION_H2_PRIOR_KNOWLEDGE (1ll << 34)
228
229#define LWS_SERVER_OPTION_NO_LWS_SYSTEM_STATES (1ll << 35)
232
233#define LWS_SERVER_OPTION_SS_PROXY (1ll << 36)
235
236#define LWS_SERVER_OPTION_SDEVENT (1ll << 37)
238
239#define LWS_SERVER_OPTION_ULOOP (1ll << 38)
241
242#define LWS_SERVER_OPTION_DISABLE_TLS_SESSION_CACHE (1ll << 39)
244
245#define LWS_SERVER_OPTION_OPENSSL_AUTO_DH_PARAMETERS (1ll << 40)
251
252#define LWS_SERVER_OPTION_MBEDTLS_VERIFY_CLIENT_CERT_POST_HANDSHAKE ((1ll << 41) | \
253 (1ll << 12))
254
261
262#define LWS_SERVER_OPTION_VH_INSTANTIATE_ALL_PROTOCOLS (1ll << 42)
264
265#define LWS_SERVER_OPTION_VH_SKIP_PRIV_DROP (1ll << 43)
268
269#define LWS_SERVER_OPTION_CMDLINE_FORCE_H1 (1ll << 44)
271
272#define LWS_SERVER_OPTION_CMDLINE_FORCE_H2 (1ll << 45)
274
275#define LWS_SERVER_OPTION_CMDLINE_FORCE_H3 (1ll << 46)
277
278#define LWS_SERVER_OPTION_ALLOW_EARLY_DATA (1ll << 47)
280
281#define LWS_SERVER_OPTION_CPD_BYPASS (1ll << 48)
283
284#define LWS_SERVER_OPTION_QUIC_PAD_CRYPTO (1ll << 49)
286
287 /****** add new things just above ---^ ******/
288
289
290#define lws_check_opt(c, f) ((((uint64_t)c) & ((uint64_t)f)) == ((uint64_t)f))
291
292struct lws_plat_file_ops;
293struct lws_ss_policy;
294struct lws_ss_plugin;
295struct lws_metric_policy;
296struct lws_sss_ops;
297
298typedef int (*lws_context_ready_cb_t)(struct lws_context *context);
299
300#if defined(LWS_WITH_NETWORK)
301typedef int (*lws_peer_limits_notify_t)(struct lws_context *ctx,
302 lws_sockfd_type sockfd,
303 lws_sockaddr46 *sa46);
304#endif
305
317typedef uint64_t (*lws_quic_tx_credit_cb_t)(struct lws *wsi, uint64_t current_window,
318 uint64_t consumed_bytes, uint64_t time_since_last_update_us);
319
330#if defined(LWS_WITH_NETWORK)
331 const char *iface;
338 const struct lws_protocols *protocols;
344#if defined(LWS_ROLE_WS)
345 const struct lws_extension *extensions;
348#endif
349#if defined(LWS_ROLE_H1) || defined(LWS_ROLE_H2) || defined(LWS_ROLE_H3)
350 const struct lws_token_limits *token_limits;
353 const char *http_proxy_address;
357 const struct lws_protocol_vhost_options *headers;
360
361 const struct lws_protocol_vhost_options *reject_service_keywords;
368#endif
369 const struct lws_protocol_vhost_options *pvo;
372 const char *log_filepath;
375#if defined(LWS_ROLE_H1) || defined(LWS_ROLE_H2) || defined(LWS_ROLE_H3)
376 const struct lws_http_mount *mounts;
378 const char *server_string;
381
382 const char *error_document_404;
386#endif
387 int port;
399
400#if defined(LWS_ROLE_H1) || defined(LWS_ROLE_H2) || defined(LWS_ROLE_H3)
401 unsigned int http_proxy_port;
403 unsigned int max_http_header_data2;
408 unsigned int max_http_header_pool2;
413#endif
414
415 int keepalive_timeout;
419#if defined(LWS_ROLE_H1) || defined(LWS_ROLE_H2) || defined(LWS_ROLE_H3)
420 uint32_t http2_settings[7];
426
427 unsigned short max_http_header_data;
430 unsigned short max_http_header_pool;
437
438#endif
439
440#if defined(LWS_WITH_TLS)
441 const char *ssl_private_key_password;
446 const char *ssl_cert_filepath;
458 const char *ssl_private_key_filepath;
477 const char *ssl_ca_filepath;
486 const char *ssl_cipher_list;
502 const char *tls_ciphers_iana;
508 const char *ecdh_curve;
511 const char *tls1_3_plus_cipher_list;
521
522 const void *server_ssl_cert_mem;
526 const void *server_ssl_private_key_mem;
531 const void *server_ssl_ca_mem;
535
536 long ssl_options_set;
538 long ssl_options_clear;
540 int simultaneous_ssl_restriction;
543 int simultaneous_ssl_handshake_restriction;
545 int ssl_info_event_mask;
551 unsigned int server_ssl_cert_mem_len;
554 unsigned int server_ssl_private_key_mem_len;
556 unsigned int server_ssl_ca_mem_len;
558
559 const char *alpn;
566
567
568#if defined(LWS_WITH_CLIENT)
569 const char *client_ssl_private_key_password;
572 const char *client_ssl_cert_filepath;
575 const void *client_ssl_cert_mem;
578 unsigned int client_ssl_cert_mem_len;
581 const char *client_ssl_private_key_filepath;
587 const void *client_ssl_key_mem;
590 const char *client_ssl_ca_filepath;
592 const void *client_ssl_ca_mem;
595
596 const char *client_ssl_cipher_list;
607 const char *client_tls_ciphers_iana;
613 const char *client_tls_1_3_plus_cipher_list;
622
623 long ssl_client_options_set;
625 long ssl_client_options_clear;
627
628
629 unsigned int client_ssl_ca_mem_len;
632 unsigned int client_ssl_key_mem_len;
635
636#endif
637
638#if !defined(LWS_WITH_MBEDTLS) && !defined(LWS_WITH_BEARSSL) && \
639 !defined(LWS_WITH_OPENHITLS)
640 SSL_CTX *provided_client_ssl_ctx;
645#elif defined(LWS_WITH_MBEDTLS)
646 const char *mbedtls_client_preload_filepath;
656#endif
657#endif
658
659 int ka_time;
662 int ka_probes;
666 int ka_interval;
669 unsigned int timeout_secs;
674 unsigned int connect_timeout_secs;
678 int bind_iface;
689 unsigned int timeout_secs_ah_idle;
692#endif /* WITH_NETWORK */
693
694#if defined(LWS_WITH_TLS_SESSIONS)
695 uint32_t tls_session_timeout;
698 uint32_t tls_session_cache_max;
701#endif
702
703 gid_t gid;
706 uid_t uid;
709 uint64_t options;
711 void *user;
720 unsigned int count_threads;
738 const char *vhost_name;
745#if defined(LWS_WITH_PLUGINS)
746 const char * const *plugin_dirs;
749#endif
757
758
759 unsigned int pt_serv_buf_size;
765#if defined(LWS_WITH_FILE_OPS)
766 const struct lws_plat_file_ops *fops;
773#endif
774
775#if defined(LWS_WITH_SOCKS5)
776 const char *socks_proxy_address;
780 unsigned int socks_proxy_port;
784#endif
785
786#if defined(LWS_HAVE_SYS_CAPABILITY_H) && defined(LWS_HAVE_LIBCAP)
787 cap_value_t caps[4];
794 char count_caps;
797#endif
812 void (*signal_cb)(void *event_lib_handle, int signum);
818 struct lws_context **pcontext;
824 void (*finalize)(struct lws_vhost *vh, void *arg);
842 const struct lws_protocols **pprotocols;
852
853 const char *username;
855 const char *groupname;
857 const char *unix_socket_perms;
868#if defined(LWS_WITH_SYS_STATE)
869 lws_state_notify_link_t * const *register_notifier_list;
873#endif
874#if defined(LWS_WITH_SECURE_STREAMS)
875#if defined(LWS_WITH_SECURE_STREAMS_STATIC_POLICY_ONLY)
876 const struct lws_ss_policy *pss_policies;
878#else
879 const char *pss_policies_json;
886#endif
887 const struct lws_ss_plugin **pss_plugins;
890 const char *ss_proxy_bind;
895 const char *ss_proxy_address;
897 uint16_t ss_proxy_port; /* 0 = if connecting to ss proxy, do it via a
898 * Unix Domain Socket, "+@proxy.ss.lws" if ss_proxy_bind is NULL else
899 * the socket path given in ss_proxy_bind (start it with a + or +@);
900 * nonzero means connect via a tcp socket to the tcp address in
901 * ss_proxy_bind and the given port */
902 const struct lws_transport_proxy_ops *txp_ops_ssproxy;
905 const void *txp_ssproxy_info;
907 const struct lws_transport_client_ops *txp_ops_sspc;
910#endif
911
912#if defined(LWS_WITH_SECURE_STREAMS_PROXY_API)
913#endif
914
919#if defined(LWS_WITH_PEER_LIMITS)
920 lws_peer_limits_notify_t pl_notify_cb;
927 unsigned short ip_limit_ah;
935 unsigned short ip_limit_wsi;
942
943#endif /* PEER_LIMITS */
944
945#if defined(LWS_WITH_SYS_FAULT_INJECTION)
946 lws_fi_ctx_t fic;
953#endif
954
955#if defined(LWS_WITH_SYS_SMD)
956 lws_smd_notification_cb_t early_smd_cb;
963 void *early_smd_opaque;
964 lws_smd_class_t early_smd_class_filter;
965 lws_usec_t smd_ttl_us;
970 uint16_t smd_queue_depth;
973#endif
974
975#if defined(LWS_WITH_SYS_METRICS)
976 const struct lws_metric_policy *metrics_policies;
978 const char *metrics_prefix;
985#endif
986
992
1002
1003#if defined(LWS_WITH_TLS_JIT_TRUST)
1004 size_t jitt_cache_max_footprint;
1007 int vh_idle_grace_ms;
1010#endif
1011
1015
1016#if defined(LWS_WITH_CACHE_NSCOOKIEJAR) && defined(LWS_WITH_CLIENT)
1017 const char *http_nsc_filepath;
1019
1020 size_t http_nsc_heap_max_footprint;
1023 size_t http_nsc_heap_max_items;
1026 size_t http_nsc_heap_max_payload;
1029#endif
1030
1031#if defined(LWS_WITH_SYS_ASYNC_DNS)
1032 const char **async_dns_servers;
1038
1039#endif
1040
1041#if defined(WIN32)
1042 unsigned int win32_connect_check_interval_usec;
1047#endif
1048
1055
1063
1064#if defined(LWS_WITH_NETWORK)
1065 const char *wol_if;
1067#endif
1068
1069 const char *lws_stub;
1073 int argc;
1076 const char **argv;
1079
1080#if defined(LWS_WITH_ASYNC_QUEUE)
1081 uint8_t count_async_threads;
1086#endif
1087
1088 /* Add new things just above here ---^
1089 * This is part of the ABI, don't needlessly break compatibility
1090 *
1091 * The below is to ensure later library versions with new
1092 * members added above will see 0 (default) even if the app
1093 * was not built against the newer headers.
1094 */
1095
1098
1101
1104
1105 void *_unused[1];
1106};
1107
1142LWS_VISIBLE LWS_EXTERN struct lws_context *
1144
1145
1155lws_context_destroy(struct lws_context *context);
1156
1168
1169typedef int (*lws_reload_func)(void);
1170
1194lws_context_deprecate(struct lws_context *context, lws_reload_func cb);
1195
1197lws_context_is_deprecated(struct lws_context *context);
1198
1217lws_set_proxy(struct lws_vhost *vhost, const char *proxy);
1218
1237lws_set_socks(struct lws_vhost *vhost, const char *socks);
1238
1239struct lws_vhost;
1240
1250LWS_VISIBLE LWS_EXTERN struct lws_vhost *
1251lws_create_vhost(struct lws_context *context,
1252 const struct lws_context_creation_info *info);
1253
1273lws_vhost_destroy(struct lws_vhost *vh);
1274
1291 char **config_strings, int *len);
1292
1309lwsws_get_config_vhosts(struct lws_context *context,
1310 struct lws_context_creation_info *info, const char *d,
1311 char **config_strings, int *len);
1312
1318LWS_VISIBLE LWS_EXTERN struct lws_vhost *
1319lws_get_vhost(struct lws *wsi);
1320
1326LWS_VISIBLE LWS_EXTERN const char *
1327lws_get_vhost_name(struct lws_vhost *vhost);
1328
1337LWS_VISIBLE LWS_EXTERN struct lws_vhost *
1338lws_get_vhost_by_name(struct lws_context *context, const char *name);
1339
1346lws_get_vhost_port(struct lws_vhost *vhost);
1347
1354lws_get_vhost_user(struct lws_vhost *vhost);
1355
1361LWS_VISIBLE LWS_EXTERN const char *
1362lws_get_vhost_iface(struct lws_vhost *vhost);
1363
1373lws_vhost_user(struct lws_vhost *vhost);
1374
1385lws_context_user(struct lws_context *context);
1386
1387LWS_VISIBLE LWS_EXTERN const char *
1388lws_vh_tag(struct lws_vhost *vh);
1389
1392 const char *sspol);
1393
1395lws_default_loop_exit(struct lws_context *cx);
1396
1399
1401lws_cmdline_passfail(int argc, const char **argv, int actual);
1402
1414lws_systemd_inherited_fd(unsigned int index,
1415 struct lws_context_creation_info *info);
1416
1433lws_context_is_being_destroyed(struct lws_context *context);
1434
1441
1453
1468
1477
1479#define AUTH_MODE_MASK 0xF0000000
1480
1488 const char *mountpoint;
1490 const char *origin;
1492 const char *def;
1494 const char *protocol;
1496
1505
1510 unsigned int auth_mask;
1512
1513 unsigned int cache_reusable:1;
1514 unsigned int cache_revalidate:1;
1515 unsigned int cache_intermediaries:1;
1516 unsigned int cache_no:1;
1517 unsigned int exact_match:1;
1518 unsigned int append_path:1;
1519 unsigned int no_ws_upgrades:1;
1520
1521 unsigned char origin_protocol;
1522 unsigned char mountpoint_len;
1523
1526
1527 const char *cgi_chroot_path;
1529
1530 const char *cgi_wd;
1534
1543 unsigned int keepalive_timeout;
1547#if defined(LWS_WITH_JOSE)
1548 const char *interceptor_path;
1552#endif
1553
1554 /* Add new things just above here ---^
1555 * This is part of the ABI, don't needlessly break compatibility
1556 */
1557};
1558
1560lws_vhost_set_mounts(struct lws_vhost *v, const struct lws_http_mount *mounts);
1561
const lws_system_ops_t * system_ops
const struct lws_plugin_evlib * event_lib_custom
void(* finalize)(struct lws_vhost *vh, void *arg)
const struct lws_protocols ** pprotocols
struct lws_context ** pcontext
lws_quic_tx_credit_cb_t quic_tx_credit_cb
const lws_retry_bo_t * retry_and_idle_policy
const struct lws_protocol_vhost_options * next
void(* signal_cb)(void *event_lib_handle, int signum)
const struct lws_cc_ops * quic_cc_ops
const struct lws_protocol_vhost_options * options
LWS_VISIBLE LWS_EXTERN void lws_context_deprecate(struct lws_context *context, lws_reload_func cb)
LWS_VISIBLE LWS_EXTERN void lws_context_default_loop_run_destroy(struct lws_context *cx)
int(* lws_reload_func)(void)
LWS_VISIBLE LWS_EXTERN struct lws_vhost * lws_get_vhost(struct lws *wsi)
LWS_VISIBLE LWS_EXTERN int lwsws_get_config_vhosts(struct lws_context *context, struct lws_context_creation_info *info, const char *d, char **config_strings, int *len)
LWS_VISIBLE LWS_EXTERN struct lws_vhost * lws_create_vhost(struct lws_context *context, const struct lws_context_creation_info *info)
LWS_VISIBLE LWS_EXTERN int lws_cmdline_passfail(int argc, const char **argv, int actual)
LWS_VISIBLE LWS_EXTERN void * lws_vhost_user(struct lws_vhost *vhost)
uint64_t(* lws_quic_tx_credit_cb_t)(struct lws *wsi, uint64_t current_window, uint64_t consumed_bytes, uint64_t time_since_last_update_us)
LWS_VISIBLE LWS_EXTERN int lws_set_proxy(struct lws_vhost *vhost, const char *proxy)
LWS_VISIBLE LWS_EXTERN struct lws_context * lws_create_context(const struct lws_context_creation_info *info)
LWS_VISIBLE LWS_EXTERN void lws_default_loop_exit(struct lws_context *cx)
LWS_VISIBLE LWS_EXTERN void lws_context_destroy(struct lws_context *context)
LWS_VISIBLE LWS_EXTERN int lwsws_get_config_globals(struct lws_context_creation_info *info, const char *d, char **config_strings, int *len)
LWS_VISIBLE LWS_EXTERN void lws_tls_cleanup_process(void)
LWS_VISIBLE LWS_EXTERN int lws_set_socks(struct lws_vhost *vhost, const char *socks)
LWS_VISIBLE LWS_EXTERN const char * lws_vh_tag(struct lws_vhost *vh)
LWS_VISIBLE LWS_EXTERN const char * lws_get_vhost_name(struct lws_vhost *vhost)
LWS_VISIBLE LWS_EXTERN struct lws_vhost * lws_get_vhost_by_name(struct lws_context *context, const char *name)
LWS_VISIBLE LWS_EXTERN int lws_get_vhost_port(struct lws_vhost *vhost)
LWS_VISIBLE LWS_EXTERN void lws_vhost_destroy(struct lws_vhost *vh)
LWS_VISIBLE LWS_EXTERN const char * lws_get_vhost_iface(struct lws_vhost *vhost)
LWS_VISIBLE LWS_EXTERN int lws_systemd_inherited_fd(unsigned int index, struct lws_context_creation_info *info)
LWS_VISIBLE LWS_EXTERN void _lws_context_info_defaults(struct lws_context_creation_info *info, const char *sspol)
LWS_VISIBLE LWS_EXTERN int lws_context_is_deprecated(struct lws_context *context)
LWS_VISIBLE LWS_EXTERN int lws_context_is_being_destroyed(struct lws_context *context)
LWS_VISIBLE LWS_EXTERN void * lws_context_user(struct lws_context *context)
LWS_VISIBLE LWS_EXTERN void * lws_get_vhost_user(struct lws_vhost *vhost)
int(* lws_context_ready_cb_t)(struct lws_context *context)
struct lws_log_cx lws_log_cx_t
const struct lws_http_mount * mount_next
const char * protocol
const struct lws_protocol_vhost_options * interpret
unsigned int keepalive_timeout
unsigned int cache_no
const char * basic_auth_login_file
const struct lws_protocol_vhost_options * extra_mimetypes
unsigned int auth_mask
unsigned char origin_protocol
unsigned int cache_reusable
unsigned int no_ws_upgrades
unsigned int append_path
const char * mountpoint
unsigned int cache_intermediaries
const char * cgi_chroot_path
unsigned char mountpoint_len
const struct lws_protocol_vhost_options * headers
unsigned int exact_match
unsigned int cache_revalidate
const struct lws_protocol_vhost_options * cgienv
lws_mount_protocols
LWS_VISIBLE LWS_EXTERN void lws_vhost_set_mounts(struct lws_vhost *v, const struct lws_http_mount *mounts)
lws_authentication_mode
@ LWSMPRO_NO_MOUNT
@ LWSMPRO_CGI
@ LWSMPRO_HTTP
@ LWSMPRO_FILE
@ LWSMPRO_REDIR_HTTPS
@ LWSMPRO_CALLBACK
@ LWSMPRO_REDIR_HTTP
@ LWSMPRO_HTTPS
@ LWSAUTHM_BASIC_AUTH_CALLBACK
@ LWSAUTHM_DEFAULT
unsigned short uint16_t
unsigned int uint32_t
#define LWS_EXTERN
int64_t lws_usec_t
unsigned char uint8_t
int lws_sockfd_type
#define LWS_VISIBLE
struct lws_retry_bo lws_retry_bo_t
int(* lws_smd_notification_cb_t)(void *opaque, lws_smd_class_t _class, lws_usec_t timestamp, void *buf, size_t len)
Definition lws-smd.h:185
uint32_t lws_smd_class_t
Definition lws-smd.h:31
struct lws_system_ops lws_system_ops_t