blob: 0aa5410c6c09a9927e57ce0f7a2a48f983a1cc4b [file] [log] [blame]
Andy Green7c212cc2010-11-08 20:20:42 +00001/*
2 * libwebsockets - small server side websockets and web server implementation
Andy Greene77ddd82010-11-13 10:03:47 +00003 *
Andy Green8c1f6022016-01-26 20:56:56 +08004 * Copyright (C) 2010 - 2016 Andy Green <andy@warmcat.com>
Andy Green7c212cc2010-11-08 20:20:42 +00005 *
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation:
9 * version 2.1 of the License.
10 *
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19 * MA 02110-1301 USA
20 */
Joakim Soderberg91de9332013-02-06 15:30:33 +090021
Joakim Soderberg4c531232013-02-06 15:26:58 +090022#include "lws_config.h"
Roger A. Light7a474b42015-06-26 11:40:54 +020023#include "lws_config_private.h"
Andy Greene40aa9b2014-04-02 21:02:54 +080024
Andy Green6a8099b2016-02-21 21:25:48 +080025
26#if defined(LWS_WITH_CGI) && defined(LWS_HAVE_VFORK)
27#define _GNU_SOURCE
28#endif
29
=?UTF-8?q?Joakim=20S=C3=B6derberg?=cefab312015-06-24 16:46:02 +020030#ifdef LWS_HAVE_SYS_TYPES_H
Andy Greene40aa9b2014-04-02 21:02:54 +080031#include <sys/types.h>
Joakim Soderberg91de9332013-02-06 15:30:33 +090032#endif
Joakim Soderberg4c531232013-02-06 15:26:58 +090033
Andy Green7c212cc2010-11-08 20:20:42 +000034#include <stdio.h>
35#include <stdlib.h>
36#include <string.h>
Patrick Ganstererb13eed42014-03-30 10:19:23 +020037#include <time.h>
Andy Green7c212cc2010-11-08 20:20:42 +000038#include <ctype.h>
Peter Young26757a72013-01-17 10:08:16 +080039#include <limits.h>
Peter Hinz56885f32011-03-02 22:03:47 +000040#include <stdarg.h>
Andy Greenc7c4ae02017-02-18 17:26:40 +080041
42#if defined(LWS_WITH_ESP32)
43#define MSG_NOSIGNAL 0
44#define SOMAXCONN 3
45#endif
46
Andy Green7acf76c2016-07-23 14:18:25 +080047#if defined(LWS_WITH_ESP8266)
48#include <user_interface.h>
49#define assert(n)
50
51/* rom-provided stdc functions for free, ensure use these instead of libc ones */
52
53int ets_vsprintf(char *str, const char *format, va_list argptr);
54int ets_vsnprintf(char *buffer, size_t sizeOfBuffer, const char *format, va_list argptr);
55int ets_snprintf(char *str, size_t size, const char *format, ...);
56int ets_sprintf(char *str, const char *format, ...);
57int os_printf_plus(const char *format, ...);
58#undef malloc
59#undef realloc
60#undef free
61void *pvPortMalloc(size_t s, const char *f, int line);
62#define malloc(s) pvPortMalloc(s, "", 0)
63void *pvPortRealloc(void *p, size_t s, const char *f, int line);
64#define realloc(p, s) pvPortRealloc(p, s, "", 0)
65void vPortFree(void *p, const char *f, int line);
66#define free(p) vPortFree(p, "", 0)
67#undef memcpy
68void *ets_memcpy(void *dest, const void *src, size_t n);
69#define memcpy ets_memcpy
70void *ets_memset(void *dest, int v, size_t n);
71#define memset ets_memset
72char *ets_strcpy(char *dest, const char *src);
73#define strcpy ets_strcpy
74char *ets_strncpy(char *dest, const char *src, size_t n);
75#define strncpy ets_strncpy
76char *ets_strstr(const char *haystack, const char *needle);
77#define strstr ets_strstr
78int ets_strcmp(const char *s1, const char *s2);
79int ets_strncmp(const char *s1, const char *s2, size_t n);
80#define strcmp ets_strcmp
81#define strncmp ets_strncmp
82size_t ets_strlen(const char *s);
83#define strlen ets_strlen
84void *ets_memmove(void *dest, const void *src, size_t n);
85#define memmove ets_memmove
86char *ets_strchr(const char *s, int c);
87#define strchr_ets_strchr
88#undef _DEBUG
89#include <osapi.h>
90
91#else
92#define STORE_IN_ROM
Andy Green112f9802015-12-04 07:22:44 +080093#include <assert.h>
Andy Green7acf76c2016-07-23 14:18:25 +080094#endif
Andy Green8c1f6022016-01-26 20:56:56 +080095#if LWS_MAX_SMP > 1
96#include <pthread.h>
97#endif
Peter Hinz56885f32011-03-02 22:03:47 +000098
=?UTF-8?q?Joakim=20S=C3=B6derberg?=cefab312015-06-24 16:46:02 +020099#ifdef LWS_HAVE_SYS_STAT_H
Peter Hinz56885f32011-03-02 22:03:47 +0000100#include <sys/stat.h>
Patrick Gansterere5720a32014-02-28 00:57:19 +0100101#endif
Peter Hinz56885f32011-03-02 22:03:47 +0000102
Andreas Pakulat68bd4bd2013-10-28 15:18:04 +0100103#if defined(WIN32) || defined(_WIN32)
Stephan Eberleb820e2c2015-10-23 08:10:55 +0200104#if (WINVER < 0x0501)
105#undef WINVER
106#undef _WIN32_WINNT
107#define WINVER 0x0501
108#define _WIN32_WINNT WINVER
109#endif
Joakim Soderberg4c531232013-02-06 15:26:58 +0900110#define LWS_NO_DAEMONIZE
Patrick Gansterer2dbd8372014-02-28 12:37:52 +0100111#define LWS_ERRNO WSAGetLastError()
112#define LWS_EAGAIN WSAEWOULDBLOCK
113#define LWS_EALREADY WSAEALREADY
114#define LWS_EINPROGRESS WSAEINPROGRESS
115#define LWS_EINTR WSAEINTR
116#define LWS_EISCONN WSAEISCONN
117#define LWS_EWOULDBLOCK WSAEWOULDBLOCK
Patrick Gansterer73882e42014-03-29 08:25:58 +0100118#define MSG_NOSIGNAL 0
119#define SHUT_RDWR SD_BOTH
120#define SOL_TCP IPPROTO_TCP
Andy Green8c1f6022016-01-26 20:56:56 +0800121#define SHUT_WR SD_SEND
Joakim Soderberg4c531232013-02-06 15:26:58 +0900122
Andy Green158e8042014-04-02 14:25:10 +0800123#define compatible_close(fd) closesocket(fd)
Andy Greenaa775fd2015-12-26 08:56:58 +0800124#define lws_set_blocking_send(wsi) wsi->sock_send_blocking = 1
Andy Greenc53f7ca2015-11-14 07:35:27 +0800125#define lws_socket_is_valid(x) (!!x)
Andy Green40110e82015-12-14 08:52:03 +0800126#define LWS_SOCK_INVALID 0
Peter Hinz56885f32011-03-02 22:03:47 +0000127#include <winsock2.h>
Andy Greeneee0d8a2015-12-17 15:15:12 +0800128#include <ws2tcpip.h>
Peter Hinz56885f32011-03-02 22:03:47 +0000129#include <windows.h>
Joakim Soderbergd2f5b192014-04-07 11:28:08 +0200130#include <tchar.h>
=?UTF-8?q?Joakim=20S=C3=B6derberg?=cefab312015-06-24 16:46:02 +0200131#ifdef LWS_HAVE_IN6ADDR_H
Andy Green0f58db32014-04-12 11:10:35 +0800132#include <in6addr.h>
133#endif
Joakim Soderbergd2f5b192014-04-07 11:28:08 +0200134#include <mstcpip.h>
Andy Greend6be6772016-05-14 06:49:29 +0800135#include <io.h>
Joakim Soderbergd2f5b192014-04-07 11:28:08 +0200136
WebsocketUser0be9e982017-06-09 20:20:42 +0800137#if !defined(LWS_HAVE_ATOLL)
138#if defined(LWS_HAVE__ATOI64)
139#define atoll _atoi64
140#else
141#warning No atoll or _atoi64 available, using atoi
142#define atoll atoi
143#endif
144#endif
145
Joakim Soderbergd2f5b192014-04-07 11:28:08 +0200146#ifndef __func__
147#define __func__ __FUNCTION__
148#endif
149
Andy Green7d22c292016-03-04 10:53:51 +0800150#ifdef LWS_HAVE__VSNPRINTF
151#define vsnprintf _vsnprintf
152#endif
Patrick Gansterer6bb4b622014-04-15 18:39:26 +0200153
Andy Greenbe9fb912016-12-16 07:37:43 +0800154/* we don't have an implementation for this on windows... */
155int kill(int pid, int sig);
156int fork(void);
157#ifndef SIGINT
158#define SIGINT 2
159#endif
160
Andy Green158e8042014-04-02 14:25:10 +0800161#else /* not windows --> */
Andy Green8c0d3c02015-11-02 20:34:12 +0800162
Patrick Ganstererb13eed42014-03-30 10:19:23 +0200163#include <fcntl.h>
Patrick Ganstererb13eed42014-03-30 10:19:23 +0200164#include <strings.h>
165#include <unistd.h>
Andy Greene77ddd82010-11-13 10:03:47 +0000166#include <sys/types.h>
Andy Green0aed7a02017-02-22 09:50:11 +0800167
Andy Green8c0d3c02015-11-02 20:34:12 +0800168#ifndef __cplusplus
169#include <errno.h>
170#endif
Andy Green5f2a8152015-11-02 08:21:08 +0800171#include <netdb.h>
172#include <signal.h>
Andy Green7acf76c2016-07-23 14:18:25 +0800173#ifdef LWS_WITH_ESP8266
174#include <sockets.h>
175#define vsnprintf ets_vsnprintf
176#define snprintf ets_snprintf
177#define sprintf ets_sprintf
Andy Greendd0dfae2016-12-22 11:32:34 +0800178
179int kill(int pid, int sig);
180
Andy Green7acf76c2016-07-23 14:18:25 +0800181#else
Andy Green7c212cc2010-11-08 20:20:42 +0000182#include <sys/socket.h>
Andy Green7acf76c2016-07-23 14:18:25 +0800183#endif
Andy Green1e5a9ad2016-03-20 11:59:53 +0800184#ifdef LWS_WITH_HTTP_PROXY
185#include <hubbub/hubbub.h>
186#include <hubbub/parser.h>
187#endif
Andy Green7acf76c2016-07-23 14:18:25 +0800188#if defined(LWS_BUILTIN_GETIFADDRS)
Andy Greene40aa9b2014-04-02 21:02:54 +0800189 #include <getifaddrs.h>
190#else
Andy Greenc7c4ae02017-02-18 17:26:40 +0800191 #if !defined(LWS_WITH_ESP8266) && !defined(LWS_WITH_ESP32)
Andy Greene40aa9b2014-04-02 21:02:54 +0800192 #include <ifaddrs.h>
Andy Green7acf76c2016-07-23 14:18:25 +0800193 #endif
Andy Greene40aa9b2014-04-02 21:02:54 +0800194#endif
Dnyanesh Gate759e50c2014-09-26 05:39:05 +0800195#if defined (__ANDROID__)
196#include <syslog.h>
Alexander Bruines119bdaa2016-04-23 11:10:18 +0200197#include <sys/resource.h>
Fredrik Skogman316960b2016-09-09 06:49:44 +0800198#elif defined (__sun)
199#include <syslog.h>
Dnyanesh Gate759e50c2014-09-26 05:39:05 +0800200#else
Andy Greenc7c4ae02017-02-18 17:26:40 +0800201#if !defined(LWS_WITH_ESP8266) && !defined(LWS_WITH_ESP32)
Andy Greene40aa9b2014-04-02 21:02:54 +0800202#include <sys/syslog.h>
Dnyanesh Gate759e50c2014-09-26 05:39:05 +0800203#endif
Andy Green7acf76c2016-07-23 14:18:25 +0800204#endif
Andy Greene40aa9b2014-04-02 21:02:54 +0800205#include <netdb.h>
Andy Greenc7c4ae02017-02-18 17:26:40 +0800206#if !defined(LWS_WITH_ESP8266) && !defined(LWS_WITH_ESP32)
Andy Green7acf76c2016-07-23 14:18:25 +0800207#include <sys/mman.h>
208#include <sys/un.h>
Andy Green7c212cc2010-11-08 20:20:42 +0000209#include <netinet/in.h>
Andy Green6c939552011-03-08 08:56:57 +0000210#include <netinet/tcp.h>
Andy Greenb45993c2010-12-18 15:13:50 +0000211#include <arpa/inet.h>
Andy Green7c212cc2010-11-08 20:20:42 +0000212#include <poll.h>
Andy Green7acf76c2016-07-23 14:18:25 +0800213#endif
Andrew Canaday9769f4f2014-03-23 13:25:07 +0800214#ifdef LWS_USE_LIBEV
Andy Green86ed65f2016-02-14 09:27:41 +0800215#include <ev.h>
216#endif
217#ifdef LWS_USE_LIBUV
Alex Hultmana43c2ac2016-02-01 08:31:54 +0800218#include <uv.h>
Andy Green86ed65f2016-02-14 09:27:41 +0800219#endif
Aditya Tirumalaec50eba2017-03-15 19:41:11 +0530220#ifdef LWS_USE_LIBEVENT
221#include <event2/event.h>
222#endif
Andy Green5f2a8152015-11-02 08:21:08 +0800223
Andy Green5f2a8152015-11-02 08:21:08 +0800224#ifndef LWS_NO_FORK
225#ifdef LWS_HAVE_SYS_PRCTL_H
226#include <sys/prctl.h>
227#endif
228#endif
229
Andy Green038d5822011-02-14 20:58:26 +0000230#include <sys/time.h>
Andy Green7c212cc2010-11-08 20:20:42 +0000231
Patrick Gansterer2dbd8372014-02-28 12:37:52 +0100232#define LWS_ERRNO errno
233#define LWS_EAGAIN EAGAIN
234#define LWS_EALREADY EALREADY
235#define LWS_EINPROGRESS EINPROGRESS
236#define LWS_EINTR EINTR
237#define LWS_EISCONN EISCONN
238#define LWS_EWOULDBLOCK EWOULDBLOCK
Andy Green2b304a92016-07-11 07:28:23 +0800239
Andy Green158e8042014-04-02 14:25:10 +0800240#define lws_set_blocking_send(wsi)
Andy Green2cd30742015-11-02 13:10:33 +0800241
Andy Green0aed7a02017-02-22 09:50:11 +0800242#if defined(LWS_WITH_ESP8266)
Andy Green2cd30742015-11-02 13:10:33 +0800243#define lws_socket_is_valid(x) ((x) != NULL)
244#define LWS_SOCK_INVALID (NULL)
Andy Green7acf76c2016-07-23 14:18:25 +0800245struct lws;
246const char *
247lws_plat_get_peer_simple(struct lws *wsi, char *name, int namelen);
Andy Green2cd30742015-11-02 13:10:33 +0800248#else
Andy Greenc53f7ca2015-11-14 07:35:27 +0800249#define lws_socket_is_valid(x) (x >= 0)
250#define LWS_SOCK_INVALID (-1)
Peter Hinz56885f32011-03-02 22:03:47 +0000251#endif
Andy Green2cd30742015-11-02 13:10:33 +0800252#endif
Peter Hinz56885f32011-03-02 22:03:47 +0000253
=?UTF-8?q?Joakim=20S=C3=B6derberg?=cefab312015-06-24 16:46:02 +0200254#ifndef LWS_HAVE_BZERO
Andy Greene5ea1f92014-11-18 18:25:24 +0800255#ifndef bzero
Patrick Gansterer4a837272014-02-28 13:17:49 +0100256#define bzero(b, len) (memset((b), '\0', (len)), (void) 0)
257#endif
Andy Greene5ea1f92014-11-18 18:25:24 +0800258#endif
Patrick Gansterer4a837272014-02-28 13:17:49 +0100259
=?UTF-8?q?Joakim=20S=C3=B6derberg?=cefab312015-06-24 16:46:02 +0200260#ifndef LWS_HAVE_STRERROR
Patrick Gansterer9d614912014-02-28 00:59:53 +0100261#define strerror(x) ""
262#endif
263
Andy Green7c212cc2010-11-08 20:20:42 +0000264#ifdef LWS_OPENSSL_SUPPORT
Andy Green1a3f1772016-03-28 19:58:02 +0800265
Alexander Bruinesc3bcb892015-08-08 18:54:49 +0200266#ifdef USE_WOLFSSL
ABruines80a70682015-08-09 22:56:32 +0200267#ifdef USE_OLD_CYASSL
268#include <cyassl/openssl/ssl.h>
269#include <cyassl/error-ssl.h>
270#else
Alexander Bruinesc3bcb892015-08-08 18:54:49 +0200271#include <wolfssl/openssl/ssl.h>
272#include <wolfssl/error-ssl.h>
Andy Green1e227192017-01-07 10:24:16 +0800273#define OPENSSL_NO_TLSEXT
ABruines80a70682015-08-09 22:56:32 +0200274#endif /* not USE_OLD_CYASSL */
Andy Green23c5f2e2013-02-06 15:43:00 +0900275#else
Andy Green7c212cc2010-11-08 20:20:42 +0000276#include <openssl/ssl.h>
Andy Green3a09c3b2017-03-08 11:11:41 +0800277#if !defined(LWS_WITH_ESP32)
Andy Green7c212cc2010-11-08 20:20:42 +0000278#include <openssl/evp.h>
279#include <openssl/err.h>
Andy Green70dfebd2010-12-20 09:35:03 +0000280#include <openssl/md5.h>
Andy Greene2522172011-01-18 17:14:03 +0000281#include <openssl/sha.h>
Andy Green1a3f1772016-03-28 19:58:02 +0800282#ifdef LWS_HAVE_OPENSSL_ECDH_H
283#include <openssl/ecdh.h>
284#endif
Andy Greene7bf0aa2016-06-28 19:50:40 +0800285#include <openssl/x509v3.h>
Andy Green3a09c3b2017-03-08 11:11:41 +0800286#endif
Andy Greenc001a152017-01-06 09:49:28 +0800287#if (OPENSSL_VERSION_NUMBER < 0x0009080afL)
288/* later openssl defines this to negate the presence of tlsext... but it was only
289 * introduced at 0.9.8j. Earlier versions don't know it exists so don't
290 * define it... making it look like the feature exists...
291 */
292#define OPENSSL_NO_TLSEXT
293#endif
Alexander Bruinesc3bcb892015-08-08 18:54:49 +0200294#endif /* not USE_WOLFSSL */
Darin Willitsdb9ba422011-02-14 20:56:24 +0000295#endif
296
Andy Green7c212cc2010-11-08 20:20:42 +0000297#include "libwebsockets.h"
Andy Green7acf76c2016-07-23 14:18:25 +0800298#if defined(WIN32) || defined(_WIN32)
299#else
300static inline int compatible_close(int fd) { return close(fd); }
301#endif
Andy Green7c212cc2010-11-08 20:20:42 +0000302
Rainer Poiseld2cef152016-11-07 21:36:05 +0100303#if defined(WIN32) || defined(_WIN32)
304#include <gettimeofday.h>
305#endif
306
Andy Green7acf76c2016-07-23 14:18:25 +0800307#if defined(LWS_WITH_ESP8266)
308#undef compatible_close
309#define compatible_close(fd) { fd->state=ESPCONN_CLOSE; espconn_delete(fd); }
310lws_sockfd_type
311esp8266_create_tcp_stream_socket(void);
312void
313esp8266_tcp_stream_bind(lws_sockfd_type fd, int port, struct lws *wsi);
314#ifndef BIG_ENDIAN
315#define BIG_ENDIAN 4321 /* to show byte order (taken from gcc) */
316#endif
317#ifndef LITTLE_ENDIAN
318#define LITTLE_ENDIAN 1234
319#endif
320#ifndef BYTE_ORDER
321#define BYTE_ORDER LITTLE_ENDIAN
322#endif
323#endif
324
325
Andy Green158e8042014-04-02 14:25:10 +0800326#if defined(WIN32) || defined(_WIN32)
327
328#ifndef BIG_ENDIAN
329#define BIG_ENDIAN 4321 /* to show byte order (taken from gcc) */
330#endif
331#ifndef LITTLE_ENDIAN
332#define LITTLE_ENDIAN 1234
333#endif
334#ifndef BYTE_ORDER
335#define BYTE_ORDER LITTLE_ENDIAN
336#endif
Andy Green11f27342015-11-08 12:10:26 +0800337#ifndef u_int64_t
Andy Green158e8042014-04-02 14:25:10 +0800338typedef unsigned __int64 u_int64_t;
Andy Green11f27342015-11-08 12:10:26 +0800339#endif
Andy Green158e8042014-04-02 14:25:10 +0800340
341#undef __P
342#ifndef __P
343#if __STDC__
344#define __P(protos) protos
345#else
346#define __P(protos) ()
347#endif
348#endif
349
350#else
351
352#include <sys/stat.h>
Andy Green158e8042014-04-02 14:25:10 +0800353#include <sys/time.h>
354
355#if defined(__APPLE__)
356#include <machine/endian.h>
357#elif defined(__FreeBSD__)
358#include <sys/endian.h>
359#elif defined(__linux__)
360#include <endian.h>
361#endif
362
Andy Green8c0d3c02015-11-02 20:34:12 +0800363#ifdef __cplusplus
364extern "C" {
365#endif
Alejandro Meryead8afe2014-12-07 03:36:11 +0100366
emironova49d0842014-09-16 14:05:13 +0400367#if defined(__QNX__)
368 #include <gulliver.h>
369 #if defined(__LITTLEENDIAN__)
370 #define BYTE_ORDER __LITTLEENDIAN__
371 #define LITTLE_ENDIAN __LITTLEENDIAN__
372 #define BIG_ENDIAN 4321 /* to show byte order (taken from gcc); for suppres warning that BIG_ENDIAN is not defined. */
373 #endif
374 #if defined(__BIGENDIAN__)
375 #define BYTE_ORDER __BIGENDIAN__
376 #define LITTLE_ENDIAN 1234 /* to show byte order (taken from gcc); for suppres warning that LITTLE_ENDIAN is not defined. */
377 #define BIG_ENDIAN __BIGENDIAN__
378 #endif
379#endif
380
Fredrik Skogman316960b2016-09-09 06:49:44 +0800381#if defined(__sun) && defined(__GNUC__)
luk65a4d23642017-03-23 23:56:25 +0800382
383#include <arpa/nameser_compat.h>
384
385#if !defined (BYTE_ORDER)
Fredrik Skogman316960b2016-09-09 06:49:44 +0800386# define BYTE_ORDER __BYTE_ORDER__
luk65a4d23642017-03-23 23:56:25 +0800387#endif
388
389#if !defined(LITTLE_ENDIAN)
Fredrik Skogman316960b2016-09-09 06:49:44 +0800390# define LITTLE_ENDIAN __ORDER_LITTLE_ENDIAN__
luk65a4d23642017-03-23 23:56:25 +0800391#endif
392
393#if !defined(BIG_ENDIAN)
Fredrik Skogman316960b2016-09-09 06:49:44 +0800394# define BIG_ENDIAN __ORDER_BIG_ENDIAN__
395#endif
396
luk65a4d23642017-03-23 23:56:25 +0800397#endif /* sun + GNUC */
398
Andy Green158e8042014-04-02 14:25:10 +0800399#if !defined(BYTE_ORDER)
400# define BYTE_ORDER __BYTE_ORDER
401#endif
402#if !defined(LITTLE_ENDIAN)
403# define LITTLE_ENDIAN __LITTLE_ENDIAN
404#endif
405#if !defined(BIG_ENDIAN)
406# define BIG_ENDIAN __BIG_ENDIAN
407#endif
408
409#endif
410
Darin Willitsc19456f2011-02-14 17:52:39 +0000411/*
412 * Mac OSX as well as iOS do not define the MSG_NOSIGNAL flag,
413 * but happily have something equivalent in the SO_NOSIGPIPE flag.
414 */
415#ifdef __APPLE__
Andy Green6ee372f2012-04-09 15:09:01 +0800416#define MSG_NOSIGNAL SO_NOSIGPIPE
Darin Willitsc19456f2011-02-14 17:52:39 +0000417#endif
418
Fredrik Skogman316960b2016-09-09 06:49:44 +0800419/*
420 * Solaris 11.X only supports POSIX 2001, MSG_NOSIGNAL appears in
421 * POSIX 2008.
422 */
423#ifdef __sun
424#define MSG_NOSIGNAL 0
425#endif
426
Bud Davis229bfec2015-01-30 10:13:01 +0800427#ifdef _WIN32
428#ifndef FD_HASHTABLE_MODULUS
429#define FD_HASHTABLE_MODULUS 32
430#endif
431#endif
432
Andy Green8c1f6022016-01-26 20:56:56 +0800433#ifndef LWS_DEF_HEADER_LEN
Andy Green5ab523e2016-07-11 07:48:53 +0800434#define LWS_DEF_HEADER_LEN 4096
Andy Greenc0d6b632013-01-12 23:42:17 +0800435#endif
Andy Green8c1f6022016-01-26 20:56:56 +0800436#ifndef LWS_DEF_HEADER_POOL
Andy Green5ab523e2016-07-11 07:48:53 +0800437#define LWS_DEF_HEADER_POOL 4
Andy Green3df58002015-12-25 12:44:12 +0800438#endif
Andy Greenc0d6b632013-01-12 23:42:17 +0800439#ifndef LWS_MAX_PROTOCOLS
Andy Greend91d5e82013-02-10 16:00:47 +0800440#define LWS_MAX_PROTOCOLS 5
Andy Greenc0d6b632013-01-12 23:42:17 +0800441#endif
442#ifndef LWS_MAX_EXTENSIONS_ACTIVE
Andy Greend738f842016-01-19 04:32:14 +0800443#define LWS_MAX_EXTENSIONS_ACTIVE 2
Andy Greenc0d6b632013-01-12 23:42:17 +0800444#endif
Andy Green67112662016-01-11 11:34:01 +0800445#ifndef LWS_MAX_EXT_OFFERS
446#define LWS_MAX_EXT_OFFERS 8
447#endif
Andy Greenc0d6b632013-01-12 23:42:17 +0800448#ifndef SPEC_LATEST_SUPPORTED
Andy Greend85cb202011-09-25 09:32:54 +0100449#define SPEC_LATEST_SUPPORTED 13
Andy Greenc0d6b632013-01-12 23:42:17 +0800450#endif
451#ifndef AWAITING_TIMEOUT
Andy Green8c1f6022016-01-26 20:56:56 +0800452#define AWAITING_TIMEOUT 20
Andy Greenc0d6b632013-01-12 23:42:17 +0800453#endif
454#ifndef CIPHERS_LIST_STRING
David Galeanof177f2a2013-01-10 10:15:19 +0800455#define CIPHERS_LIST_STRING "DEFAULT"
Andy Greenc0d6b632013-01-12 23:42:17 +0800456#endif
Andy Greena824d182013-01-15 20:52:29 +0800457#ifndef LWS_SOMAXCONN
458#define LWS_SOMAXCONN SOMAXCONN
459#endif
Andy Green7c212cc2010-11-08 20:20:42 +0000460
Andy Greene2522172011-01-18 17:14:03 +0000461#define MAX_WEBSOCKET_04_KEY_LEN 128
Andy Greenc0d6b632013-01-12 23:42:17 +0800462
463#ifndef SYSTEM_RANDOM_FILEPATH
Andy Green4739e5c2011-01-22 12:51:57 +0000464#define SYSTEM_RANDOM_FILEPATH "/dev/urandom"
Andy Greenc0d6b632013-01-12 23:42:17 +0800465#endif
Andy Greenc0d6b632013-01-12 23:42:17 +0800466
Andy Green5fd55cd2011-04-23 10:54:53 +0100467enum lws_websocket_opcodes_07 {
Andy Green54806b12015-12-17 17:03:59 +0800468 LWSWSOPC_CONTINUATION = 0,
469 LWSWSOPC_TEXT_FRAME = 1,
470 LWSWSOPC_BINARY_FRAME = 2,
Andy Greena41314f2011-05-23 10:00:03 +0100471
Andy Green54806b12015-12-17 17:03:59 +0800472 LWSWSOPC_NOSPEC__MUX = 7,
Andy Greena41314f2011-05-23 10:00:03 +0100473
474 /* control extensions 8+ */
475
Andy Green54806b12015-12-17 17:03:59 +0800476 LWSWSOPC_CLOSE = 8,
477 LWSWSOPC_PING = 9,
478 LWSWSOPC_PONG = 0xa,
Andy Green5fd55cd2011-04-23 10:54:53 +0100479};
480
Andy Greena41314f2011-05-23 10:00:03 +0100481
Andy Green7c212cc2010-11-08 20:20:42 +0000482enum lws_connection_states {
Andy Green54806b12015-12-17 17:03:59 +0800483 LWSS_HTTP,
484 LWSS_HTTP_ISSUING_FILE,
485 LWSS_HTTP_HEADERS,
486 LWSS_HTTP_BODY,
487 LWSS_DEAD_SOCKET,
488 LWSS_ESTABLISHED,
Andy Greena661ee52016-02-29 13:18:30 +0800489 LWSS_CLIENT_HTTP_ESTABLISHED,
Andy Green54806b12015-12-17 17:03:59 +0800490 LWSS_CLIENT_UNCONNECTED,
Andy Green3b0066c2017-07-17 10:11:17 +0800491 LWSS_WAITING_TO_SEND_CLOSE_NOTIFICATION,
Andy Green54806b12015-12-17 17:03:59 +0800492 LWSS_RETURNED_CLOSE_ALREADY,
493 LWSS_AWAITING_CLOSE_ACK,
494 LWSS_FLUSHING_STORED_SEND_BEFORE_CLOSE,
Andy Green8c1f6022016-01-26 20:56:56 +0800495 LWSS_SHUTDOWN,
Andy Green40110e82015-12-14 08:52:03 +0800496
Andy Green54806b12015-12-17 17:03:59 +0800497 LWSS_HTTP2_AWAIT_CLIENT_PREFACE,
498 LWSS_HTTP2_ESTABLISHED_PRE_SETTINGS,
499 LWSS_HTTP2_ESTABLISHED,
Andy Green6a8099b2016-02-21 21:25:48 +0800500
Andy Green2d8d35a2016-02-29 14:19:16 +0800501 LWSS_CGI,
Andy Green7c212cc2010-11-08 20:20:42 +0000502};
503
Andrew Canadayafe26cf2014-07-13 01:07:36 -0400504enum http_version {
505 HTTP_VERSION_1_0,
506 HTTP_VERSION_1_1,
Andy Green22d6f392016-04-10 09:33:54 +0800507 HTTP_VERSION_2
Andrew Canadayafe26cf2014-07-13 01:07:36 -0400508};
509
510enum http_connection_type {
511 HTTP_CONNECTION_CLOSE,
512 HTTP_CONNECTION_KEEP_ALIVE
513};
514
Andy Green024eb6c2014-10-08 12:00:53 +0800515enum lws_pending_protocol_send {
516 LWS_PPS_NONE,
517 LWS_PPS_HTTP2_MY_SETTINGS,
518 LWS_PPS_HTTP2_ACK_SETTINGS,
Andy Greenbbbf07a2014-10-27 16:46:44 +0800519 LWS_PPS_HTTP2_PONG,
Andy Green024eb6c2014-10-08 12:00:53 +0800520};
521
Andy Green7c212cc2010-11-08 20:20:42 +0000522enum lws_rx_parse_state {
523 LWS_RXPS_NEW,
Andy Greene77ddd82010-11-13 10:03:47 +0000524
Andy Green67112662016-01-11 11:34:01 +0800525 LWS_RXPS_04_mask_1,
526 LWS_RXPS_04_mask_2,
527 LWS_RXPS_04_mask_3,
Andy Green3e5eb782011-01-18 18:14:26 +0000528
529 LWS_RXPS_04_FRAME_HDR_1,
Andy Green38e57bb2011-01-19 12:20:27 +0000530 LWS_RXPS_04_FRAME_HDR_LEN,
531 LWS_RXPS_04_FRAME_HDR_LEN16_2,
532 LWS_RXPS_04_FRAME_HDR_LEN16_1,
533 LWS_RXPS_04_FRAME_HDR_LEN64_8,
534 LWS_RXPS_04_FRAME_HDR_LEN64_7,
535 LWS_RXPS_04_FRAME_HDR_LEN64_6,
536 LWS_RXPS_04_FRAME_HDR_LEN64_5,
537 LWS_RXPS_04_FRAME_HDR_LEN64_4,
538 LWS_RXPS_04_FRAME_HDR_LEN64_3,
539 LWS_RXPS_04_FRAME_HDR_LEN64_2,
540 LWS_RXPS_04_FRAME_HDR_LEN64_1,
Andy Green3e5eb782011-01-18 18:14:26 +0000541
Andy Green283d0a22011-04-24 05:46:23 +0100542 LWS_RXPS_07_COLLECT_FRAME_KEY_1,
543 LWS_RXPS_07_COLLECT_FRAME_KEY_2,
544 LWS_RXPS_07_COLLECT_FRAME_KEY_3,
545 LWS_RXPS_07_COLLECT_FRAME_KEY_4,
546
Andy Green7c212cc2010-11-08 20:20:42 +0000547 LWS_RXPS_PAYLOAD_UNTIL_LENGTH_EXHAUSTED
548};
549
Andy Green95fff472016-08-08 21:54:30 +0800550#define LWSCM_FLAG_IMPLIES_CALLBACK_CLOSED_CLIENT_HTTP 32
Andy Green7c212cc2010-11-08 20:20:42 +0000551
Andy Green0d338332011-02-12 11:57:43 +0000552enum connection_mode {
Andy Green54806b12015-12-17 17:03:59 +0800553 LWSCM_HTTP_SERVING,
554 LWSCM_HTTP_SERVING_ACCEPTED, /* actual HTTP service going on */
555 LWSCM_PRE_WS_SERVING_ACCEPT,
Andy Greend280b6e2013-01-15 13:40:23 +0800556
Andy Green54806b12015-12-17 17:03:59 +0800557 LWSCM_WS_SERVING,
558 LWSCM_WS_CLIENT,
Andy Green40110e82015-12-14 08:52:03 +0800559
Andy Green54806b12015-12-17 17:03:59 +0800560 LWSCM_HTTP2_SERVING,
Andy Green0d338332011-02-12 11:57:43 +0000561
Andy Greene2160712013-01-28 12:19:10 +0800562 /* transient, ssl delay hiding */
Andy Green54806b12015-12-17 17:03:59 +0800563 LWSCM_SSL_ACK_PENDING,
Andy Green8c1f6022016-01-26 20:56:56 +0800564 LWSCM_SSL_INIT,
Andy Green297c0312017-02-12 20:32:49 +0800565 /* as above, but complete into LWSCM_RAW */
566 LWSCM_SSL_ACK_PENDING_RAW,
567 LWSCM_SSL_INIT_RAW,
Andy Greene2160712013-01-28 12:19:10 +0800568
Andy Green95fff472016-08-08 21:54:30 +0800569 /* special internal types */
570 LWSCM_SERVER_LISTENER,
571 LWSCM_CGI, /* stdin, stdout, stderr for another cgi master wsi */
Andy Greenbe8d7912017-02-27 12:55:56 +0800572 LWSCM_RAW, /* raw with bulk handling */
573 LWSCM_RAW_FILEDESC, /* raw without bulk handling */
Andy Green95fff472016-08-08 21:54:30 +0800574
575 /* HTTP Client related */
576 LWSCM_HTTP_CLIENT = LWSCM_FLAG_IMPLIES_CALLBACK_CLOSED_CLIENT_HTTP,
577 LWSCM_HTTP_CLIENT_ACCEPTED, /* actual HTTP service going on */
Andy Green54806b12015-12-17 17:03:59 +0800578 LWSCM_WSCL_WAITING_CONNECT,
579 LWSCM_WSCL_WAITING_PROXY_REPLY,
580 LWSCM_WSCL_ISSUE_HANDSHAKE,
581 LWSCM_WSCL_ISSUE_HANDSHAKE2,
Andy Green95fff472016-08-08 21:54:30 +0800582 LWSCM_WSCL_ISSUE_HTTP_BODY,
Andy Green54806b12015-12-17 17:03:59 +0800583 LWSCM_WSCL_WAITING_SSL,
584 LWSCM_WSCL_WAITING_SERVER_REPLY,
585 LWSCM_WSCL_WAITING_EXTENSION_CONNECT,
586 LWSCM_WSCL_PENDING_CANDIDATE_CHILD,
Andy Ninged92b6d2017-05-05 11:38:34 -0400587 LWSCM_WSCL_WAITING_SOCKS_GREETING_REPLY,
588 LWSCM_WSCL_WAITING_SOCKS_CONNECT_REPLY,
589 LWSCM_WSCL_WAITING_SOCKS_AUTH_REPLY,
Andy Greenbe93fef2011-02-14 20:25:43 +0000590
Andy Green95fff472016-08-08 21:54:30 +0800591 /****** add new things just above ---^ ******/
592
593
Andy Green0d338332011-02-12 11:57:43 +0000594};
595
Andy Ninged92b6d2017-05-05 11:38:34 -0400596/* enums of socks version */
597enum socks_version {
598 SOCKS_VERSION_4 = 4,
599 SOCKS_VERSION_5 = 5
600};
601
602/* enums of subnegotiation version */
603enum socks_subnegotiation_version {
604 SOCKS_SUBNEGOTIATION_VERSION_1 = 1,
605};
606
607/* enums of socks commands */
608enum socks_command {
609 SOCKS_COMMAND_CONNECT = 1,
610 SOCKS_COMMAND_BIND = 2,
611 SOCKS_COMMAND_UDP_ASSOCIATE = 3
612};
613
614/* enums of socks address type */
615enum socks_atyp {
616 SOCKS_ATYP_IPV4 = 1,
617 SOCKS_ATYP_DOMAINNAME = 3,
618 SOCKS_ATYP_IPV6 = 4
619};
620
621/* enums of socks authentication methods */
622enum socks_auth_method {
623 SOCKS_AUTH_NO_AUTH = 0,
624 SOCKS_AUTH_GSSAPI = 1,
625 SOCKS_AUTH_USERNAME_PASSWORD = 2
626};
627
628/* enums of subnegotiation status */
629enum socks_subnegotiation_status {
630 SOCKS_SUBNEGOTIATION_STATUS_SUCCESS = 0,
631};
632
633/* enums of socks request reply */
634enum socks_request_reply {
635 SOCKS_REQUEST_REPLY_SUCCESS = 0,
636 SOCKS_REQUEST_REPLY_FAILURE_GENERAL = 1,
637 SOCKS_REQUEST_REPLY_CONNECTION_NOT_ALLOWED = 2,
638 SOCKS_REQUEST_REPLY_NETWORK_UNREACHABLE = 3,
639 SOCKS_REQUEST_REPLY_HOST_UNREACHABLE = 4,
640 SOCKS_REQUEST_REPLY_CONNECTION_REFUSED = 5,
641 SOCKS_REQUEST_REPLY_TTL_EXPIRED = 6,
642 SOCKS_REQUEST_REPLY_COMMAND_NOT_SUPPORTED = 7,
643 SOCKS_REQUEST_REPLY_ATYP_NOT_SUPPORTED = 8
644};
645
646/* enums used to generate socks messages */
647enum socks_msg_type {
648 /* greeting */
649 SOCKS_MSG_GREETING,
650 /* credential, user name and password */
651 SOCKS_MSG_USERNAME_PASSWORD,
652 /* connect command */
653 SOCKS_MSG_CONNECT
654};
655
Andy Greenca0a1292013-03-16 11:24:23 +0800656enum {
657 LWS_RXFLOW_ALLOW = (1 << 0),
658 LWS_RXFLOW_PENDING_CHANGE = (1 << 1),
659};
660
Andy Green1fb95e82015-12-26 17:20:34 +0800661/* this is not usable directly by user code any more, lws_close_reason() */
662#define LWS_WRITE_CLOSE 4
663
Andy Green4b85c1d2015-12-04 11:08:32 +0800664struct lws_protocols;
665struct lws;
Andy Greene92cd172011-01-19 13:11:55 +0000666
Aditya Tirumalaec50eba2017-03-15 19:41:11 +0530667#if defined(LWS_USE_LIBEV) || defined(LWS_USE_LIBUV) || defined(LWS_USE_LIBEVENT)
Andy Green86ed65f2016-02-14 09:27:41 +0800668
Andrew Canaday9769f4f2014-03-23 13:25:07 +0800669struct lws_io_watcher {
Andy Green86ed65f2016-02-14 09:27:41 +0800670#ifdef LWS_USE_LIBEV
671 ev_io ev_watcher;
672#endif
673#ifdef LWS_USE_LIBUV
674 uv_poll_t uv_watcher;
675#endif
Aditya Tirumalaec50eba2017-03-15 19:41:11 +0530676#ifdef LWS_USE_LIBEVENT
677 struct event *event_watcher;
678#endif
Andy Green86ed65f2016-02-14 09:27:41 +0800679 struct lws_context *context;
Andrew Canaday9769f4f2014-03-23 13:25:07 +0800680};
681
682struct lws_signal_watcher {
Andy Green86ed65f2016-02-14 09:27:41 +0800683#ifdef LWS_USE_LIBEV
684 ev_signal ev_watcher;
685#endif
686#ifdef LWS_USE_LIBUV
687 uv_signal_t uv_watcher;
688#endif
Aditya Tirumalaec50eba2017-03-15 19:41:11 +0530689#ifdef LWS_USE_LIBEVENT
690 struct event *event_watcher;
691#endif
Andy Green86ed65f2016-02-14 09:27:41 +0800692 struct lws_context *context;
Andrew Canaday9769f4f2014-03-23 13:25:07 +0800693};
Andy Green86ed65f2016-02-14 09:27:41 +0800694#endif
Andrew Canaday9769f4f2014-03-23 13:25:07 +0800695
Bud Davis229bfec2015-01-30 10:13:01 +0800696#ifdef _WIN32
697#define LWS_FD_HASH(fd) ((fd ^ (fd >> 8) ^ (fd >> 16)) % FD_HASHTABLE_MODULUS)
Andy Green3ef579b2015-12-04 09:23:56 +0800698struct lws_fd_hashtable {
Andy Green4b85c1d2015-12-04 11:08:32 +0800699 struct lws **wsi;
Bud Davis229bfec2015-01-30 10:13:01 +0800700 int length;
701};
702#endif
703
Andy Green3df58002015-12-25 12:44:12 +0800704/*
705 * This is totally opaque to code using the library. It's exported as a
706 * forward-reference pointer-only declaration; the user can use the pointer with
707 * other APIs to get information out of it.
708 */
709
710struct lws_fragments {
Andy Green48895662016-06-02 12:32:38 +0800711 unsigned int offset;
Andy Green3df58002015-12-25 12:44:12 +0800712 unsigned short len;
713 unsigned char nfrag; /* which ah->frag[] continues this content, or 0 */
714};
715
716/*
717 * these are assigned from a pool held in the context.
718 * Both client and server mode uses them for http header analysis
719 */
720
721struct allocated_headers {
Andy Green2c218e72016-02-15 12:37:04 +0800722 struct lws *wsi; /* owner */
Andy Greende132b92015-12-25 13:48:20 +0800723 char *data; /* prepared by context init to point to dedicated storage */
724 /*
725 * the randomly ordered fragments, indexed by frag_index and
726 * lws_fragments->nfrag for continuation.
727 */
728 struct lws_fragments frags[WSI_TOKEN_COUNT * 2];
Andy Green8c1f6022016-01-26 20:56:56 +0800729 time_t assigned;
Andy Green3df58002015-12-25 12:44:12 +0800730 /*
731 * for each recognized token, frag_index says which frag[] his data
732 * starts in (0 means the token did not appear)
733 * the actual header data gets dumped as it comes in, into data[]
734 */
735 unsigned char frag_index[WSI_TOKEN_COUNT];
Andy Green2c218e72016-02-15 12:37:04 +0800736 unsigned char rx[2048];
Andy Greened4acef2016-12-12 13:36:25 +0800737
Andy Green2c218e72016-02-15 12:37:04 +0800738 unsigned int rxpos;
739 unsigned int rxlen;
Andy Green48895662016-06-02 12:32:38 +0800740 unsigned int pos;
Andy Green2c218e72016-02-15 12:37:04 +0800741
Andy Green86ab0602016-10-21 23:12:21 +0800742 unsigned int http_response;
743
Andy Green3df58002015-12-25 12:44:12 +0800744#ifndef LWS_NO_CLIENT
745 char initial_handshake_hash_base64[30];
Andy Green3df58002015-12-25 12:44:12 +0800746#endif
Andy Greenaa775fd2015-12-26 08:56:58 +0800747
Andy Greenaa775fd2015-12-26 08:56:58 +0800748 unsigned char in_use;
749 unsigned char nfrag;
Andy Green3df58002015-12-25 12:44:12 +0800750};
751
Andy Greend3a55052016-01-19 03:34:24 +0800752/*
753 * so we can have n connections being serviced simultaneously,
754 * these things need to be isolated per-thread.
755 */
756
757struct lws_context_per_thread {
Andy Green8c1f6022016-01-26 20:56:56 +0800758#if LWS_MAX_SMP > 1
759 pthread_mutex_t lock;
760#endif
Andy Greend3a55052016-01-19 03:34:24 +0800761 struct lws_pollfd *fds;
Andy Green7acf76c2016-07-23 14:18:25 +0800762#if defined(LWS_WITH_ESP8266)
763 struct lws **lws_vs_fds_index;
764#endif
Andy Greend3a55052016-01-19 03:34:24 +0800765 struct lws *rx_draining_ext_list;
766 struct lws *tx_draining_ext_list;
Andy Green8c1f6022016-01-26 20:56:56 +0800767 struct lws *timeout_list;
Aditya Tirumalaec50eba2017-03-15 19:41:11 +0530768#if defined(LWS_USE_LIBUV) || defined(LWS_USE_LIBEVENT)
Andy Green38a1cbb2016-02-27 11:03:27 +0800769 struct lws_context *context;
Patrick Ganstererfa9ebb32016-08-14 14:04:56 +0200770#endif
Andy Green6a8099b2016-02-21 21:25:48 +0800771#ifdef LWS_WITH_CGI
772 struct lws_cgi *cgi_list;
773#endif
Andy Green8c1f6022016-01-26 20:56:56 +0800774 void *http_header_data;
775 struct allocated_headers *ah_pool;
776 struct lws *ah_wait_list;
777 int ah_wait_list_length;
Andy Greend3a55052016-01-19 03:34:24 +0800778#ifdef LWS_OPENSSL_SUPPORT
779 struct lws *pending_read_list; /* linked list */
780#endif
Andy Green86ed65f2016-02-14 09:27:41 +0800781#if defined(LWS_USE_LIBEV)
782 struct ev_loop *io_loop_ev;
783#endif
784#if defined(LWS_USE_LIBUV)
785 uv_loop_t *io_loop_uv;
786 uv_signal_t signals[8];
Andy Green38a1cbb2016-02-27 11:03:27 +0800787 uv_timer_t uv_timeout_watcher;
Andy Green09998e32016-04-06 09:23:16 +0800788 uv_idle_t uv_idle;
Andy Green86ed65f2016-02-14 09:27:41 +0800789#endif
Aditya Tirumalaec50eba2017-03-15 19:41:11 +0530790#if defined(LWS_USE_LIBEVENT)
791 struct event_base *io_loop_event_base;
792#endif
Andy Green86ed65f2016-02-14 09:27:41 +0800793#if defined(LWS_USE_LIBEV)
794 struct lws_io_watcher w_accept;
795#endif
Aditya Tirumalaec50eba2017-03-15 19:41:11 +0530796#if defined(LWS_USE_LIBEV) || defined(LWS_USE_LIBUV) || defined(LWS_USE_LIBEVENT)
Andy Green86ed65f2016-02-14 09:27:41 +0800797 struct lws_signal_watcher w_sigint;
798 unsigned char ev_loop_foreign:1;
799#endif
Andy Green8c1f6022016-01-26 20:56:56 +0800800
801 unsigned long count_conns;
Andy Greend3a55052016-01-19 03:34:24 +0800802 /*
803 * usable by anything in the service code, but only if the scope
804 * does not last longer than the service action (since next service
805 * of any socket can likewise use it and overwrite)
806 */
807 unsigned char *serv_buf;
808#ifdef _WIN32
809 WSAEVENT *events;
810#else
Andy Green7acf76c2016-07-23 14:18:25 +0800811 lws_sockfd_type dummy_pipe_fds[2];
Andy Greend3a55052016-01-19 03:34:24 +0800812#endif
Andy Green8c1f6022016-01-26 20:56:56 +0800813 unsigned int fds_count;
814
815 short ah_count_in_use;
Andy Green38a1cbb2016-02-27 11:03:27 +0800816 unsigned char tid;
Andy Greenbbf93692016-08-07 08:33:08 +0800817 unsigned char lock_depth;
Andy Greend3a55052016-01-19 03:34:24 +0800818};
819
Andy Greenbe9fb912016-12-16 07:37:43 +0800820struct lws_conn_stats {
821 unsigned long long rx, tx;
822 unsigned long conn, trans, ws_upg, http2_upg, rejected;
823};
824
825void
826lws_sum_stats(const struct lws_context *ctx, struct lws_conn_stats *cs);
827
Andy Greend526c502016-03-28 10:10:43 +0800828/*
829 * virtual host -related context information
830 * vhostwide SSL context
831 * vhostwide proxy
832 *
Peter Pentchevfb71b792016-10-02 02:21:03 +0300833 * hierarchy:
Andy Greend526c502016-03-28 10:10:43 +0800834 *
835 * context -> vhost -> wsi
836 *
837 * incoming connection non-SSL vhost binding:
838 *
839 * listen socket -> wsi -> select vhost after first headers
840 *
841 * incoming connection SSL vhost binding:
842 *
843 * SSL SNI -> wsi -> bind after SSL negotiation
844 */
845
846struct lws_vhost {
Andy Green7acf76c2016-07-23 14:18:25 +0800847#if !defined(LWS_WITH_ESP8266)
Andy Greend526c502016-03-28 10:10:43 +0800848 char http_proxy_address[128];
849 char proxy_basic_auth_token[128];
Andy Ninged92b6d2017-05-05 11:38:34 -0400850#if defined(LWS_WITH_SOCKS5)
851 char socks_proxy_address[128];
852 char socks_user[96];
853 char socks_password[96];
854#endif
Andy Green7acf76c2016-07-23 14:18:25 +0800855#endif
856#if defined(LWS_WITH_ESP8266)
857 /* listen sockets need a place to hang their hat */
858 esp_tcp tcp;
859#endif
Andy Greenbe9fb912016-12-16 07:37:43 +0800860 struct lws_conn_stats conn_stats;
Andy Greend526c502016-03-28 10:10:43 +0800861 struct lws_context *context;
862 struct lws_vhost *vhost_next;
Andy Green4664f712016-05-02 04:59:54 +0800863 const struct lws_http_mount *mount_list;
Andy Greend526c502016-03-28 10:10:43 +0800864 struct lws *lserv_wsi;
865 const char *name;
866 const char *iface;
Leonardo Maccari Rufino393b38a2017-06-02 14:07:35 -0300867#if !defined(LWS_WITH_ESP8266) && !defined(LWS_WITH_ESP32) && !defined(OPTEE_TA) && !defined(WIN32)
868 int bind_iface;
869#endif
Andy Greend526c502016-03-28 10:10:43 +0800870 const struct lws_protocols *protocols;
Andy Green02077052016-04-06 16:15:40 +0800871 void **protocol_vh_privs;
Andy Green952fcde2016-05-02 06:01:59 +0800872 const struct lws_protocol_vhost_options *pvo;
Andy Greene35d91a2016-08-27 17:07:06 +0800873 const struct lws_protocol_vhost_options *headers;
Andy Green4714cf02016-04-16 08:40:35 +0800874 struct lws **same_vh_protocol_list;
Andy Greend526c502016-03-28 10:10:43 +0800875#ifdef LWS_OPENSSL_SUPPORT
876 SSL_CTX *ssl_ctx;
877 SSL_CTX *ssl_client_ctx;
878#endif
879#ifndef LWS_NO_EXTENSIONS
880 const struct lws_extension *extensions;
881#endif
882
883 int listen_port;
884 unsigned int http_proxy_port;
Andy Ninged92b6d2017-05-05 11:38:34 -0400885#if defined(LWS_WITH_SOCKS5)
886 unsigned int socks_proxy_port;
887#endif
Andy Greencc3c6fb2016-04-14 15:09:01 +0800888 unsigned int options;
Andy Greend526c502016-03-28 10:10:43 +0800889 int count_protocols;
890 int ka_time;
891 int ka_probes;
892 int ka_interval;
Andy Greenb46e4a82016-04-12 16:26:03 +0800893 int keepalive_timeout;
Andy Greenba45f7c2017-07-26 11:49:41 +0800894 int timeout_secs_ah_idle;
Andy Green3ff720f2017-06-20 11:46:49 +0800895 int ssl_info_event_mask;
Andy Green2f0bc932016-04-15 12:00:23 +0800896#ifdef LWS_WITH_ACCESS_LOG
897 int log_fd;
898#endif
Andy Greend526c502016-03-28 10:10:43 +0800899
900#ifdef LWS_OPENSSL_SUPPORT
901 int use_ssl;
902 int allow_non_ssl_on_ssl_port;
903 unsigned int user_supplied_ssl_ctx:1;
904#endif
Andy Greenf32d2502016-07-15 13:41:38 +0800905
Bablooos6e436dc2016-11-30 07:05:13 +0800906 unsigned int created_vhost_protocols:1;
Andy Greenfaa15262017-07-15 14:37:04 +0800907 unsigned int being_destroyed:1;
Bablooos6e436dc2016-11-30 07:05:13 +0800908
Andy Greenf6585282016-05-06 14:24:59 +0800909 unsigned char default_protocol_index;
Andy Green205cced2017-03-07 16:06:05 +0800910 unsigned char raw_protocol_index;
Andy Greend526c502016-03-28 10:10:43 +0800911};
912
Andy Greenfaa15262017-07-15 14:37:04 +0800913struct lws_deferred_free
914{
915 struct lws_deferred_free *next;
916 time_t deadline;
917 void *payload;
918};
919
Andy Greend3a55052016-01-19 03:34:24 +0800920/*
921 * the rest is managed per-context, that includes
922 *
923 * - processwide single fd -> wsi lookup
924 * - contextwide headers pool
Andy Greend3a55052016-01-19 03:34:24 +0800925 */
926
Andy Green4b85c1d2015-12-04 11:08:32 +0800927struct lws_context {
Andy Greenaa775fd2015-12-26 08:56:58 +0800928 time_t last_timeout_check_s;
Andy Greenf32d2502016-07-15 13:41:38 +0800929 time_t last_ws_ping_pong_check_s;
Andy Green98061402016-04-15 14:01:29 +0800930 time_t time_up;
Andy Green1ada1322017-03-01 14:28:56 +0800931 const struct lws_plat_file_ops *fops;
Andy Green19cc7ac2017-03-03 12:38:10 +0800932 struct lws_plat_file_ops fops_platform;
933#if defined(LWS_WITH_ZIP_FOPS)
934 struct lws_plat_file_ops fops_zip;
935#endif
Andy Greend3a55052016-01-19 03:34:24 +0800936 struct lws_context_per_thread pt[LWS_MAX_SMP];
Andy Greenbe9fb912016-12-16 07:37:43 +0800937 struct lws_conn_stats conn_stats;
Bud Davis229bfec2015-01-30 10:13:01 +0800938#ifdef _WIN32
939/* different implementation between unix and windows */
Andy Green3ef579b2015-12-04 09:23:56 +0800940 struct lws_fd_hashtable fd_hashtable[FD_HASHTABLE_MODULUS];
Bud Davis229bfec2015-01-30 10:13:01 +0800941#else
Andy Green7acf76c2016-07-23 14:18:25 +0800942#if defined(LWS_WITH_ESP8266)
943 struct espconn **connpool; /* .reverse points to the wsi */
944 void *rxd;
945 int rxd_len;
946 os_timer_t to_timer;
947#else
Andy Green4b85c1d2015-12-04 11:08:32 +0800948 struct lws **lws_lookup; /* fd to wsi */
Bud Davis229bfec2015-01-30 10:13:01 +0800949#endif
Andy Green7acf76c2016-07-23 14:18:25 +0800950#endif
Andy Greend526c502016-03-28 10:10:43 +0800951 struct lws_vhost *vhost_list;
Andy Greenfaa15262017-07-15 14:37:04 +0800952 struct lws_vhost *vhost_pending_destruction_list;
Andy Green02077052016-04-06 16:15:40 +0800953 struct lws_plugin *plugin_list;
Andy Greenfaa15262017-07-15 14:37:04 +0800954 struct lws_deferred_free *deferred_free_list;
Andy Greenbe9fb912016-12-16 07:37:43 +0800955
Andy Green69c88d92016-12-04 07:34:05 +0800956 void *external_baggage_free_on_destroy;
Andy Greenaa775fd2015-12-26 08:56:58 +0800957 const struct lws_token_limits *token_limits;
958 void *user_space;
Andy Greenb21c20b2016-04-15 13:33:52 +0800959 const char *server_string;
Andy Green3b93e342016-10-13 06:32:57 +0800960 const struct lws_protocol_vhost_options *reject_service_keywords;
Andy Greenbe9fb912016-12-16 07:37:43 +0800961 lws_reload_func deprecation_cb;
Andy Greend738f842016-01-19 04:32:14 +0800962
Andy Green156363f2017-06-07 06:10:02 +0800963#if defined(LWS_HAVE_SYS_CAPABILITY_H) && defined(LWS_HAVE_LIBCAP)
964 cap_value_t caps[4];
965 char count_caps;
966#endif
967
Andy Green86ed65f2016-02-14 09:27:41 +0800968#if defined(LWS_USE_LIBEV)
969 lws_ev_signal_cb_t * lws_ev_sigint_cb;
970#endif
971#if defined(LWS_USE_LIBUV)
Denis Osvaldf107e4b2016-03-22 14:04:15 +0100972 uv_signal_cb lws_uv_sigint_cb;
Andy Greend5f960f2017-07-15 17:57:14 +0800973 uv_loop_t pu_loop;
Andy Green86ed65f2016-02-14 09:27:41 +0800974#endif
Aditya Tirumalaec50eba2017-03-15 19:41:11 +0530975#if defined(LWS_USE_LIBEVENT)
976 lws_event_signal_cb_t * lws_event_sigint_cb;
977#endif
Andy Greenaa775fd2015-12-26 08:56:58 +0800978 char canonical_hostname[128];
979#ifdef LWS_LATENCY
980 unsigned long worst_latency;
981 char worst_latency_info[256];
982#endif
Andy Greenb8b247d2013-01-22 07:20:08 +0800983
Andy Greena7def3c2017-05-07 10:02:03 +0800984#if defined(LWS_WITH_STATS)
985 uint64_t lws_stats[LWSSTATS_SIZE];
986 uint64_t last_dump;
987 int updated;
988#endif
989
Andy Greenaa775fd2015-12-26 08:56:58 +0800990 int max_fds;
Aditya Tirumalaec50eba2017-03-15 19:41:11 +0530991#if defined(LWS_USE_LIBEV) || defined(LWS_USE_LIBUV) || defined(LWS_USE_LIBEVENT)
Andy Greenaa775fd2015-12-26 08:56:58 +0800992 int use_ev_sigint;
993#endif
Andy Green24cba922013-01-19 13:56:10 +0800994 int started_with_parent;
Andy Greend526c502016-03-28 10:10:43 +0800995 int uid, gid;
Andy Green24cba922013-01-19 13:56:10 +0800996
Andy Green44eee682011-02-10 09:32:24 +0000997 int fd_random;
Andy Greend526c502016-03-28 10:10:43 +0800998#ifdef LWS_OPENSSL_SUPPORT
999#define lws_ssl_anybody_has_buffered_read(w) \
1000 (w->vhost->use_ssl && \
1001 w->context->pt[(int)w->tsi].pending_read_list)
1002#define lws_ssl_anybody_has_buffered_read_tsi(c, t) \
1003 (/*c->use_ssl && */ \
1004 c->pt[(int)t].pending_read_list)
1005#else
1006#define lws_ssl_anybody_has_buffered_read(ctx) (0)
1007#define lws_ssl_anybody_has_buffered_read_tsi(ctx, t) (0)
1008#endif
Andy Green86ed65f2016-02-14 09:27:41 +08001009 int count_wsi_allocated;
Andy Green748a2212016-04-20 06:10:56 +08001010 int count_cgi_spawned;
Andy Greenaa775fd2015-12-26 08:56:58 +08001011 unsigned int options;
Andy Greend3a55052016-01-19 03:34:24 +08001012 unsigned int fd_limit_per_thread;
Andy Green200a6a22016-02-15 20:36:02 +08001013 unsigned int timeout_secs;
Andy Greene7c1c752016-05-19 12:34:35 +08001014 unsigned int pt_serv_buf_size;
Andy Green48895662016-06-02 12:32:38 +08001015 int max_http_header_data;
Andy Green00ae9092017-03-16 10:46:31 +08001016 int simultaneous_ssl_restriction;
1017 int simultaneous_ssl;
Andy Green6ee372f2012-04-09 15:09:01 +08001018
Andy Greenbe9fb912016-12-16 07:37:43 +08001019 unsigned int deprecated:1;
1020 unsigned int being_destroyed:1;
1021 unsigned int being_destroyed1:1;
1022 unsigned int requested_kill:1;
1023 unsigned int protocol_init_done:1;
Andy Greenfbc1ff62017-05-15 07:30:06 +08001024 unsigned int ssl_gate_accepts:1;
Patrick Gansterer1ee57f62014-03-06 11:57:50 +01001025 /*
1026 * set to the Thread ID that's doing the service loop just before entry
1027 * to poll indicates service thread likely idling in poll()
1028 * volatile because other threads may check it as part of processing
1029 * for pollfd event change.
1030 */
1031 volatile int service_tid;
Andy Greenc35b36b2015-12-24 13:00:54 +08001032 int service_tid_detected;
Patrick Gansterer1ee57f62014-03-06 11:57:50 +01001033
Andy Green3df58002015-12-25 12:44:12 +08001034 short max_http_header_pool;
Andy Greend3a55052016-01-19 03:34:24 +08001035 short count_threads;
Andy Green02077052016-04-06 16:15:40 +08001036 short plugin_protocol_count;
1037 short plugin_extension_count;
Andy Greenb21c20b2016-04-15 13:33:52 +08001038 short server_string_len;
Andy Greenf32d2502016-07-15 13:41:38 +08001039 unsigned short ws_ping_pong_interval;
Andy Greenbe9fb912016-12-16 07:37:43 +08001040 unsigned short deprecation_pending_listen_close_count;
Andy Green19cc7ac2017-03-03 12:38:10 +08001041 uint8_t max_fi;
Andy Greenb45993c2010-12-18 15:13:50 +00001042};
1043
Andy Greenfaa15262017-07-15 14:37:04 +08001044int
1045lws_check_deferred_free(struct lws_context *context, int force);
1046
Andy Greend526c502016-03-28 10:10:43 +08001047#define lws_get_context_protocol(ctx, x) ctx->vhost_list->protocols[x]
1048#define lws_get_vh_protocol(vh, x) vh->protocols[x]
1049
Andy Green86ed65f2016-02-14 09:27:41 +08001050LWS_EXTERN void
1051lws_close_free_wsi_final(struct lws *wsi);
1052LWS_EXTERN void
1053lws_libuv_closehandle(struct lws *wsi);
Andy Greenede9ad22017-06-23 10:27:52 +08001054LWS_EXTERN void
1055lws_libuv_closehandle_manually(struct lws *wsi);
1056LWS_EXTERN int
1057lws_libuv_check_watcher_active(struct lws *wsi);
Andy Green86ed65f2016-02-14 09:27:41 +08001058
Andy Green0a183542016-04-09 07:22:40 +08001059LWS_VISIBLE LWS_EXTERN int
Andy Greencae57ad2016-05-02 10:03:25 +08001060lws_plat_plugins_init(struct lws_context * context, const char * const *d);
Andy Green0a183542016-04-09 07:22:40 +08001061
1062LWS_VISIBLE LWS_EXTERN int
1063lws_plat_plugins_destroy(struct lws_context * context);
1064
Andy Greenf32d2502016-07-15 13:41:38 +08001065LWS_EXTERN void
1066lws_restart_ws_ping_pong_timer(struct lws *wsi);
1067
Andy Green7acf76c2016-07-23 14:18:25 +08001068struct lws *
1069lws_adopt_socket_vhost(struct lws_vhost *vh, lws_sockfd_type accept_fd);
1070
1071
Andy Greena717df22014-04-11 13:14:37 +08001072enum {
1073 LWS_EV_READ = (1 << 0),
1074 LWS_EV_WRITE = (1 << 1),
1075 LWS_EV_START = (1 << 2),
1076 LWS_EV_STOP = (1 << 3),
Andy Green86ed65f2016-02-14 09:27:41 +08001077
1078 LWS_EV_PREPARE_DELETION = (1 << 31),
Andy Greena717df22014-04-11 13:14:37 +08001079};
1080
Andy Green86ed65f2016-02-14 09:27:41 +08001081#if defined(LWS_USE_LIBEV)
Andy Greena717df22014-04-11 13:14:37 +08001082LWS_EXTERN void
Andy Greenbe8d7912017-02-27 12:55:56 +08001083lws_libev_accept(struct lws *new_wsi, lws_sock_file_fd_type desc);
Andy Green04054b42017-03-03 08:18:16 +08001084LWS_EXTERN void
Andy Green11c05bf2015-12-16 18:19:08 +08001085lws_libev_io(struct lws *wsi, int flags);
Andy Greena717df22014-04-11 13:14:37 +08001086LWS_EXTERN int
Andy Green4b85c1d2015-12-04 11:08:32 +08001087lws_libev_init_fd_table(struct lws_context *context);
Andy Greena717df22014-04-11 13:14:37 +08001088LWS_EXTERN void
Andy Green86ed65f2016-02-14 09:27:41 +08001089lws_libev_destroyloop(struct lws_context *context, int tsi);
1090LWS_EXTERN void
1091lws_libev_run(const struct lws_context *context, int tsi);
Andy Greenc6fd3602016-03-23 09:22:11 +08001092#define LWS_LIBEV_ENABLED(context) lws_check_opt(context->options, LWS_SERVER_OPTION_LIBEV)
Andy Green86ed65f2016-02-14 09:27:41 +08001093LWS_EXTERN void lws_feature_status_libev(struct lws_context_creation_info *info);
Andrew Canaday9769f4f2014-03-23 13:25:07 +08001094#else
Andy Green86ed65f2016-02-14 09:27:41 +08001095#define lws_libev_accept(_a, _b) ((void) 0)
1096#define lws_libev_io(_a, _b) ((void) 0)
1097#define lws_libev_init_fd_table(_a) (0)
1098#define lws_libev_run(_a, _b) ((void) 0)
1099#define lws_libev_destroyloop(_a, _b) ((void) 0)
Andrew Canaday9769f4f2014-03-23 13:25:07 +08001100#define LWS_LIBEV_ENABLED(context) (0)
Andy Greenc7c4ae02017-02-18 17:26:40 +08001101#if LWS_POSIX && !defined(LWS_WITH_ESP32)
Andy Greena717df22014-04-11 13:14:37 +08001102#define lws_feature_status_libev(_a) \
1103 lwsl_notice("libev support not compiled in\n")
Andy Green8c0d3c02015-11-02 20:34:12 +08001104#else
1105#define lws_feature_status_libev(_a)
1106#endif
Andrew Canaday9769f4f2014-03-23 13:25:07 +08001107#endif
1108
Andy Green86ed65f2016-02-14 09:27:41 +08001109#if defined(LWS_USE_LIBUV)
1110LWS_EXTERN void
Andy Greenbe8d7912017-02-27 12:55:56 +08001111lws_libuv_accept(struct lws *new_wsi, lws_sock_file_fd_type desc);
Andy Green86ed65f2016-02-14 09:27:41 +08001112LWS_EXTERN void
1113lws_libuv_io(struct lws *wsi, int flags);
1114LWS_EXTERN int
1115lws_libuv_init_fd_table(struct lws_context *context);
1116LWS_EXTERN void
1117lws_libuv_run(const struct lws_context *context, int tsi);
1118LWS_EXTERN void
1119lws_libuv_destroyloop(struct lws_context *context, int tsi);
Bablooos6e436dc2016-11-30 07:05:13 +08001120LWS_EXTERN int
1121lws_uv_initvhost(struct lws_vhost* vh, struct lws*);
Andy Greenc6fd3602016-03-23 09:22:11 +08001122#define LWS_LIBUV_ENABLED(context) lws_check_opt(context->options, LWS_SERVER_OPTION_LIBUV)
Andy Green86ed65f2016-02-14 09:27:41 +08001123LWS_EXTERN void lws_feature_status_libuv(struct lws_context_creation_info *info);
1124#else
1125#define lws_libuv_accept(_a, _b) ((void) 0)
1126#define lws_libuv_io(_a, _b) ((void) 0)
1127#define lws_libuv_init_fd_table(_a) (0)
1128#define lws_libuv_run(_a, _b) ((void) 0)
1129#define lws_libuv_destroyloop(_a, _b) ((void) 0)
1130#define LWS_LIBUV_ENABLED(context) (0)
Andy Greenc7c4ae02017-02-18 17:26:40 +08001131#if LWS_POSIX && !defined(LWS_WITH_ESP32)
Andy Green86ed65f2016-02-14 09:27:41 +08001132#define lws_feature_status_libuv(_a) \
1133 lwsl_notice("libuv support not compiled in\n")
1134#else
1135#define lws_feature_status_libuv(_a)
1136#endif
1137#endif
1138
Aditya Tirumalaec50eba2017-03-15 19:41:11 +05301139#if defined(LWS_USE_LIBEVENT)
1140LWS_EXTERN void
1141lws_libevent_accept(struct lws *new_wsi, lws_sock_file_fd_type desc);
1142LWS_EXTERN void
1143lws_libevent_io(struct lws *wsi, int flags);
1144LWS_EXTERN int
1145lws_libevent_init_fd_table(struct lws_context *context);
1146LWS_EXTERN void
1147lws_libevent_destroyloop(struct lws_context *context, int tsi);
1148LWS_EXTERN void
1149lws_libevent_run(const struct lws_context *context, int tsi);
1150#define LWS_LIBEVENT_ENABLED(context) lws_check_opt(context->options, LWS_SERVER_OPTION_LIBEVENT)
1151LWS_EXTERN void lws_feature_status_libevent(struct lws_context_creation_info *info);
1152#else
1153#define lws_libevent_accept(_a, _b) ((void) 0)
1154#define lws_libevent_io(_a, _b) ((void) 0)
1155#define lws_libevent_init_fd_table(_a) (0)
1156#define lws_libevent_run(_a, _b) ((void) 0)
1157#define lws_libevent_destroyloop(_a, _b) ((void) 0)
1158#define LWS_LIBEVENT_ENABLED(context) (0)
1159#if LWS_POSIX && !defined(LWS_WITH_ESP32)
1160#define lws_feature_status_libevent(_a) \
1161 lwsl_notice("libevent support not compiled in\n")
1162#else
1163#define lws_feature_status_libevent(_a)
1164#endif
1165#endif
1166
Andy Green86ed65f2016-02-14 09:27:41 +08001167
Andy Green055f2972014-03-24 16:09:25 +08001168#ifdef LWS_USE_IPV6
Andy Green2dc7dde2016-06-03 21:19:40 +08001169#define LWS_IPV6_ENABLED(vh) \
Denis Osvaldc16c6c82016-06-03 17:40:12 +02001170 (!lws_check_opt(vh->context->options, LWS_SERVER_OPTION_DISABLE_IPV6) && \
Andy Green2dc7dde2016-06-03 21:19:40 +08001171 !lws_check_opt(vh->options, LWS_SERVER_OPTION_DISABLE_IPV6))
James Devine3f13ea22014-03-24 16:09:25 +08001172#else
1173#define LWS_IPV6_ENABLED(context) (0)
1174#endif
Andrew Canaday9769f4f2014-03-23 13:25:07 +08001175
Yeonjun Lim3c6a8c12016-03-30 22:47:02 -07001176#ifdef LWS_USE_UNIX_SOCK
Andy Green144594d2016-04-14 12:11:51 +08001177#define LWS_UNIX_SOCK_ENABLED(vhost) \
1178 (vhost->options & LWS_SERVER_OPTION_UNIX_SOCK)
Yeonjun Lim3c6a8c12016-03-30 22:47:02 -07001179#else
Andy Green144594d2016-04-14 12:11:51 +08001180#define LWS_UNIX_SOCK_ENABLED(vhost) (0)
Yeonjun Lim3c6a8c12016-03-30 22:47:02 -07001181#endif
Andy Green3ff720f2017-06-20 11:46:49 +08001182
Andy Greenc70f6692017-06-20 15:56:48 +08001183typedef union {
1184#ifdef LWS_USE_IPV6
1185 struct sockaddr_in6 sa6;
1186#endif
1187 struct sockaddr_in sa4;
1188} sockaddr46;
1189
Andy Greenb1a9e502013-11-10 15:15:21 +08001190enum uri_path_states {
1191 URIPS_IDLE,
1192 URIPS_SEEN_SLASH,
1193 URIPS_SEEN_SLASH_DOT,
1194 URIPS_SEEN_SLASH_DOT_DOT,
1195};
1196
1197enum uri_esc_states {
1198 URIES_IDLE,
1199 URIES_SEEN_PERCENT,
1200 URIES_SEEN_PERCENT_H1,
1201};
Andy Greenf3d3b402011-02-09 07:16:34 +00001202
Andy Green024eb6c2014-10-08 12:00:53 +08001203/* notice that these union members:
Andy Green40110e82015-12-14 08:52:03 +08001204 *
Andy Green024eb6c2014-10-08 12:00:53 +08001205 * hdr
1206 * http
1207 * http2
Andy Green40110e82015-12-14 08:52:03 +08001208 *
Andy Green024eb6c2014-10-08 12:00:53 +08001209 * all have a pointer to allocated_headers struct as their first member.
Andy Green40110e82015-12-14 08:52:03 +08001210 *
Andy Green024eb6c2014-10-08 12:00:53 +08001211 * It means for allocated_headers access, the three union paths can all be
Peter Pentchevbb085da2015-12-03 15:55:11 +02001212 * used interchangeably to access the same data
Andy Green024eb6c2014-10-08 12:00:53 +08001213 */
1214
Andy Greena661ee52016-02-29 13:18:30 +08001215
1216#ifndef LWS_NO_CLIENT
1217struct client_info_stash {
1218 char address[256];
sjames1958gm0fdca9f2016-11-21 09:23:17 -06001219 char path[4096];
Andy Greena661ee52016-02-29 13:18:30 +08001220 char host[256];
1221 char origin[256];
1222 char protocol[256];
1223 char method[16];
Andy Green449eec92017-06-14 09:45:30 +08001224 char iface[16];
Andy Greena661ee52016-02-29 13:18:30 +08001225};
1226#endif
1227
Andy Green2d8d35a2016-02-29 14:19:16 +08001228struct _lws_header_related {
1229 /* MUST be first in struct */
1230 struct allocated_headers *ah;
1231 struct lws *ah_wait_list;
1232 unsigned char *preamble_rx;
1233#ifndef LWS_NO_CLIENT
1234 struct client_info_stash *stash;
1235#endif
1236 unsigned int preamble_rx_len;
1237 enum uri_path_states ups;
1238 enum uri_esc_states ues;
1239 short lextable_pos;
Andy Green48895662016-06-02 12:32:38 +08001240 unsigned int current_token_limit;
Andy Green3e0006c2017-02-22 06:55:12 +08001241
Andy Green2d8d35a2016-02-29 14:19:16 +08001242 char esc_stash;
1243 char post_literal_equal;
1244 unsigned char parser_state; /* enum lws_token_indexes */
Andy Green2d8d35a2016-02-29 14:19:16 +08001245};
1246
Andy Greened4acef2016-12-12 13:36:25 +08001247#if defined(LWS_WITH_RANGES)
1248enum range_states {
1249 LWSRS_NO_ACTIVE_RANGE,
1250 LWSRS_BYTES_EQ,
1251 LWSRS_FIRST,
1252 LWSRS_STARTING,
1253 LWSRS_ENDING,
1254 LWSRS_COMPLETED,
1255 LWSRS_SYNTAX,
1256};
1257
1258struct lws_range_parsing {
1259 unsigned long long start, end, extent, agg, budget;
1260 const char buf[128];
1261 int pos;
1262 enum range_states state;
1263 char start_valid, end_valid, ctr, count_ranges, did_try, inside, send_ctr;
1264};
1265
1266int
1267lws_ranges_init(struct lws *wsi, struct lws_range_parsing *rp, unsigned long long extent);
1268int
1269lws_ranges_next(struct lws_range_parsing *rp);
1270void
1271lws_ranges_reset(struct lws_range_parsing *rp);
1272#endif
1273
Andy Green84fd9492013-11-09 11:40:32 +08001274struct _lws_http_mode_related {
Andy Green024eb6c2014-10-08 12:00:53 +08001275 /* MUST be first in struct */
Andy Green84fd9492013-11-09 11:40:32 +08001276 struct allocated_headers *ah; /* mirroring _lws_header_related */
Andy Green8c1f6022016-01-26 20:56:56 +08001277 struct lws *ah_wait_list;
Andy Green2d8d35a2016-02-29 14:19:16 +08001278 unsigned char *preamble_rx;
1279#ifndef LWS_NO_CLIENT
1280 struct client_info_stash *stash;
1281#endif
1282 unsigned int preamble_rx_len;
Andy Green8c1f6022016-01-26 20:56:56 +08001283 struct lws *new_wsi_list;
Andy Green1789d0a2017-02-25 12:42:45 +08001284 lws_filepos_t filepos;
1285 lws_filepos_t filelen;
1286 lws_fop_fd_t fop_fd;
kapejodce64fb02013-11-19 13:38:16 +01001287
Andy Greened4acef2016-12-12 13:36:25 +08001288#if defined(LWS_WITH_RANGES)
1289 struct lws_range_parsing range;
1290 char multipart_content_type[64];
1291#endif
1292
Andrew Canadayafe26cf2014-07-13 01:07:36 -04001293 enum http_version request_version;
1294 enum http_connection_type connection_type;
Andy Green02638f62017-06-07 07:57:19 +08001295 lws_filepos_t content_length;
1296 lws_filepos_t content_remain;
Andy Green84fd9492013-11-09 11:40:32 +08001297};
1298
Andy Green024eb6c2014-10-08 12:00:53 +08001299#ifdef LWS_USE_HTTP2
1300
1301enum lws_http2_settings {
1302 LWS_HTTP2_SETTINGS__HEADER_TABLE_SIZE = 1,
1303 LWS_HTTP2_SETTINGS__ENABLE_PUSH,
1304 LWS_HTTP2_SETTINGS__MAX_CONCURRENT_STREAMS,
1305 LWS_HTTP2_SETTINGS__INITIAL_WINDOW_SIZE,
1306 LWS_HTTP2_SETTINGS__MAX_FRAME_SIZE,
1307 LWS_HTTP2_SETTINGS__MAX_HEADER_LIST_SIZE,
Andy Green40110e82015-12-14 08:52:03 +08001308
Andy Green024eb6c2014-10-08 12:00:53 +08001309 LWS_HTTP2_SETTINGS__COUNT /* always last */
Andy Greena54f2322014-09-30 09:43:14 +08001310};
1311
Andy Green024eb6c2014-10-08 12:00:53 +08001312enum lws_http2_wellknown_frame_types {
1313 LWS_HTTP2_FRAME_TYPE_DATA,
1314 LWS_HTTP2_FRAME_TYPE_HEADERS,
1315 LWS_HTTP2_FRAME_TYPE_PRIORITY,
1316 LWS_HTTP2_FRAME_TYPE_RST_STREAM,
1317 LWS_HTTP2_FRAME_TYPE_SETTINGS,
1318 LWS_HTTP2_FRAME_TYPE_PUSH_PROMISE,
1319 LWS_HTTP2_FRAME_TYPE_PING,
1320 LWS_HTTP2_FRAME_TYPE_GOAWAY,
1321 LWS_HTTP2_FRAME_TYPE_WINDOW_UPDATE,
1322 LWS_HTTP2_FRAME_TYPE_CONTINUATION,
Andy Green40110e82015-12-14 08:52:03 +08001323
Andy Green024eb6c2014-10-08 12:00:53 +08001324 LWS_HTTP2_FRAME_TYPE_COUNT /* always last */
1325};
1326
Andy Green91b05892014-10-17 08:38:44 +08001327enum lws_http2_flags {
1328 LWS_HTTP2_FLAG_END_STREAM = 1,
1329 LWS_HTTP2_FLAG_END_HEADERS = 4,
1330 LWS_HTTP2_FLAG_PADDED = 8,
1331 LWS_HTTP2_FLAG_PRIORITY = 0x20,
1332
1333 LWS_HTTP2_FLAG_SETTINGS_ACK = 1,
1334};
1335
Andy Green024eb6c2014-10-08 12:00:53 +08001336#define LWS_HTTP2_STREAM_ID_MASTER 0
1337#define LWS_HTTP2_FRAME_HEADER_LENGTH 9
1338#define LWS_HTTP2_SETTINGS_LENGTH 6
1339
1340struct http2_settings {
1341 unsigned int setting[LWS_HTTP2_SETTINGS__COUNT];
1342};
1343
Andy Greenecc2e722014-10-09 16:57:47 +08001344enum http2_hpack_state {
Andy Green40110e82015-12-14 08:52:03 +08001345
Andy Green200f3852014-10-18 12:23:05 +08001346 /* optional before first header block */
1347 HPKS_OPT_PADDING,
1348 HKPS_OPT_E_DEPENDENCY,
1349 HKPS_OPT_WEIGHT,
Andy Green40110e82015-12-14 08:52:03 +08001350
Andy Green200f3852014-10-18 12:23:05 +08001351 /* header block */
Andy Greenecc2e722014-10-09 16:57:47 +08001352 HPKS_TYPE,
Andy Green40110e82015-12-14 08:52:03 +08001353
Andy Green2add6342014-10-12 08:38:16 +08001354 HPKS_IDX_EXT,
Andy Green40110e82015-12-14 08:52:03 +08001355
Andy Greenecc2e722014-10-09 16:57:47 +08001356 HPKS_HLEN,
1357 HPKS_HLEN_EXT,
1358
1359 HPKS_DATA,
Andy Green40110e82015-12-14 08:52:03 +08001360
Andy Green200f3852014-10-18 12:23:05 +08001361 /* optional after last header block */
1362 HKPS_OPT_DISCARD_PADDING,
Andy Greenecc2e722014-10-09 16:57:47 +08001363};
1364
Andy Green2add6342014-10-12 08:38:16 +08001365enum http2_hpack_type {
1366 HPKT_INDEXED_HDR_7,
1367 HPKT_INDEXED_HDR_6_VALUE_INCR,
1368 HPKT_LITERAL_HDR_VALUE_INCR,
1369 HPKT_INDEXED_HDR_4_VALUE,
1370 HPKT_LITERAL_HDR_VALUE,
1371 HPKT_SIZE_5
1372};
1373
Andy Green200f3852014-10-18 12:23:05 +08001374struct hpack_dt_entry {
1375 int token; /* additions that don't map to a token are ignored */
1376 int arg_offset;
1377 int arg_len;
1378};
1379
1380struct hpack_dynamic_table {
1381 struct hpack_dt_entry *entries;
1382 char *args;
1383 int pos;
1384 int next;
1385 int num_entries;
1386 int args_length;
1387};
1388
Andy Green024eb6c2014-10-08 12:00:53 +08001389struct _lws_http2_related {
Andy Green40110e82015-12-14 08:52:03 +08001390 /*
Andy Green024eb6c2014-10-08 12:00:53 +08001391 * having this first lets us also re-use all HTTP union code
1392 * and in turn, http_mode_related has allocated headers in right
1393 * place so we can use the header apis on the wsi directly still
1394 */
1395 struct _lws_http_mode_related http; /* MUST BE FIRST IN STRUCT */
1396
1397 struct http2_settings my_settings;
1398 struct http2_settings peer_settings;
Andy Green40110e82015-12-14 08:52:03 +08001399
Andy Green4b85c1d2015-12-04 11:08:32 +08001400 struct lws *parent_wsi;
1401 struct lws *next_child_wsi;
Andy Green024eb6c2014-10-08 12:00:53 +08001402
Andy Green200f3852014-10-18 12:23:05 +08001403 struct hpack_dynamic_table *hpack_dyn_table;
Andy Greenaa775fd2015-12-26 08:56:58 +08001404 struct lws *stream_wsi;
1405 unsigned char ping_payload[8];
1406 unsigned char one_setting[LWS_HTTP2_SETTINGS_LENGTH];
Andy Green40110e82015-12-14 08:52:03 +08001407
Andy Green024eb6c2014-10-08 12:00:53 +08001408 unsigned int count;
Andy Green024eb6c2014-10-08 12:00:53 +08001409 unsigned int length;
1410 unsigned int stream_id;
Andy Greenaa775fd2015-12-26 08:56:58 +08001411 enum http2_hpack_state hpack;
1412 enum http2_hpack_type hpack_type;
1413 unsigned int header_index;
1414 unsigned int hpack_len;
1415 unsigned int hpack_e_dep;
1416 int tx_credit;
1417 unsigned int my_stream_id;
1418 unsigned int child_count;
1419 int my_priority;
Andy Green67112662016-01-11 11:34:01 +08001420
Andy Green91b05892014-10-17 08:38:44 +08001421 unsigned int END_STREAM:1;
1422 unsigned int END_HEADERS:1;
Andy Green1cea5812014-10-19 07:36:20 +08001423 unsigned int send_END_STREAM:1;
Andy Green7df53c52014-10-22 15:37:28 +08001424 unsigned int GOING_AWAY;
1425 unsigned int requested_POLLOUT:1;
Andy Green97ee57f2014-10-29 09:39:08 +08001426 unsigned int waiting_tx_credit:1;
Andy Greenecc2e722014-10-09 16:57:47 +08001427 unsigned int huff:1;
1428 unsigned int value:1;
Andy Green40110e82015-12-14 08:52:03 +08001429
Andy Greenaa775fd2015-12-26 08:56:58 +08001430 unsigned short round_robin_POLLOUT;
1431 unsigned short count_POLLOUT_children;
1432 unsigned short hpack_pos;
1433
1434 unsigned char type;
1435 unsigned char flags;
1436 unsigned char frame_state;
1437 unsigned char padding;
1438 unsigned char hpack_m;
Andy Green024eb6c2014-10-08 12:00:53 +08001439 unsigned char initialized;
Andy Green024eb6c2014-10-08 12:00:53 +08001440};
1441
Andy Green7df53c52014-10-22 15:37:28 +08001442#define HTTP2_IS_TOPLEVEL_WSI(wsi) (!wsi->u.http2.parent_wsi)
Andy Green024eb6c2014-10-08 12:00:53 +08001443
1444#endif
1445
Andy Green623a98d2013-01-21 11:04:23 +08001446struct _lws_websocket_related {
Andy Green2c218e72016-02-15 12:37:04 +08001447 /* cheapest way to deal with ah overlap with ws union transition */
Andy Green26d42492016-02-24 12:40:21 +08001448 struct _lws_header_related hdr;
Andy Green67112662016-01-11 11:34:01 +08001449 char *rx_ubuf;
Andy Green4019aab2016-01-30 11:43:10 +08001450 unsigned int rx_ubuf_alloc;
Andy Green67112662016-01-11 11:34:01 +08001451 struct lws *rx_draining_ext_list;
1452 struct lws *tx_draining_ext_list;
Andy Greenf32d2502016-07-15 13:41:38 +08001453 time_t time_next_ping_check;
Andy Greende132b92015-12-25 13:48:20 +08001454 size_t rx_packet_length;
Andy Green67112662016-01-11 11:34:01 +08001455 unsigned int rx_ubuf_head;
1456 unsigned char mask[4];
Andy Green1fb95e82015-12-26 17:20:34 +08001457 /* Also used for close content... control opcode == < 128 */
Andy Green67112662016-01-11 11:34:01 +08001458 unsigned char ping_payload_buf[128 - 3 + LWS_PRE];
Andy Green1fb95e82015-12-26 17:20:34 +08001459
Andy Greenaa775fd2015-12-26 08:56:58 +08001460 unsigned char ping_payload_len;
Andy Green67112662016-01-11 11:34:01 +08001461 unsigned char mask_idx;
Andy Green623a98d2013-01-21 11:04:23 +08001462 unsigned char opcode;
Andy Green623a98d2013-01-21 11:04:23 +08001463 unsigned char rsv;
Andy Green67112662016-01-11 11:34:01 +08001464 unsigned char rsv_first_msg;
Andy Green1fb95e82015-12-26 17:20:34 +08001465 /* zero if no info, or length including 2-byte close code */
1466 unsigned char close_in_ping_buffer_len;
Andy Green0c7b38b2015-12-29 09:46:03 +08001467 unsigned char utf8;
Andy Green67112662016-01-11 11:34:01 +08001468 unsigned char stashed_write_type;
1469 unsigned char tx_draining_stashed_wp;
Andy Greende132b92015-12-25 13:48:20 +08001470
1471 unsigned int final:1;
Andy Greend91d5e82013-02-10 16:00:47 +08001472 unsigned int frame_is_binary:1;
Andy Greend91d5e82013-02-10 16:00:47 +08001473 unsigned int all_zero_nonce:1;
Andy Greend91d5e82013-02-10 16:00:47 +08001474 unsigned int this_frame_masked:1;
Andy Green1f4267b2013-10-17 08:09:19 +08001475 unsigned int inside_frame:1; /* next write will be more of frame */
1476 unsigned int clean_buffer:1; /* buffer not rewritten by extension */
Andy Green40d5abc2015-04-17 20:29:58 +08001477 unsigned int payload_is_close:1; /* process as PONG, but it is close */
Andy Greenba38a7e2015-12-25 13:14:09 +08001478 unsigned int ping_pending_flag:1;
Andy Green977734e2015-12-28 16:51:08 +08001479 unsigned int continuation_possible:1;
Andy Green91d624e2015-12-28 17:05:40 +08001480 unsigned int owed_a_fin:1;
Andy Green9b81d3c2015-12-29 12:28:48 +08001481 unsigned int check_utf8:1;
1482 unsigned int defeat_check_utf8:1;
Andy Green67112662016-01-11 11:34:01 +08001483 unsigned int pmce_compressed_message:1;
1484 unsigned int stashed_write_pending:1;
1485 unsigned int rx_draining_ext:1;
1486 unsigned int tx_draining_ext:1;
Andy Greenf32d2502016-07-15 13:41:38 +08001487 unsigned int send_check_ping:1;
Andy Green6f11c132017-07-19 04:39:14 +08001488 unsigned int first_fragment:1;
Andy Green623a98d2013-01-21 11:04:23 +08001489};
1490
Andy Green6a8099b2016-02-21 21:25:48 +08001491#ifdef LWS_WITH_CGI
1492
Petar Paradzikafc9c0a2017-08-26 12:00:24 +08001493#define LWS_HTTP_CHUNK_HDR_SIZE 16
1494
Andy Greende12c862017-05-18 21:19:57 +08001495enum {
1496 SIGNIFICANT_HDR_CONTENT_LENGTH,
1497 SIGNIFICANT_HDR_LOCATION,
1498 SIGNIFICANT_HDR_STATUS,
Andy Green38449882017-05-19 08:33:33 +08001499 SIGNIFICANT_HDR_TRANSFER_ENCODING,
Andy Greende12c862017-05-18 21:19:57 +08001500
1501 SIGNIFICANT_HDR_COUNT
1502};
1503
Andy Green6a8099b2016-02-21 21:25:48 +08001504/* wsi who is master of the cgi points to an lws_cgi */
1505
1506struct lws_cgi {
1507 struct lws_cgi *cgi_list;
1508 struct lws *stdwsi[3]; /* points to the associated stdin/out/err wsis */
1509 struct lws *wsi; /* owner */
Andy Greende12c862017-05-18 21:19:57 +08001510 unsigned char *headers_buf;
1511 unsigned char *headers_pos;
1512 unsigned char *headers_dumped;
1513 unsigned char *headers_end;
Andy Green02638f62017-06-07 07:57:19 +08001514 lws_filepos_t content_length;
1515 lws_filepos_t content_length_seen;
Andy Green6a8099b2016-02-21 21:25:48 +08001516 int pipe_fds[3][2];
Andy Greende12c862017-05-18 21:19:57 +08001517 int match[SIGNIFICANT_HDR_COUNT];
Andy Green6a8099b2016-02-21 21:25:48 +08001518 int pid;
Andy Greende12c862017-05-18 21:19:57 +08001519 int response_code;
1520 int lp;
1521 char l[12];
Andy Green6a8099b2016-02-21 21:25:48 +08001522
1523 unsigned int being_closed:1;
Andy Green38449882017-05-19 08:33:33 +08001524 unsigned int explicitly_chunked:1;
Andy Greena0c4a0e2017-01-03 08:18:37 +08001525
1526 unsigned char chunked_grace;
Andy Green6a8099b2016-02-21 21:25:48 +08001527};
Andy Green5c8906e2016-03-13 16:44:19 +08001528#endif
Andy Greenc3c2d6d2016-03-09 07:41:59 +08001529
Andy Green5c8906e2016-03-13 16:44:19 +08001530signed char char_to_hex(const char c);
1531
1532#ifndef LWS_NO_CLIENT
1533enum lws_chunk_parser {
1534 ELCP_HEX,
1535 ELCP_CR,
1536 ELCP_CONTENT,
1537 ELCP_POST_CR,
1538 ELCP_POST_LF,
1539};
Andy Green6a8099b2016-02-21 21:25:48 +08001540#endif
1541
Andy Green1e5a9ad2016-03-20 11:59:53 +08001542struct lws_rewrite;
1543
Andy Green2f0bc932016-04-15 12:00:23 +08001544#ifdef LWS_WITH_ACCESS_LOG
1545struct lws_access_log {
1546 char *header_log;
1547 char *user_agent;
Andy Greendebb7aa2017-08-27 20:18:48 +08001548 char *referrer;
Andy Green2f0bc932016-04-15 12:00:23 +08001549 unsigned long sent;
1550 int response;
1551};
1552#endif
1553
Andy Green4b85c1d2015-12-04 11:08:32 +08001554struct lws {
Andy Green623a98d2013-01-21 11:04:23 +08001555
Andy Greenaa775fd2015-12-26 08:56:58 +08001556 /* structs */
1557 /* members with mutually exclusive lifetimes are unionized */
1558
1559 union u {
1560 struct _lws_http_mode_related http;
1561#ifdef LWS_USE_HTTP2
1562 struct _lws_http2_related http2;
1563#endif
1564 struct _lws_header_related hdr;
1565 struct _lws_websocket_related ws;
1566 } u;
1567
Andy Green623a98d2013-01-21 11:04:23 +08001568 /* lifetime members */
1569
Aditya Tirumalaec50eba2017-03-15 19:41:11 +05301570#if defined(LWS_USE_LIBEV) || defined(LWS_USE_LIBUV) || defined(LWS_USE_LIBEVENT)
Andy Green40110e82015-12-14 08:52:03 +08001571 struct lws_io_watcher w_read;
Andy Green86ed65f2016-02-14 09:27:41 +08001572#endif
Aditya Tirumalaec50eba2017-03-15 19:41:11 +05301573#if defined(LWS_USE_LIBEV) || defined(LWS_USE_LIBEVENT)
Andy Green40110e82015-12-14 08:52:03 +08001574 struct lws_io_watcher w_write;
Andy Green86ed65f2016-02-14 09:27:41 +08001575#endif
Andy Greende132b92015-12-25 13:48:20 +08001576 time_t pending_timeout_limit;
Andy Greenaa775fd2015-12-26 08:56:58 +08001577
1578 /* pointers */
1579
Andy Green40110e82015-12-14 08:52:03 +08001580 struct lws_context *context;
Andy Greend526c502016-03-28 10:10:43 +08001581 struct lws_vhost *vhost;
Andy Green494418a2016-03-02 09:17:22 +08001582 struct lws *parent; /* points to parent, if any */
1583 struct lws *child_list; /* points to first child */
1584 struct lws *sibling_list; /* subsequent children at same level */
Andy Green6a8099b2016-02-21 21:25:48 +08001585#ifdef LWS_WITH_CGI
1586 struct lws_cgi *cgi; /* wsi being cgi master have one of these */
Andy Green6a8099b2016-02-21 21:25:48 +08001587#endif
Andy Green4b85c1d2015-12-04 11:08:32 +08001588 const struct lws_protocols *protocol;
Andy Green4714cf02016-04-16 08:40:35 +08001589 struct lws **same_vh_protocol_prev, *same_vh_protocol_next;
Andy Greend738f842016-01-19 04:32:14 +08001590 struct lws *timeout_list;
1591 struct lws **timeout_list_prev;
Andy Green2f0bc932016-04-15 12:00:23 +08001592#ifdef LWS_WITH_ACCESS_LOG
1593 struct lws_access_log access_log;
1594#endif
Andy Greende132b92015-12-25 13:48:20 +08001595 void *user_space;
Andy Green6f11c132017-07-19 04:39:14 +08001596 void *opaque_parent_data;
Andy Greende132b92015-12-25 13:48:20 +08001597 /* rxflow handling */
1598 unsigned char *rxflow_buffer;
1599 /* truncated send handling */
1600 unsigned char *trunc_alloc; /* non-NULL means buffering in progress */
Andy Green7acf76c2016-07-23 14:18:25 +08001601
1602#if defined (LWS_WITH_ESP8266)
1603 void *premature_rx;
1604 unsigned short prem_rx_size, prem_rx_pos;
1605#endif
1606
Andy Green3182ece2013-01-20 17:08:31 +08001607#ifndef LWS_NO_EXTENSIONS
Andy Greend2ac22c2015-12-11 10:45:35 +08001608 const struct lws_extension *active_extensions[LWS_MAX_EXTENSIONS_ACTIVE];
Andy Green67112662016-01-11 11:34:01 +08001609 void *act_ext_user[LWS_MAX_EXTENSIONS_ACTIVE];
Andy Green3182ece2013-01-20 17:08:31 +08001610#endif
Andy Greende132b92015-12-25 13:48:20 +08001611#ifdef LWS_OPENSSL_SUPPORT
1612 SSL *ssl;
1613 BIO *client_bio;
1614 struct lws *pending_read_list_prev, *pending_read_list_next;
Andy Greena7def3c2017-05-07 10:02:03 +08001615#if defined(LWS_WITH_STATS)
1616 uint64_t accept_start_us;
Andy Greenb2f8bc52017-05-13 10:26:59 +08001617 char seen_rx;
Andy Greena7def3c2017-05-07 10:02:03 +08001618#endif
Andy Greende132b92015-12-25 13:48:20 +08001619#endif
Andy Green1a138852016-03-20 11:55:25 +08001620#ifdef LWS_WITH_HTTP_PROXY
Andy Green1e5a9ad2016-03-20 11:59:53 +08001621 struct lws_rewrite *rw;
1622#endif
Andy Greenaa775fd2015-12-26 08:56:58 +08001623#ifdef LWS_LATENCY
1624 unsigned long action_start;
1625 unsigned long latency_start;
1626#endif
Andy Greenbe8d7912017-02-27 12:55:56 +08001627 lws_sock_file_fd_type desc; /* .filefd / .sockfd */
Andy Greena7def3c2017-05-07 10:02:03 +08001628#if defined(LWS_WITH_STATS)
1629 uint64_t active_writable_req_us;
1630#endif
Andy Greenaa775fd2015-12-26 08:56:58 +08001631 /* ints */
Andy Greendfb23042013-01-17 12:26:48 +08001632 int position_in_fds_table;
Andy Green024eb6c2014-10-08 12:00:53 +08001633 int rxflow_len;
1634 int rxflow_pos;
Andy Green54806b12015-12-17 17:03:59 +08001635 unsigned int trunc_alloc_len; /* size of malloc */
1636 unsigned int trunc_offset; /* where we are in terms of spilling */
1637 unsigned int trunc_len; /* how much is buffered */
Andy Green5c8906e2016-03-13 16:44:19 +08001638#ifndef LWS_NO_CLIENT
1639 int chunk_remaining;
1640#endif
Andy Green42e8b182016-04-22 08:53:49 +08001641 unsigned int cache_secs;
Andy Green2764eba2013-12-09 14:16:17 +08001642
Andy Greende132b92015-12-25 13:48:20 +08001643 unsigned int hdr_parsing_completed:1;
Andy Green22d6f392016-04-10 09:33:54 +08001644 unsigned int http2_substream:1;
Andy Greend526c502016-03-28 10:10:43 +08001645 unsigned int listener:1;
Andy Greende132b92015-12-25 13:48:20 +08001646 unsigned int user_space_externally_allocated:1;
1647 unsigned int socket_is_permanently_unusable:1;
1648 unsigned int rxflow_change_to:2;
Andy Green83af28a2016-02-28 10:55:31 +08001649 unsigned int more_rx_waiting:1; /* has to live here since ah may stick to end */
Andy Green98061402016-04-15 14:01:29 +08001650 unsigned int conn_stat_done:1;
Andy Green42e8b182016-04-22 08:53:49 +08001651 unsigned int cache_reuse:1;
1652 unsigned int cache_revalidate:1;
1653 unsigned int cache_intermediaries:1;
Andy Green2f216282016-04-23 09:26:11 +08001654 unsigned int favoured_pollin:1;
Andy Green7a2fc442016-05-19 15:28:31 +08001655 unsigned int sending_chunked:1;
Andy Green81c221e2016-07-01 08:54:39 +08001656 unsigned int already_did_cce:1;
Andy Green723b3f12016-09-06 15:36:51 +08001657 unsigned int told_user_closed:1;
Andy Green3b0066c2017-07-17 10:11:17 +08001658 unsigned int waiting_to_send_close_frame:1;
Andy Greenc70f6692017-06-20 15:56:48 +08001659 unsigned int ipv6:1;
Andy Green6f11c132017-07-19 04:39:14 +08001660 unsigned int parent_carries_io:1;
1661 unsigned int parent_pending_cb_on_writable:1;
Andy Green89212d62017-04-05 08:30:55 +08001662
Andy Green7acf76c2016-07-23 14:18:25 +08001663#if defined(LWS_WITH_ESP8266)
1664 unsigned int pending_send_completion:3;
1665 unsigned int close_is_pending_send_completion:1;
1666#endif
Andy Green2f0bc932016-04-15 12:00:23 +08001667#ifdef LWS_WITH_ACCESS_LOG
1668 unsigned int access_log_pending:1;
1669#endif
Andy Greena661ee52016-02-29 13:18:30 +08001670#ifndef LWS_NO_CLIENT
1671 unsigned int do_ws:1; /* whether we are doing http or ws flow */
Andy Green5c8906e2016-03-13 16:44:19 +08001672 unsigned int chunked:1; /* if the clientside connection is chunked */
Andy Green1e5a9ad2016-03-20 11:59:53 +08001673 unsigned int client_rx_avail:1;
Andy Green95fff472016-08-08 21:54:30 +08001674 unsigned int client_http_body_pending:1;
Andy Green1a138852016-03-20 11:55:25 +08001675#endif
1676#ifdef LWS_WITH_HTTP_PROXY
Andy Green1e5a9ad2016-03-20 11:59:53 +08001677 unsigned int perform_rewrite:1;
Andy Greena661ee52016-02-29 13:18:30 +08001678#endif
Andy Greende132b92015-12-25 13:48:20 +08001679#ifndef LWS_NO_EXTENSIONS
1680 unsigned int extension_data_pending:1;
1681#endif
1682#ifdef LWS_OPENSSL_SUPPORT
Namowen40d37e22017-02-18 07:51:27 +08001683 unsigned int use_ssl:4;
Andy Greende132b92015-12-25 13:48:20 +08001684#endif
Andy Greenaa775fd2015-12-26 08:56:58 +08001685#ifdef _WIN32
1686 unsigned int sock_send_blocking:1;
1687#endif
Andy Green0f9904f2016-03-17 15:26:49 +08001688#ifdef LWS_OPENSSL_SUPPORT
1689 unsigned int redirect_to_https:1;
1690#endif
Andy Greende132b92015-12-25 13:48:20 +08001691
Andy Green89212d62017-04-05 08:30:55 +08001692 /* volatile to make sure code is aware other thread can change */
1693 volatile unsigned int handling_pollout:1;
1694 volatile unsigned int leave_pollout_active:1;
1695
Andy Green3e0006c2017-02-22 06:55:12 +08001696#ifndef LWS_NO_CLIENT
1697 unsigned short c_port;
1698#endif
1699
Andy Greenaa775fd2015-12-26 08:56:58 +08001700 /* chars */
Andy Greende132b92015-12-25 13:48:20 +08001701#ifndef LWS_NO_EXTENSIONS
Andy Green67112662016-01-11 11:34:01 +08001702 unsigned char count_act_ext;
Andy Greende132b92015-12-25 13:48:20 +08001703#endif
1704 unsigned char ietf_spec_revision;
1705 char mode; /* enum connection_mode */
1706 char state; /* enum lws_connection_states */
Andy Green8c1f6022016-01-26 20:56:56 +08001707 char state_pre_close;
Andy Greende132b92015-12-25 13:48:20 +08001708 char lws_rx_parse_state; /* enum lws_rx_parse_state */
1709 char rx_frame_type; /* enum lws_write_protocol */
1710 char pending_timeout; /* enum pending_timeout */
Andy Greend738f842016-01-19 04:32:14 +08001711 char pps; /* enum lws_pending_protocol_send */
Andy Greend3a55052016-01-19 03:34:24 +08001712 char tsi; /* thread service index we belong to */
Andy Green7a2fc442016-05-19 15:28:31 +08001713 char protocol_interpret_idx;
Andy Green3e0006c2017-02-22 06:55:12 +08001714 char redirects;
Andy Green6a8099b2016-02-21 21:25:48 +08001715#ifdef LWS_WITH_CGI
1716 char cgi_channel; /* which of stdin/out/err */
Andy Greenc3c2d6d2016-03-09 07:41:59 +08001717 char hdr_state;
Andy Green6a8099b2016-02-21 21:25:48 +08001718#endif
Andy Green5c8906e2016-03-13 16:44:19 +08001719#ifndef LWS_NO_CLIENT
1720 char chunk_parser; /* enum lws_chunk_parser */
1721#endif
Andy Green0a4da2c2016-05-10 10:16:52 +08001722#if defined(LWS_WITH_CGI) || !defined(LWS_NO_CLIENT)
1723 char reason_bf; /* internal writeable callback reason bitfield */
1724#endif
Andy Green7c212cc2010-11-08 20:20:42 +00001725};
1726
Andy Green3d67f512014-04-03 07:29:50 +08001727LWS_EXTERN int log_level;
1728
Andy Greenc7939442016-03-12 08:18:58 +08001729LWS_EXTERN int
Andy Green53bed782016-11-16 08:59:47 +08001730lws_socket_bind(struct lws_vhost *vhost, lws_sockfd_type sockfd, int port,
Andy Greenc7939442016-03-12 08:18:58 +08001731 const char *iface);
1732
Leonardo Maccari Rufinoaf7f9432017-06-05 13:59:22 -03001733#if defined(LWS_USE_IPV6)
1734LWS_EXTERN unsigned long
1735lws_get_addr_scope(const char *ipaddr);
1736#endif
1737
Joakim Soderbergf272cb02013-02-13 09:29:26 +08001738LWS_EXTERN void
Andy Green6b5de702015-12-15 21:15:58 +08001739lws_close_free_wsi(struct lws *wsi, enum lws_close_status);
Andy Green508946c2013-02-12 10:19:08 +08001740
Andy Green34f3dd22014-04-03 07:42:50 +08001741LWS_EXTERN int
Andy Green6b5de702015-12-15 21:15:58 +08001742remove_wsi_socket_from_fds(struct lws *wsi);
Andy Green024eb6c2014-10-08 12:00:53 +08001743LWS_EXTERN int
Andy Green4b85c1d2015-12-04 11:08:32 +08001744lws_rxflow_cache(struct lws *wsi, unsigned char *buf, int n, int len);
Andy Green34f3dd22014-04-03 07:42:50 +08001745
Andy Greend636e352013-01-29 12:36:17 +08001746#ifndef LWS_LATENCY
Andy Greendc8a3a82015-12-06 09:15:27 +08001747static inline void
1748lws_latency(struct lws_context *context, struct lws *wsi, const char *action,
1749 int ret, int completion) {
Andy Green40110e82015-12-14 08:52:03 +08001750 do {
1751 (void)context; (void)wsi; (void)action; (void)ret;
1752 (void)completion;
Andy Greendc8a3a82015-12-06 09:15:27 +08001753 } while (0);
1754}
1755static inline void
1756lws_latency_pre(struct lws_context *context, struct lws *wsi) {
1757 do { (void)context; (void)wsi; } while (0);
1758}
Andy Greend636e352013-01-29 12:36:17 +08001759#else
1760#define lws_latency_pre(_context, _wsi) lws_latency(_context, _wsi, NULL, 0, 0)
1761extern void
Andy Greendc8a3a82015-12-06 09:15:27 +08001762lws_latency(struct lws_context *context, struct lws *wsi, const char *action,
1763 int ret, int completion);
Andy Greend636e352013-01-29 12:36:17 +08001764#endif
1765
Andy Greendc8a3a82015-12-06 09:15:27 +08001766LWS_EXTERN void
Andy Green6b5de702015-12-15 21:15:58 +08001767lws_set_protocol_write_pending(struct lws *wsi,
Andy Greendc8a3a82015-12-06 09:15:27 +08001768 enum lws_pending_protocol_send pend);
Andy Greene99a83c2016-01-20 16:56:06 +08001769LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green4b85c1d2015-12-04 11:08:32 +08001770lws_client_rx_sm(struct lws *wsi, unsigned char c);
Andy Green4739e5c2011-01-22 12:51:57 +00001771
Andy Greene99a83c2016-01-20 16:56:06 +08001772LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green6b5de702015-12-15 21:15:58 +08001773lws_parse(struct lws *wsi, unsigned char c);
Andy Greenb45993c2010-12-18 15:13:50 +00001774
Andy Greene99a83c2016-01-20 16:56:06 +08001775LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green6b5de702015-12-15 21:15:58 +08001776lws_http_action(struct lws *wsi);
Andy Green024eb6c2014-10-08 12:00:53 +08001777
1778LWS_EXTERN int
Andy Greendf736162011-01-18 15:39:02 +00001779lws_b64_selftest(void);
Andy Greenbfb051f2011-02-09 08:49:14 +00001780
Andy Green2c218e72016-02-15 12:37:04 +08001781LWS_EXTERN int
Andy Green2c218e72016-02-15 12:37:04 +08001782lws_service_flag_pending(struct lws_context *context, int tsi);
1783
Andy Green0aed7a02017-02-22 09:50:11 +08001784#if defined(_WIN32) || defined(LWS_WITH_ESP8266)
Andy Green4b85c1d2015-12-04 11:08:32 +08001785LWS_EXTERN struct lws *
Andy Green1fa76852015-12-14 11:17:16 +08001786wsi_from_fd(const struct lws_context *context, lws_sockfd_type fd);
Andy Green0d338332011-02-12 11:57:43 +00001787
Andy Green40110e82015-12-14 08:52:03 +08001788LWS_EXTERN int
Andy Green4b85c1d2015-12-04 11:08:32 +08001789insert_wsi(struct lws_context *context, struct lws *wsi);
Bud Davis229bfec2015-01-30 10:13:01 +08001790
1791LWS_EXTERN int
Andy Green4b85c1d2015-12-04 11:08:32 +08001792delete_from_fd(struct lws_context *context, lws_sockfd_type fd);
Bud Davis229bfec2015-01-30 10:13:01 +08001793#else
Andy Green40110e82015-12-14 08:52:03 +08001794#define wsi_from_fd(A,B) A->lws_lookup[B]
Andy Greenbe8d7912017-02-27 12:55:56 +08001795#define insert_wsi(A,B) assert(A->lws_lookup[B->desc.sockfd] == 0); A->lws_lookup[B->desc.sockfd]=B
Bud Davis229bfec2015-01-30 10:13:01 +08001796#define delete_from_fd(A,B) A->lws_lookup[B]=0
1797#endif
1798
Andy Greene99a83c2016-01-20 16:56:06 +08001799LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Greendc8a3a82015-12-06 09:15:27 +08001800insert_wsi_socket_into_fds(struct lws_context *context, struct lws *wsi);
Darin Willitsc19456f2011-02-14 17:52:39 +00001801
Andy Greene99a83c2016-01-20 16:56:06 +08001802LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green4b85c1d2015-12-04 11:08:32 +08001803lws_issue_raw(struct lws *wsi, unsigned char *buf, size_t len);
Andy Greend44bf7f2011-03-06 10:29:38 +00001804
Andy Green95a7b5d2011-03-06 10:29:39 +00001805
Andy Greene99a83c2016-01-20 16:56:06 +08001806LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green6b5de702015-12-15 21:15:58 +08001807lws_service_timeout_check(struct lws *wsi, unsigned int sec);
Andy Greena41314f2011-05-23 10:00:03 +01001808
Andy Green3d6a1e12017-02-21 23:38:40 +08001809LWS_EXTERN void
1810lws_remove_from_timeout_list(struct lws *wsi);
1811
Andy Greene99a83c2016-01-20 16:56:06 +08001812LWS_EXTERN struct lws * LWS_WARN_UNUSED_RESULT
Andy Green6b5de702015-12-15 21:15:58 +08001813lws_client_connect_2(struct lws *wsi);
Andy Greena41314f2011-05-23 10:00:03 +01001814
Andy Greene99a83c2016-01-20 16:56:06 +08001815LWS_VISIBLE struct lws * LWS_WARN_UNUSED_RESULT
Andy Green0db9b9f2017-02-21 22:59:00 +08001816lws_client_reset(struct lws **wsi, int ssl, const char *address, int port,
Andy Greene99a83c2016-01-20 16:56:06 +08001817 const char *path, const char *host);
Andy Green809d69a2016-01-14 11:37:56 +08001818
Andy Greene99a83c2016-01-20 16:56:06 +08001819LWS_EXTERN struct lws * LWS_WARN_UNUSED_RESULT
Andy Greend526c502016-03-28 10:10:43 +08001820lws_create_new_server_wsi(struct lws_vhost *vhost);
Andy Greena41314f2011-05-23 10:00:03 +01001821
Andy Greene99a83c2016-01-20 16:56:06 +08001822LWS_EXTERN char * LWS_WARN_UNUSED_RESULT
Andy Green6b5de702015-12-15 21:15:58 +08001823lws_generate_client_handshake(struct lws *wsi, char *pkt);
Andy Greena41314f2011-05-23 10:00:03 +01001824
Joakim Soderbergf272cb02013-02-13 09:29:26 +08001825LWS_EXTERN int
Andy Green6b5de702015-12-15 21:15:58 +08001826lws_handle_POLLOUT_event(struct lws *wsi, struct lws_pollfd *pollfd);
Andy Green91b05892014-10-17 08:38:44 +08001827
Andy Green2d8d35a2016-02-29 14:19:16 +08001828LWS_EXTERN struct lws *
1829lws_client_connect_via_info2(struct lws *wsi);
1830
Andy Greencdb9bf92014-04-12 10:07:02 +08001831/*
1832 * EXTENSIONS
1833 */
1834
Andy Green3182ece2013-01-20 17:08:31 +08001835#ifndef LWS_NO_EXTENSIONS
Andy Greencdb9bf92014-04-12 10:07:02 +08001836LWS_VISIBLE void
1837lws_context_init_extensions(struct lws_context_creation_info *info,
Andy Greendc8a3a82015-12-06 09:15:27 +08001838 struct lws_context *context);
Joakim Soderbergf272cb02013-02-13 09:29:26 +08001839LWS_EXTERN int
Andy Greene99a83c2016-01-20 16:56:06 +08001840lws_any_extension_handled(struct lws *wsi, enum lws_extension_callback_reasons r,
Andy Green6ee372f2012-04-09 15:09:01 +08001841 void *v, size_t len);
Andy Greena41314f2011-05-23 10:00:03 +01001842
Andy Green2c24ec02014-04-02 19:45:42 +08001843LWS_EXTERN int
Andy Greene99a83c2016-01-20 16:56:06 +08001844lws_ext_cb_active(struct lws *wsi, int reason, void *buf, int len);
Andy Green2c24ec02014-04-02 19:45:42 +08001845LWS_EXTERN int
Andy Greene99a83c2016-01-20 16:56:06 +08001846lws_ext_cb_all_exts(struct lws_context *context, struct lws *wsi, int reason,
1847 void *arg, int len);
Andy Green67112662016-01-11 11:34:01 +08001848
Andy Green2c24ec02014-04-02 19:45:42 +08001849#else
Andy Green6b5de702015-12-15 21:15:58 +08001850#define lws_any_extension_handled(_a, _b, _c, _d) (0)
Andy Green67112662016-01-11 11:34:01 +08001851#define lws_ext_cb_active(_a, _b, _c, _d) (0)
Andy Green54806b12015-12-17 17:03:59 +08001852#define lws_ext_cb_all_exts(_a, _b, _c, _d, _e) (0)
Andy Greenb49a9952014-04-03 10:11:04 +08001853#define lws_issue_raw_ext_access lws_issue_raw
Andy Greencdb9bf92014-04-12 10:07:02 +08001854#define lws_context_init_extensions(_a, _b)
Andy Green3182ece2013-01-20 17:08:31 +08001855#endif
Andy Greena41314f2011-05-23 10:00:03 +01001856
Andy Greene99a83c2016-01-20 16:56:06 +08001857LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green6b5de702015-12-15 21:15:58 +08001858lws_client_interpret_server_handshake(struct lws *wsi);
Andy Greena41314f2011-05-23 10:00:03 +01001859
Andy Greene99a83c2016-01-20 16:56:06 +08001860LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green4b85c1d2015-12-04 11:08:32 +08001861lws_rx_sm(struct lws *wsi, unsigned char c);
Andy Greena41314f2011-05-23 10:00:03 +01001862
Andy Greenc15714f2016-09-10 04:43:07 +08001863LWS_EXTERN int
Alex Hultman599cad92016-03-17 09:34:15 +08001864lws_payload_until_length_exhausted(struct lws *wsi, unsigned char **buf, size_t *len);
1865
Andy Greene99a83c2016-01-20 16:56:06 +08001866LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Greendc8a3a82015-12-06 09:15:27 +08001867lws_issue_raw_ext_access(struct lws *wsi, unsigned char *buf, size_t len);
Andy Green09226502011-05-28 10:19:19 +01001868
Andy Green44c11612014-11-08 11:18:47 +08001869LWS_EXTERN void
Andy Green4b85c1d2015-12-04 11:08:32 +08001870lws_union_transition(struct lws *wsi, enum connection_mode mode);
Andy Green44c11612014-11-08 11:18:47 +08001871
Andy Greene99a83c2016-01-20 16:56:06 +08001872LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Denis Osvald034e5142015-12-21 18:06:38 +01001873user_callback_handle_rxflow(lws_callback_function, struct lws *wsi,
Andy Green00c6d152015-12-17 07:54:44 +08001874 enum lws_callback_reasons reason, void *user,
1875 void *in, size_t len);
Andy Green024eb6c2014-10-08 12:00:53 +08001876#ifdef LWS_USE_HTTP2
Andy Green4b85c1d2015-12-04 11:08:32 +08001877LWS_EXTERN struct lws *lws_http2_get_network_wsi(struct lws *wsi);
1878struct lws * lws_http2_get_nth_child(struct lws *wsi, int n);
Andy Green024eb6c2014-10-08 12:00:53 +08001879LWS_EXTERN int
Andy Greendc8a3a82015-12-06 09:15:27 +08001880lws_http2_interpret_settings_payload(struct http2_settings *settings,
1881 unsigned char *buf, int len);
Andy Green024eb6c2014-10-08 12:00:53 +08001882LWS_EXTERN void lws_http2_init(struct http2_settings *settings);
1883LWS_EXTERN int
Andy Green11c05bf2015-12-16 18:19:08 +08001884lws_http2_parser(struct lws *wsi, unsigned char c);
Andy Greendc8a3a82015-12-06 09:15:27 +08001885LWS_EXTERN int lws_http2_do_pps_send(struct lws_context *context,
1886 struct lws *wsi);
1887LWS_EXTERN int lws_http2_frame_write(struct lws *wsi, int type, int flags,
1888 unsigned int sid, unsigned int len,
1889 unsigned char *buf);
Andy Green4b85c1d2015-12-04 11:08:32 +08001890LWS_EXTERN struct lws *
1891lws_http2_wsi_from_id(struct lws *wsi, unsigned int sid);
Andy Green11c05bf2015-12-16 18:19:08 +08001892LWS_EXTERN int lws_hpack_interpret(struct lws *wsi,
Andy Green2add6342014-10-12 08:38:16 +08001893 unsigned char c);
Andy Green917f43a2014-10-12 14:31:47 +08001894LWS_EXTERN int
Andy Green11c05bf2015-12-16 18:19:08 +08001895lws_add_http2_header_by_name(struct lws *wsi,
Andy Greendc8a3a82015-12-06 09:15:27 +08001896 const unsigned char *name,
1897 const unsigned char *value, int length,
1898 unsigned char **p, unsigned char *end);
Andy Green917f43a2014-10-12 14:31:47 +08001899LWS_EXTERN int
Andy Green11c05bf2015-12-16 18:19:08 +08001900lws_add_http2_header_by_token(struct lws *wsi,
Andy Green917f43a2014-10-12 14:31:47 +08001901 enum lws_token_indexes token,
Andy Greendc8a3a82015-12-06 09:15:27 +08001902 const unsigned char *value, int length,
1903 unsigned char **p, unsigned char *end);
Andy Green917f43a2014-10-12 14:31:47 +08001904LWS_EXTERN int
Andy Green11c05bf2015-12-16 18:19:08 +08001905lws_add_http2_header_status(struct lws *wsi,
Andy Greendc8a3a82015-12-06 09:15:27 +08001906 unsigned int code, unsigned char **p,
Andy Green917f43a2014-10-12 14:31:47 +08001907 unsigned char *end);
Andy Green7df53c52014-10-22 15:37:28 +08001908LWS_EXTERN
Andy Green4b85c1d2015-12-04 11:08:32 +08001909void lws_http2_configure_if_upgraded(struct lws *wsi);
Andy Green7df53c52014-10-22 15:37:28 +08001910#else
1911#define lws_http2_configure_if_upgraded(x)
Andy Green024eb6c2014-10-08 12:00:53 +08001912#endif
Andy Green706961d2013-01-17 16:50:35 +08001913
Joakim Soderbergf272cb02013-02-13 09:29:26 +08001914LWS_EXTERN int
Andy Greend526c502016-03-28 10:10:43 +08001915lws_plat_set_socket_options(struct lws_vhost *vhost, lws_sockfd_type fd);
Andy Greena690cd02013-02-09 12:25:31 +08001916
Andy Piper6ff571f2016-06-28 19:01:20 +08001917LWS_EXTERN int
1918lws_plat_check_connection_error(struct lws *wsi);
1919
Andy Greene99a83c2016-01-20 16:56:06 +08001920LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Greene3d141d2016-02-27 11:42:22 +08001921lws_header_table_attach(struct lws *wsi, int autoservice);
Andy Green16ab3182013-02-10 18:02:31 +08001922
Andrew Canaday37718812014-11-07 11:20:59 +08001923LWS_EXTERN int
Andy Greene3d141d2016-02-27 11:42:22 +08001924lws_header_table_detach(struct lws *wsi, int autoservice);
Andrew Canaday37718812014-11-07 11:20:59 +08001925
Andy Green4019aab2016-01-30 11:43:10 +08001926LWS_EXTERN void
Andy Greene3d141d2016-02-27 11:42:22 +08001927lws_header_table_reset(struct lws *wsi, int autoservice);
Andy Green31c51302017-02-09 15:25:01 +08001928void
1929_lws_header_table_reset(struct allocated_headers *ah);
Andy Green4019aab2016-01-30 11:43:10 +08001930
Andy Green8f4f6922017-06-28 12:13:13 +08001931void
1932lws_header_table_force_to_detachable_state(struct lws *wsi);
1933int
1934lws_header_table_is_in_detachable_state(struct lws *wsi);
1935
Andy Greene99a83c2016-01-20 16:56:06 +08001936LWS_EXTERN char * LWS_WARN_UNUSED_RESULT
Andy Green4b85c1d2015-12-04 11:08:32 +08001937lws_hdr_simple_ptr(struct lws *wsi, enum lws_token_indexes h);
Andy Green16ab3182013-02-10 18:02:31 +08001938
Andy Greene99a83c2016-01-20 16:56:06 +08001939LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green11c05bf2015-12-16 18:19:08 +08001940lws_hdr_simple_create(struct lws *wsi, enum lws_token_indexes h, const char *s);
Andy Greenb5b23192013-02-11 17:13:32 +08001941
Andy Green16146cd2016-04-23 07:53:46 +08001942LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green4b85c1d2015-12-04 11:08:32 +08001943lws_ensure_user_space(struct lws *wsi);
Andy Green2af4d5b2013-02-18 16:30:10 +08001944
Andy Green158e8042014-04-02 14:25:10 +08001945LWS_EXTERN int
Andy Green4b85c1d2015-12-04 11:08:32 +08001946lws_change_pollfd(struct lws *wsi, int _and, int _or);
Andy Green91f19d82013-12-21 11:18:34 +08001947
Andy Greenb5b23192013-02-11 17:13:32 +08001948#ifndef LWS_NO_SERVER
Andy Greene38031a2014-04-03 08:24:29 +08001949int lws_context_init_server(struct lws_context_creation_info *info,
Andy Greend526c502016-03-28 10:10:43 +08001950 struct lws_vhost *vhost);
1951LWS_EXTERN struct lws_vhost *
1952lws_select_vhost(struct lws_context *context, int port, const char *servername);
Andy Greend7340c12014-04-10 14:08:10 +08001953LWS_EXTERN int
Andy Greendc8a3a82015-12-06 09:15:27 +08001954handshake_0405(struct lws_context *context, struct lws *wsi);
Andy Greene99a83c2016-01-20 16:56:06 +08001955LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green67112662016-01-11 11:34:01 +08001956lws_interpret_incoming_packet(struct lws *wsi, unsigned char **buf, size_t len);
Andy Greencdb9bf92014-04-12 10:07:02 +08001957LWS_EXTERN void
Andy Green4b85c1d2015-12-04 11:08:32 +08001958lws_server_get_canonical_hostname(struct lws_context *context,
Andy Greendc8a3a82015-12-06 09:15:27 +08001959 struct lws_context_creation_info *info);
Andy Greene38031a2014-04-03 08:24:29 +08001960#else
1961#define lws_context_init_server(_a, _b) (0)
Andy Green3ef579b2015-12-04 09:23:56 +08001962#define lws_interpret_incoming_packet(_a, _b, _c) (0)
Andy Greencdb9bf92014-04-12 10:07:02 +08001963#define lws_server_get_canonical_hostname(_a, _b)
Andy Greenb5b23192013-02-11 17:13:32 +08001964#endif
1965
1966#ifndef LWS_NO_DAEMONIZE
Joakim Soderbergf272cb02013-02-13 09:29:26 +08001967LWS_EXTERN int get_daemonize_pid();
Andy Greencdb9bf92014-04-12 10:07:02 +08001968#else
1969#define get_daemonize_pid() (0)
Andy Greenb5b23192013-02-11 17:13:32 +08001970#endif
1971
Andy Green0aed7a02017-02-22 09:50:11 +08001972#if !defined(LWS_WITH_ESP8266)
Andy Greene99a83c2016-01-20 16:56:06 +08001973LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green2dc7dde2016-06-03 21:19:40 +08001974interface_to_sa(struct lws_vhost *vh, const char *ifname,
Andy Greendc8a3a82015-12-06 09:15:27 +08001975 struct sockaddr_in *addr, size_t addrlen);
Andy Green2cd30742015-11-02 13:10:33 +08001976#endif
Andy Greenb25b85f2014-04-03 23:34:09 +08001977LWS_EXTERN void lwsl_emit_stderr(int level, const char *line);
1978
Andy Green1a308e42014-04-08 07:26:30 +01001979enum lws_ssl_capable_status {
1980 LWS_SSL_CAPABLE_ERROR = -1,
1981 LWS_SSL_CAPABLE_MORE_SERVICE = -2,
1982};
1983
Darin Willitsc19456f2011-02-14 17:52:39 +00001984#ifndef LWS_OPENSSL_SUPPORT
Andy Greencdb9bf92014-04-12 10:07:02 +08001985#define LWS_SSL_ENABLED(context) (0)
Andy Greenc57037a2014-04-03 10:17:00 +08001986#define lws_context_init_server_ssl(_a, _b) (0)
1987#define lws_ssl_destroy(_a)
Andy Green2eedea92014-04-03 14:33:48 +08001988#define lws_context_init_http2_ssl(_a)
Andy Green02138122014-04-06 06:26:35 +01001989#define lws_ssl_capable_read lws_ssl_capable_read_no_ssl
1990#define lws_ssl_capable_write lws_ssl_capable_write_no_ssl
=?UTF-8?q?Jos=C3=A9=20Luis=20Mill=C3=A1n?=4c0ba022015-08-19 16:23:33 +02001991#define lws_ssl_pending lws_ssl_pending_no_ssl
Andy Green8c1f6022016-01-26 20:56:56 +08001992#define lws_server_socket_service_ssl(_b, _c) (0)
Andy Greencdb9bf92014-04-12 10:07:02 +08001993#define lws_ssl_close(_a) (0)
1994#define lws_ssl_context_destroy(_a)
Andy Greend526c502016-03-28 10:10:43 +08001995#define lws_ssl_SSL_CTX_destroy(_a)
Andy Green6b5de702015-12-15 21:15:58 +08001996#define lws_ssl_remove_wsi_from_buffered_list(_a)
Andy Greend526c502016-03-28 10:10:43 +08001997#define lws_context_init_ssl_library(_a)
Andy Greenb5b23192013-02-11 17:13:32 +08001998#else
Andy Greencdb9bf92014-04-12 10:07:02 +08001999#define LWS_SSL_ENABLED(context) (context->use_ssl)
Joakim Soderbergf272cb02013-02-13 09:29:26 +08002000LWS_EXTERN int openssl_websocket_private_data_index;
Andy Greene99a83c2016-01-20 16:56:06 +08002001LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green6b5de702015-12-15 21:15:58 +08002002lws_ssl_capable_read(struct lws *wsi, unsigned char *buf, int len);
Andy Greene99a83c2016-01-20 16:56:06 +08002003LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green4b85c1d2015-12-04 11:08:32 +08002004lws_ssl_capable_write(struct lws *wsi, unsigned char *buf, int len);
Andy Greene99a83c2016-01-20 16:56:06 +08002005LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green4b85c1d2015-12-04 11:08:32 +08002006lws_ssl_pending(struct lws *wsi);
Andy Greend526c502016-03-28 10:10:43 +08002007LWS_EXTERN int
2008lws_context_init_ssl_library(struct lws_context_creation_info *info);
Andy Greene99a83c2016-01-20 16:56:06 +08002009LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green8c1f6022016-01-26 20:56:56 +08002010lws_server_socket_service_ssl(struct lws *new_wsi, lws_sockfd_type accept_fd);
Andy Greencdb9bf92014-04-12 10:07:02 +08002011LWS_EXTERN int
Andy Green4b85c1d2015-12-04 11:08:32 +08002012lws_ssl_close(struct lws *wsi);
Andy Greencdb9bf92014-04-12 10:07:02 +08002013LWS_EXTERN void
Andy Greend526c502016-03-28 10:10:43 +08002014lws_ssl_SSL_CTX_destroy(struct lws_vhost *vhost);
2015LWS_EXTERN void
Andy Green4b85c1d2015-12-04 11:08:32 +08002016lws_ssl_context_destroy(struct lws_context *context);
Andy Green52815602015-01-29 08:36:18 +08002017LWS_VISIBLE void
Andy Green6b5de702015-12-15 21:15:58 +08002018lws_ssl_remove_wsi_from_buffered_list(struct lws *wsi);
Andy Greeneefb13a2016-03-28 12:43:55 +08002019LWS_EXTERN int
2020lws_ssl_client_bio_create(struct lws *wsi);
2021LWS_EXTERN int
2022lws_ssl_client_connect1(struct lws *wsi);
2023LWS_EXTERN int
2024lws_ssl_client_connect2(struct lws *wsi);
Andy Greenf1fd8822016-05-03 07:26:10 +08002025LWS_EXTERN void
2026lws_ssl_elaborate_error(void);
Andy Greenc57037a2014-04-03 10:17:00 +08002027#ifndef LWS_NO_SERVER
2028LWS_EXTERN int
2029lws_context_init_server_ssl(struct lws_context_creation_info *info,
Andy Greend526c502016-03-28 10:10:43 +08002030 struct lws_vhost *vhost);
Andy Greenc57037a2014-04-03 10:17:00 +08002031#else
2032#define lws_context_init_server_ssl(_a, _b) (0)
2033#endif
2034LWS_EXTERN void
Andy Greend526c502016-03-28 10:10:43 +08002035lws_ssl_destroy(struct lws_vhost *vhost);
Andy Green2eedea92014-04-03 14:33:48 +08002036/* HTTP2-related */
2037
2038#ifdef LWS_USE_HTTP2
2039LWS_EXTERN void
Andy Green22d6f392016-04-10 09:33:54 +08002040lws_context_init_http2_ssl(struct lws_vhost *vhost);
Andy Green2eedea92014-04-03 14:33:48 +08002041#else
2042#define lws_context_init_http2_ssl(_a)
2043#endif
Darin Willitsc19456f2011-02-14 17:52:39 +00002044#endif
Andy Greena654fc02014-04-03 07:16:40 +08002045
Andy Green8c1f6022016-01-26 20:56:56 +08002046#if LWS_MAX_SMP > 1
2047static LWS_INLINE void
2048lws_pt_mutex_init(struct lws_context_per_thread *pt)
2049{
2050 pthread_mutex_init(&pt->lock, NULL);
2051}
Sterling Jensenecaed5e2016-05-12 20:22:35 -05002052
2053static LWS_INLINE void
2054lws_pt_mutex_destroy(struct lws_context_per_thread *pt)
2055{
2056 pthread_mutex_destroy(&pt->lock);
2057}
2058
Andy Green8c1f6022016-01-26 20:56:56 +08002059static LWS_INLINE void
2060lws_pt_lock(struct lws_context_per_thread *pt)
2061{
Andy Greenbbf93692016-08-07 08:33:08 +08002062 if (!pt->lock_depth++)
2063 pthread_mutex_lock(&pt->lock);
Andy Green8c1f6022016-01-26 20:56:56 +08002064}
2065
2066static LWS_INLINE void
2067lws_pt_unlock(struct lws_context_per_thread *pt)
2068{
Andy Greenbbf93692016-08-07 08:33:08 +08002069 if (!(--pt->lock_depth))
2070 pthread_mutex_unlock(&pt->lock);
Andy Green8c1f6022016-01-26 20:56:56 +08002071}
2072#else
2073#define lws_pt_mutex_init(_a) (void)(_a)
Sterling Jensenecaed5e2016-05-12 20:22:35 -05002074#define lws_pt_mutex_destroy(_a) (void)(_a)
Andy Green8c1f6022016-01-26 20:56:56 +08002075#define lws_pt_lock(_a) (void)(_a)
2076#define lws_pt_unlock(_a) (void)(_a)
2077#endif
2078
Andy Greene99a83c2016-01-20 16:56:06 +08002079LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green6b5de702015-12-15 21:15:58 +08002080lws_ssl_capable_read_no_ssl(struct lws *wsi, unsigned char *buf, int len);
Patrick Gansterera6b019a2014-04-15 18:40:31 +02002081
Andy Greene99a83c2016-01-20 16:56:06 +08002082LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green4b85c1d2015-12-04 11:08:32 +08002083lws_ssl_capable_write_no_ssl(struct lws *wsi, unsigned char *buf, int len);
Patrick Gansterera6b019a2014-04-15 18:40:31 +02002084
Andy Greene99a83c2016-01-20 16:56:06 +08002085LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green4b85c1d2015-12-04 11:08:32 +08002086lws_ssl_pending_no_ssl(struct lws *wsi);
=?UTF-8?q?Jos=C3=A9=20Luis=20Mill=C3=A1n?=4c0ba022015-08-19 16:23:33 +02002087
Andy Green1e5a9ad2016-03-20 11:59:53 +08002088#ifdef LWS_WITH_HTTP_PROXY
2089struct lws_rewrite {
2090 hubbub_parser *parser;
2091 hubbub_parser_optparams params;
2092 const char *from, *to;
2093 int from_len, to_len;
2094 unsigned char *p, *end;
2095 struct lws *wsi;
2096};
2097static LWS_INLINE int hstrcmp(hubbub_string *s, const char *p, int len)
2098{
2099 if (s->len != len)
2100 return 1;
2101
2102 return strncmp((const char *)s->ptr, p, len);
2103}
2104typedef hubbub_error (*hubbub_callback_t)(const hubbub_token *token, void *pw);
Andy Green1e5a9ad2016-03-20 11:59:53 +08002105LWS_EXTERN struct lws_rewrite *
2106lws_rewrite_create(struct lws *wsi, hubbub_callback_t cb, const char *from, const char *to);
2107LWS_EXTERN void
2108lws_rewrite_destroy(struct lws_rewrite *r);
2109LWS_EXTERN int
2110lws_rewrite_parse(struct lws_rewrite *r, const unsigned char *in, int in_len);
2111#endif
2112
2113#ifndef LWS_NO_CLIENT
Andy Green1a138852016-03-20 11:55:25 +08002114LWS_EXTERN int lws_client_socket_service(struct lws_context *context,
2115 struct lws *wsi,
2116 struct lws_pollfd *pollfd);
2117LWS_EXTERN int LWS_WARN_UNUSED_RESULT
2118lws_http_transaction_completed_client(struct lws *wsi);
Andy Greenc57037a2014-04-03 10:17:00 +08002119#ifdef LWS_OPENSSL_SUPPORT
Andy Greendc8a3a82015-12-06 09:15:27 +08002120LWS_EXTERN int
2121lws_context_init_client_ssl(struct lws_context_creation_info *info,
Andy Greend526c502016-03-28 10:10:43 +08002122 struct lws_vhost *vhost);
Andy Green3ff720f2017-06-20 11:46:49 +08002123
2124LWS_EXTERN void
2125lws_ssl_info_callback(const SSL *ssl, int where, int ret);
2126
Andy Greene38031a2014-04-03 08:24:29 +08002127#else
Andy Greenc57037a2014-04-03 10:17:00 +08002128 #define lws_context_init_client_ssl(_a, _b) (0)
2129#endif
Andy Greene99a83c2016-01-20 16:56:06 +08002130LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Greendc8a3a82015-12-06 09:15:27 +08002131lws_handshake_client(struct lws *wsi, unsigned char **buf, size_t len);
2132LWS_EXTERN void
2133lws_decode_ssl_error(void);
Andy Greenc57037a2014-04-03 10:17:00 +08002134#else
2135#define lws_context_init_client_ssl(_a, _b) (0)
Andy Greenaad2eac2014-04-03 09:03:37 +08002136#define lws_handshake_client(_a, _b, _c) (0)
Andy Greena654fc02014-04-03 07:16:40 +08002137#endif
Andy Green44e0b082015-12-28 14:24:49 +08002138
2139LWS_EXTERN int
2140_lws_rx_flow_control(struct lws *wsi);
2141
Andy Green8c1f6022016-01-26 20:56:56 +08002142LWS_EXTERN int
2143_lws_change_pollfd(struct lws *wsi, int _and, int _or, struct lws_pollargs *pa);
2144
Andy Greena654fc02014-04-03 07:16:40 +08002145#ifndef LWS_NO_SERVER
Andy Greendc8a3a82015-12-06 09:15:27 +08002146LWS_EXTERN int
2147lws_server_socket_service(struct lws_context *context, struct lws *wsi,
2148 struct lws_pollfd *pollfd);
2149LWS_EXTERN int
Andy Green11c05bf2015-12-16 18:19:08 +08002150lws_handshake_server(struct lws *wsi, unsigned char **buf, size_t len);
Andy Greend99476b2014-04-03 08:40:05 +08002151#else
Andy Greenb49a9952014-04-03 10:11:04 +08002152#define lws_server_socket_service(_a, _b, _c) (0)
Andy Green11c05bf2015-12-16 18:19:08 +08002153#define lws_handshake_server(_a, _b, _c) (0)
Andy Greena654fc02014-04-03 07:16:40 +08002154#endif
Andy Green40110e82015-12-14 08:52:03 +08002155
Andy Green2f0bc932016-04-15 12:00:23 +08002156#ifdef LWS_WITH_ACCESS_LOG
2157LWS_EXTERN int
2158lws_access_log(struct lws *wsi);
2159#else
2160#define lws_access_log(_a)
2161#endif
2162
Andy Green6a8099b2016-02-21 21:25:48 +08002163LWS_EXTERN int
2164lws_cgi_kill_terminated(struct lws_context_per_thread *pt);
2165
Andy Green02077052016-04-06 16:15:40 +08002166int
2167lws_protocol_init(struct lws_context *context);
2168
Andy Green7f92ee82016-06-18 09:00:04 +08002169int
2170lws_bind_protocol(struct lws *wsi, const struct lws_protocols *p);
2171
Andy Green722cc4a2016-06-26 06:29:20 +08002172const struct lws_http_mount *
2173lws_find_mount(struct lws *wsi, const char *uri_ptr, int uri_len);
2174
Andy Greena654fc02014-04-03 07:16:40 +08002175/*
Alejandro Merycdc97172014-12-04 23:15:27 +01002176 * custom allocator
2177 */
Andy Greene99a83c2016-01-20 16:56:06 +08002178LWS_EXTERN void *
Alejandro Merycdc97172014-12-04 23:15:27 +01002179lws_realloc(void *ptr, size_t size);
2180
Andy Greene99a83c2016-01-20 16:56:06 +08002181LWS_EXTERN void * LWS_WARN_UNUSED_RESULT
Alejandro Merycdc97172014-12-04 23:15:27 +01002182lws_zalloc(size_t size);
2183
Andy Green9395eb62017-01-30 15:02:54 +08002184#ifdef LWS_PLAT_OPTEE
2185void *lws_malloc(size_t size);
2186void lws_free(void *p);
2187#define lws_free_set_NULL(P) do { lws_free(P); (P) = NULL; } while(0)
2188#else
Alejandro Merycdc97172014-12-04 23:15:27 +01002189#define lws_malloc(S) lws_realloc(NULL, S)
2190#define lws_free(P) lws_realloc(P, 0)
Andy Green54806b12015-12-17 17:03:59 +08002191#define lws_free_set_NULL(P) do { lws_realloc(P, 0); (P) = NULL; } while(0)
Andy Green9395eb62017-01-30 15:02:54 +08002192#endif
Alejandro Merycdc97172014-12-04 23:15:27 +01002193
Andy Green19cc7ac2017-03-03 12:38:10 +08002194const struct lws_plat_file_ops *
2195lws_vfs_select_fops(const struct lws_plat_file_ops *fops, const char *vfs_path,
2196 const char **vpath);
2197
Andy Greendc8a3a82015-12-06 09:15:27 +08002198/* lws_plat_ */
Andy Greena654fc02014-04-03 07:16:40 +08002199LWS_EXTERN void
Andy Green4b85c1d2015-12-04 11:08:32 +08002200lws_plat_delete_socket_from_fds(struct lws_context *context,
Andy Greendc8a3a82015-12-06 09:15:27 +08002201 struct lws *wsi, int m);
Andy Greena654fc02014-04-03 07:16:40 +08002202LWS_EXTERN void
Andy Green4b85c1d2015-12-04 11:08:32 +08002203lws_plat_insert_socket_into_fds(struct lws_context *context,
Andy Greendc8a3a82015-12-06 09:15:27 +08002204 struct lws *wsi);
Andy Greena654fc02014-04-03 07:16:40 +08002205LWS_EXTERN void
Andy Green4b85c1d2015-12-04 11:08:32 +08002206lws_plat_service_periodic(struct lws_context *context);
Andy Greena654fc02014-04-03 07:16:40 +08002207
2208LWS_EXTERN int
Andy Greendc8a3a82015-12-06 09:15:27 +08002209lws_plat_change_pollfd(struct lws_context *context, struct lws *wsi,
2210 struct lws_pollfd *pfd);
Andy Green7aadd142017-03-25 08:42:35 +08002211LWS_EXTERN void
Andy Greend58353f2017-03-26 10:08:35 +08002212lws_add_wsi_to_draining_ext_list(struct lws *wsi);
2213LWS_EXTERN void
Andy Green7aadd142017-03-25 08:42:35 +08002214lws_remove_wsi_from_draining_ext_list(struct lws *wsi);
Andy Greena654fc02014-04-03 07:16:40 +08002215LWS_EXTERN int
2216lws_plat_context_early_init(void);
2217LWS_EXTERN void
Andy Green4b85c1d2015-12-04 11:08:32 +08002218lws_plat_context_early_destroy(struct lws_context *context);
Andy Greena654fc02014-04-03 07:16:40 +08002219LWS_EXTERN void
Andy Green4b85c1d2015-12-04 11:08:32 +08002220lws_plat_context_late_destroy(struct lws_context *context);
Andy Greena654fc02014-04-03 07:16:40 +08002221LWS_EXTERN int
Andy Green4b85c1d2015-12-04 11:08:32 +08002222lws_poll_listen_fd(struct lws_pollfd *fd);
Andy Greena654fc02014-04-03 07:16:40 +08002223LWS_EXTERN int
Andy Green4b85c1d2015-12-04 11:08:32 +08002224lws_plat_service(struct lws_context *context, int timeout_ms);
Andy Greend3a55052016-01-19 03:34:24 +08002225LWS_EXTERN LWS_VISIBLE int
Andy Greenb46c4012016-10-20 09:09:56 +08002226_lws_plat_service_tsi(struct lws_context *context, int timeout_ms, int tsi);
Andy Greena654fc02014-04-03 07:16:40 +08002227LWS_EXTERN int
Andy Green4386e362015-12-10 07:14:16 +08002228lws_plat_init(struct lws_context *context,
2229 struct lws_context_creation_info *info);
Andy Greena654fc02014-04-03 07:16:40 +08002230LWS_EXTERN void
2231lws_plat_drop_app_privileges(struct lws_context_creation_info *info);
2232LWS_EXTERN unsigned long long
2233time_in_microseconds(void);
Andy Greene99a83c2016-01-20 16:56:06 +08002234LWS_EXTERN const char * LWS_WARN_UNUSED_RESULT
Andy Greena654fc02014-04-03 07:16:40 +08002235lws_plat_inet_ntop(int af, const void *src, char *dst, int cnt);
Leonardo Maccari Rufinoaf7f9432017-06-05 13:59:22 -03002236LWS_EXTERN int LWS_WARN_UNUSED_RESULT
2237lws_plat_inet_pton(int af, const char *src, void *dst);
Andy Green8c0d3c02015-11-02 20:34:12 +08002238
Andy Greene99a83c2016-01-20 16:56:06 +08002239LWS_EXTERN int LWS_WARN_UNUSED_RESULT
Andy Green86c1ef12015-12-30 11:43:36 +08002240lws_check_utf8(unsigned char *state, unsigned char *buf, size_t len);
Andy Green3a09c3b2017-03-08 11:11:41 +08002241LWS_EXTERN int alloc_file(struct lws_context *context, const char *filename, uint8_t **buf,
2242 lws_filepos_t *amount);
Andy Green54236bd2017-05-11 15:02:01 +08002243LWS_EXTERN int alloc_pem_to_der_file(struct lws_context *context, const char *filename, uint8_t **buf,
2244 lws_filepos_t *amount);
2245
Andy Green19242db2017-04-06 13:49:17 +08002246LWS_EXTERN void
2247lws_same_vh_protocol_remove(struct lws *wsi);
2248LWS_EXTERN void
2249lws_same_vh_protocol_insert(struct lws *wsi, int n);
Andy Green86c1ef12015-12-30 11:43:36 +08002250
Andy Greena7def3c2017-05-07 10:02:03 +08002251#if defined(LWS_WITH_STATS)
2252void
2253lws_stats_atomic_bump(struct lws_context * context,
2254 struct lws_context_per_thread *pt, int index, uint64_t bump);
2255void
2256lws_stats_atomic_max(struct lws_context * context,
2257 struct lws_context_per_thread *pt, int index, uint64_t val);
2258#else
2259static inline uint64_t lws_stats_atomic_bump(struct lws_context * context,
2260 struct lws_context_per_thread *pt, int index, uint64_t bump) {
2261 (void)context; (void)pt; (void)index; (void)bump; return 0; }
2262static inline uint64_t lws_stats_atomic_max(struct lws_context * context,
2263 struct lws_context_per_thread *pt, int index, uint64_t val) {
2264 (void)context; (void)pt; (void)index; (void)val; return 0; }
2265#endif
2266
Andy Ninged92b6d2017-05-05 11:38:34 -04002267/* socks */
2268void socks_generate_msg(struct lws *wsi, enum socks_msg_type type,
2269 size_t *msg_len);
2270
Andy Green8c0d3c02015-11-02 20:34:12 +08002271#ifdef __cplusplus
2272};
2273#endif