libwebsockets
Lightweight C library for HTML5 websockets
libwebsockets.h
Go to the documentation of this file.
1/*
2 * libwebsockets - small server side websockets and web server implementation
3 *
4 * Copyright (C) 2010 - 2019 Andy Green <andy@warmcat.com>
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to
8 * deal in the Software without restriction, including without limitation the
9 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
22 * IN THE SOFTWARE.
23 */
24
27#ifndef LIBWEBSOCKET_H_3060898B846849FF9F88F5DB59B5950C
28#define LIBWEBSOCKET_H_3060898B846849FF9F88F5DB59B5950C
29
30#ifdef __cplusplus
31#include <cstddef>
32#include <cstdarg>
33
34extern "C" {
35#else
36#include <stdarg.h>
37#endif
38
39#include <string.h>
40#include <stdlib.h>
41
42#include "lws_config.h"
43
44/* place for one-shot opaque forward references */
45
46struct lws_sequencer;
47struct lws_dsh;
48
49/*
50 * CARE: everything using cmake defines needs to be below here
51 */
52
53#define LWS_US_PER_SEC ((lws_usec_t)1000000)
54#define LWS_MS_PER_SEC ((lws_usec_t)1000)
55#define LWS_US_PER_MS ((lws_usec_t)1000)
56#define LWS_NS_PER_US ((lws_usec_t)1000)
57
58#define LWS_KI (1024)
59#define LWS_MI (LWS_KI * 1024)
60#define LWS_GI (LWS_MI * 1024)
61#define LWS_TI ((uint64_t)LWS_GI * 1024)
62#define LWS_PI ((uint64_t)LWS_TI * 1024)
63
64#define LWS_US_TO_MS(x) ((x + (LWS_US_PER_MS / 2)) / LWS_US_PER_MS)
65
66#if defined(LWS_HAS_INTPTR_T)
67#include <stdint.h>
68#define lws_intptr_t intptr_t
69#else
70typedef unsigned long long lws_intptr_t;
71#endif
72
73#if defined(WIN32) || defined(_WIN32)
74#ifndef WIN32_LEAN_AND_MEAN
75#define WIN32_LEAN_AND_MEAN
76#endif
77
78#include <winsock2.h>
79#include <ws2tcpip.h>
80#include <stddef.h>
81#include <basetsd.h>
82#include <io.h>
83#ifndef _WIN32_WCE
84#include <fcntl.h>
85#else
86#define _O_RDONLY 0x0000
87#define O_RDONLY _O_RDONLY
88#endif
89
90#define LWS_INLINE __inline
91#define LWS_VISIBLE
92#define LWS_WARN_UNUSED_RESULT
93#define LWS_WARN_DEPRECATED
94#define LWS_FORMAT(string_index)
95
96#if !defined(LWS_EXTERN)
97#ifdef LWS_DLL
98#ifdef LWS_INTERNAL
99#define LWS_EXTERN extern __declspec(dllexport)
100#else
101#define LWS_EXTERN extern __declspec(dllimport)
102#endif
103#endif
104#endif
105
106#define LWS_INVALID_FILE INVALID_HANDLE_VALUE
107#define LWS_SOCK_INVALID (INVALID_SOCKET)
108#define LWS_O_RDONLY _O_RDONLY
109#define LWS_O_WRONLY _O_WRONLY
110#define LWS_O_CREAT _O_CREAT
111#define LWS_O_TRUNC _O_TRUNC
112
113#ifndef __func__
114#define __func__ __FUNCTION__
115#endif
116
117#else /* NOT WIN32 */
118#include <unistd.h>
119#if defined(LWS_HAVE_SYS_CAPABILITY_H) && defined(LWS_HAVE_LIBCAP)
120#include <sys/capability.h>
121#endif
122
123#if defined(__NetBSD__) || defined(__FreeBSD__) || defined(__QNX__) || defined(__OpenBSD__)
124#include <sys/socket.h>
125#include <netinet/in.h>
126#endif
127
128#define LWS_INLINE inline
129#define LWS_O_RDONLY O_RDONLY
130#define LWS_O_WRONLY O_WRONLY
131#define LWS_O_CREAT O_CREAT
132#define LWS_O_TRUNC O_TRUNC
133
134#if !defined(LWS_PLAT_OPTEE) && !defined(OPTEE_TA) && !defined(LWS_PLAT_FREERTOS)
135#include <poll.h>
136#include <netdb.h>
137#define LWS_INVALID_FILE -1
138#define LWS_SOCK_INVALID (-1)
139#else
140#define getdtablesize() (30)
141#if defined(LWS_PLAT_FREERTOS)
142#define LWS_INVALID_FILE NULL
143#define LWS_SOCK_INVALID (-1)
144#else
145#define LWS_INVALID_FILE NULL
146#define LWS_SOCK_INVALID (-1)
147#endif
148#endif
149
150#if defined(__GNUC__)
151
152/* warn_unused_result attribute only supported by GCC 3.4 or later */
153#if __GNUC__ >= 4 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4)
154#define LWS_WARN_UNUSED_RESULT __attribute__((warn_unused_result))
155#else
156#define LWS_WARN_UNUSED_RESULT
157#endif
158
159#define LWS_VISIBLE __attribute__((visibility("default")))
160#define LWS_WARN_DEPRECATED __attribute__ ((deprecated))
161#define LWS_FORMAT(string_index) __attribute__ ((format(printf, string_index, string_index+1)))
162#else
163#define LWS_VISIBLE
164#define LWS_WARN_UNUSED_RESULT
165#define LWS_WARN_DEPRECATED
166#define LWS_FORMAT(string_index)
167#endif
168
169#if defined(__ANDROID__)
170#include <netinet/in.h>
171#include <unistd.h>
172#endif
173
174#endif
175
176#if defined(LWS_WITH_LIBEV)
177#include <libev/ev.h>
178#endif /* LWS_WITH_LIBEV */
179#ifdef LWS_WITH_LIBUV
180#include <uv.h>
181#ifdef LWS_HAVE_UV_VERSION_H
182#include <uv-version.h>
183#endif
184#ifdef LWS_HAVE_NEW_UV_VERSION_H
185#include <uv/version.h>
186#endif
187#endif /* LWS_WITH_LIBUV */
188#if defined(LWS_WITH_LIBEVENT)
189#include <event2/event.h>
190#endif /* LWS_WITH_LIBEVENT */
191
192#ifndef LWS_EXTERN
193#define LWS_EXTERN extern
194#endif
195
196#ifdef _WIN32
197#define random rand
198#else
199#if !defined(LWS_PLAT_OPTEE)
200#include <sys/time.h>
201#include <unistd.h>
202#endif
203#endif
204
205#if defined(LWS_WITH_TLS)
206
207#ifdef USE_WOLFSSL
208#ifdef USE_OLD_CYASSL
209#ifdef _WIN32
210/*
211 * Include user-controlled settings for windows from
212 * <wolfssl-root>/IDE/WIN/user_settings.h
213 */
214#include <IDE/WIN/user_settings.h>
215#include <cyassl/ctaocrypt/settings.h>
216#else
217#include <cyassl/options.h>
218#endif
219#include <cyassl/openssl/ssl.h>
220#include <cyassl/error-ssl.h>
221
222#else
223#ifdef _WIN32
224/*
225 * Include user-controlled settings for windows from
226 * <wolfssl-root>/IDE/WIN/user_settings.h
227 */
228#include <IDE/WIN/user_settings.h>
229#include <wolfssl/wolfcrypt/settings.h>
230#else
231#include <wolfssl/options.h>
232#endif
233#include <wolfssl/openssl/ssl.h>
234#include <wolfssl/error-ssl.h>
235#endif /* not USE_OLD_CYASSL */
236#else
237#if defined(LWS_WITH_MBEDTLS)
238#if defined(LWS_PLAT_FREERTOS)
239/* this filepath is passed to us but without quotes or <> */
240#if !defined(LWS_AMAZON_RTOS)
241/* AMAZON RTOS has its own setting via MTK_MBEDTLS_CONFIG_FILE */
242#undef MBEDTLS_CONFIG_FILE
243#define MBEDTLS_CONFIG_FILE <mbedtls/esp_config.h>
244#endif
245#endif
246#include <mbedtls/ssl.h>
247#include <mbedtls/entropy.h>
248#include <mbedtls/ctr_drbg.h>
249#else
250#include <openssl/ssl.h>
251#if !defined(LWS_WITH_MBEDTLS)
252#include <openssl/err.h>
253#endif
254#endif
255#endif /* not USE_WOLFSSL */
256#endif
257
258/*
259 * Helpers for pthread mutex in user code... if lws is built for
260 * multiple service threads, these resolve to pthread mutex
261 * operations. In the case LWS_MAX_SMP is 1 (the default), they
262 * are all NOPs and no pthread type or api is referenced.
263 */
264
265#if LWS_MAX_SMP > 1
266
267#include <pthread.h>
268
269#define lws_pthread_mutex(name) pthread_mutex_t name;
270
271static LWS_INLINE void
272lws_pthread_mutex_init(pthread_mutex_t *lock)
273{
274 pthread_mutex_init(lock, NULL);
275}
276
277static LWS_INLINE void
278lws_pthread_mutex_destroy(pthread_mutex_t *lock)
279{
280 pthread_mutex_destroy(lock);
281}
282
283static LWS_INLINE void
284lws_pthread_mutex_lock(pthread_mutex_t *lock)
285{
286 pthread_mutex_lock(lock);
287}
288
289static LWS_INLINE void
290lws_pthread_mutex_unlock(pthread_mutex_t *lock)
291{
292 pthread_mutex_unlock(lock);
293}
294
295#else
296#define lws_pthread_mutex(name)
297#define lws_pthread_mutex_init(_a)
298#define lws_pthread_mutex_destroy(_a)
299#define lws_pthread_mutex_lock(_a)
300#define lws_pthread_mutex_unlock(_a)
301#endif
302
303
304#define CONTEXT_PORT_NO_LISTEN -1
305#define CONTEXT_PORT_NO_LISTEN_SERVER -2
306
307#include <libwebsockets/lws-logs.h>
308
309
310#include <stddef.h>
311
312#ifndef lws_container_of
313#define lws_container_of(P,T,M) ((T *)((char *)(P) - offsetof(T, M)))
314#endif
315#define LWS_ALIGN_TO(x, bou) x += ((bou) - ((x) % (bou))) % (bou)
316
317struct lws;
318
319/* api change list for user code to test against */
320
321#define LWS_FEATURE_SERVE_HTTP_FILE_HAS_OTHER_HEADERS_ARG
322
323/* the struct lws_protocols has the id field present */
324#define LWS_FEATURE_PROTOCOLS_HAS_ID_FIELD
325
326/* you can call lws_get_peer_write_allowance */
327#define LWS_FEATURE_PROTOCOLS_HAS_PEER_WRITE_ALLOWANCE
328
329/* extra parameter introduced in 917f43ab821 */
330#define LWS_FEATURE_SERVE_HTTP_FILE_HAS_OTHER_HEADERS_LEN
331
332/* File operations stuff exists */
333#define LWS_FEATURE_FOPS
334
335
336#if defined(_WIN32)
337#if !defined(LWS_WIN32_HANDLE_TYPES)
338typedef SOCKET lws_sockfd_type;
339typedef HANDLE lws_filefd_type;
340#endif
341
342struct lws_pollfd {
343 lws_sockfd_type fd;
344 SHORT events;
345 SHORT revents;
346};
347#define LWS_POLLHUP (FD_CLOSE)
348#define LWS_POLLIN (FD_READ | FD_ACCEPT)
349#define LWS_POLLOUT (FD_WRITE)
350
351#if !defined(pid_t)
352#define pid_t int
353#endif
354
355#else
356
357
358#if defined(LWS_PLAT_FREERTOS)
359#include <libwebsockets/lws-freertos.h>
360#if defined(LWS_WITH_ESP32)
361#include <libwebsockets/lws-esp32.h>
362#endif
363#else
364typedef int lws_sockfd_type;
365typedef int lws_filefd_type;
366#endif
367
368#if defined(LWS_PLAT_OPTEE)
369#include <time.h>
370struct timeval {
371 time_t tv_sec;
372 unsigned int tv_usec;
373};
374#if defined(LWS_WITH_NETWORK)
375// #include <poll.h>
376#define lws_pollfd pollfd
377
378struct timezone;
379
380int gettimeofday(struct timeval *tv, struct timezone *tz);
381
382 /* Internet address. */
383 struct in_addr {
384 uint32_t s_addr; /* address in network byte order */
385 };
386
387typedef unsigned short sa_family_t;
388typedef unsigned short in_port_t;
389typedef uint32_t socklen_t;
390
391#include <libwebsockets/lws-optee.h>
392
393#if !defined(TEE_SE_READER_NAME_MAX)
394 struct addrinfo {
395 int ai_flags;
396 int ai_family;
397 int ai_socktype;
398 int ai_protocol;
399 socklen_t ai_addrlen;
400 struct sockaddr *ai_addr;
401 char *ai_canonname;
402 struct addrinfo *ai_next;
403 };
404#endif
405
406ssize_t recv(int sockfd, void *buf, size_t len, int flags);
407ssize_t send(int sockfd, const void *buf, size_t len, int flags);
408ssize_t read(int fd, void *buf, size_t count);
409int getsockopt(int sockfd, int level, int optname,
410 void *optval, socklen_t *optlen);
411 int setsockopt(int sockfd, int level, int optname,
412 const void *optval, socklen_t optlen);
413int connect(int sockfd, const struct sockaddr *addr,
414 socklen_t addrlen);
415
416extern int errno;
417
418uint16_t ntohs(uint16_t netshort);
419uint16_t htons(uint16_t hostshort);
420
421int bind(int sockfd, const struct sockaddr *addr,
422 socklen_t addrlen);
423
424
425#define MSG_NOSIGNAL 0x4000
426#define EAGAIN 11
427#define EINTR 4
428#define EWOULDBLOCK EAGAIN
429#define EADDRINUSE 98
430#define INADDR_ANY 0
431#define AF_INET 2
432#define SHUT_WR 1
433#define AF_UNSPEC 0
434#define PF_UNSPEC 0
435#define SOCK_STREAM 1
436#define SOCK_DGRAM 2
437# define AI_PASSIVE 0x0001
438#define IPPROTO_UDP 17
439#define SOL_SOCKET 1
440#define SO_SNDBUF 7
441#define EISCONN 106
442#define EALREADY 114
443#define EINPROGRESS 115
444int shutdown(int sockfd, int how);
445int close(int fd);
446int atoi(const char *nptr);
447long long atoll(const char *nptr);
448
449int socket(int domain, int type, int protocol);
450 int getaddrinfo(const char *node, const char *service,
451 const struct addrinfo *hints,
452 struct addrinfo **res);
453
454 void freeaddrinfo(struct addrinfo *res);
455
456#if !defined(TEE_SE_READER_NAME_MAX)
457struct lws_pollfd
458{
459 int fd; /* File descriptor to poll. */
460 short int events; /* Types of events poller cares about. */
461 short int revents; /* Types of events that actually occurred. */
462};
463#endif
464
465int poll(struct pollfd *fds, int nfds, int timeout);
466
467#define LWS_POLLHUP (0x18)
468#define LWS_POLLIN (1)
469#define LWS_POLLOUT (4)
470#else
471struct lws_pollfd;
472struct sockaddr_in;
473#endif
474#else
475#define lws_pollfd pollfd
476#define LWS_POLLHUP (POLLHUP | POLLERR)
477#define LWS_POLLIN (POLLIN)
478#define LWS_POLLOUT (POLLOUT)
479#endif
480#endif
481
482
483#if (defined(WIN32) || defined(_WIN32)) && !defined(__MINGW32__)
484/* ... */
485#define ssize_t SSIZE_T
486#endif
487
488#if defined(WIN32) && defined(LWS_HAVE__STAT32I64)
489#include <sys/types.h>
490#include <sys/stat.h>
491#endif
492
493#if defined(LWS_HAVE_STDINT_H)
494#include <stdint.h>
495#else
496#if defined(WIN32) || defined(_WIN32)
497/* !!! >:-[ */
498typedef __int64 int64_t;
499typedef unsigned __int64 uint64_t;
500typedef __int32 int32_t;
501typedef unsigned __int32 uint32_t;
502typedef __int16 int16_t;
503typedef unsigned __int16 uint16_t;
504typedef unsigned __int8 uint8_t;
505#else
506typedef unsigned int uint32_t;
507typedef unsigned short uint16_t;
508typedef unsigned char uint8_t;
509#endif
510#endif
511
512typedef int64_t lws_usec_t;
513typedef unsigned long long lws_filepos_t;
514typedef long long lws_fileofs_t;
515typedef uint32_t lws_fop_flags_t;
516
517#define lws_concat_temp(_t, _l) (_t + sizeof(_t) - _l)
518#define lws_concat_used(_t, _l) (sizeof(_t) - _l)
519
523 lws_sockfd_type fd;
524 int events;
526};
527
528struct lws_extension; /* needed even with ws exts disabled for create context */
529struct lws_token_limits;
530struct lws_protocols;
531struct lws_context;
532struct lws_tokens;
533struct lws_vhost;
534struct lws;
535
536#include <libwebsockets/lws-dll2.h>
537#include <libwebsockets/lws-timeout-timer.h>
538#include <libwebsockets/lws-state.h>
539#include <libwebsockets/lws-retry.h>
540#include <libwebsockets/lws-adopt.h>
541#include <libwebsockets/lws-network-helper.h>
542#include <libwebsockets/lws-system.h>
543#include <libwebsockets/lws-detailed-latency.h>
544#include <libwebsockets/lws-ws-close.h>
545#include <libwebsockets/lws-callbacks.h>
546#include <libwebsockets/lws-ws-state.h>
547#include <libwebsockets/lws-ws-ext.h>
548#include <libwebsockets/lws-protocols-plugins.h>
549#include <libwebsockets/lws-plugin-generic-sessions.h>
550#include <libwebsockets/lws-context-vhost.h>
551#if defined(LWS_ROLE_MQTT)
552#include <libwebsockets/lws-mqtt.h>
553#endif
554#include <libwebsockets/lws-client.h>
555#include <libwebsockets/lws-http.h>
556#include <libwebsockets/lws-spa.h>
557#include <libwebsockets/lws-purify.h>
558#include <libwebsockets/lws-misc.h>
559#include <libwebsockets/lws-dsh.h>
560#include <libwebsockets/lws-service.h>
561#include <libwebsockets/lws-write.h>
562#include <libwebsockets/lws-writeable.h>
563#include <libwebsockets/lws-ring.h>
564#include <libwebsockets/lws-sha1-base64.h>
565#include <libwebsockets/lws-x509.h>
566#include <libwebsockets/lws-cgi.h>
567#if defined(LWS_WITH_FILE_OPS)
568#include <libwebsockets/lws-vfs.h>
569#endif
570#include <libwebsockets/lws-lejp.h>
571#include <libwebsockets/lws-stats.h>
572#include <libwebsockets/lws-struct.h>
573#include <libwebsockets/lws-threadpool.h>
574#include <libwebsockets/lws-tokenize.h>
575#include <libwebsockets/lws-lwsac.h>
576#include <libwebsockets/lws-fts.h>
577#include <libwebsockets/lws-diskcache.h>
578#include <libwebsockets/lws-sequencer.h>
579#include <libwebsockets/lws-secure-streams.h>
580#include <libwebsockets/lws-secure-streams-policy.h>
581#include <libwebsockets/lws-secure-streams-client.h>
582
583#if !defined(LWS_PLAT_FREERTOS)
584#include <libwebsockets/abstract/abstract.h>
585
586#include <libwebsockets/lws-test-sequencer.h>
587#endif
588#include <libwebsockets/lws-async-dns.h>
589
590#if defined(LWS_WITH_TLS)
591
592#if defined(LWS_WITH_MBEDTLS)
593#include <mbedtls/md5.h>
594#include <mbedtls/sha1.h>
595#include <mbedtls/sha256.h>
596#include <mbedtls/sha512.h>
597#endif
598
599#include <libwebsockets/lws-gencrypto.h>
600#include <libwebsockets/lws-genhash.h>
601#include <libwebsockets/lws-genrsa.h>
602#include <libwebsockets/lws-genaes.h>
603#include <libwebsockets/lws-genec.h>
604
605#include <libwebsockets/lws-jwk.h>
606#include <libwebsockets/lws-jose.h>
607#include <libwebsockets/lws-jws.h>
608#include <libwebsockets/lws-jwe.h>
609
610#endif
611
612#ifdef __cplusplus
613}
614#endif
615
616#endif
Definition: libwebsockets.h:522
int events
Definition: libwebsockets.h:524
int prev_events
Definition: libwebsockets.h:525
lws_sockfd_type fd
Definition: libwebsockets.h:523