*/
#include "private-libwebsockets.h"
+
#include "lextable-strings.h"
+
const unsigned char *lws_token_to_string(enum lws_token_indexes token)
{
if ((unsigned int)token >= ARRAY_SIZE(set))
}
int lws_add_http_header_content_length(struct lws *wsi,
- unsigned long content_length,
+ lws_filepos_t content_length,
unsigned char **p, unsigned char *end)
{
char b[24];
int n;
- n = sprintf(b, "%lu", content_length);
+ n = sprintf(b, "%llu", (unsigned long long)content_length);
if (lws_add_http_header_by_token(wsi, WSI_TOKEN_HTTP_CONTENT_LENGTH,
(unsigned char *)b, n, p, end))
return 1;
return 0;
}
-static const char *err400[] = {
+STORE_IN_ROM static const char * const err400[] = {
"Bad Request",
"Unauthorized",
"Payment Required",
"Expectation Failed"
};
-static const char *err500[] = {
+STORE_IN_ROM static const char * const err500[] = {
"Internal Server Error",
"Not Implemented",
"Bad Gateway",
};
int
-lws_add_http_header_status(struct lws *wsi, unsigned int code,
+lws_add_http_header_status(struct lws *wsi, unsigned int _code,
unsigned char **p, unsigned char *end)
{
- unsigned char code_and_desc[60];
- const char *description = "", *p1;
- int n;
- static const char * const hver[] = {
+ STORE_IN_ROM static const char * const hver[] = {
"HTTP/1.0", "HTTP/1.1", "HTTP/2"
};
+ const struct lws_protocol_vhost_options *headers;
+ unsigned int code = _code & LWSAHH_CODE_MASK;
+ const char *description = "", *p1;
+ unsigned char code_and_desc[60];
+ int n;
#ifdef LWS_WITH_ACCESS_LOG
wsi->access_log.response = code;
else
p1 = hver[0];
- n = sprintf((char *)code_and_desc, "%s %u %s",
- p1, code, description);
+ n = sprintf((char *)code_and_desc, "%s %u %s", p1, code, description);
- if (lws_add_http_header_by_name(wsi, NULL, code_and_desc,
- n, p, end))
+ if (lws_add_http_header_by_name(wsi, NULL, code_and_desc, n, p, end))
return 1;
- if (lws_add_http_header_by_token(wsi, WSI_TOKEN_HTTP_SERVER,
- (unsigned char *)
- wsi->context->server_string,
- wsi->context->server_string_len,
- p, end))
- return 1;
+ headers = wsi->vhost->headers;
+ while (headers) {
+ if (lws_add_http_header_by_name(wsi,
+ (const unsigned char *)headers->name,
+ (unsigned char *)headers->value,
+ strlen(headers->value), p, end))
+ return 1;
+
+ headers = headers->next;
+ }
+
+ if (wsi->context->server_string &&
+ !(_code & LWSAHH_FLAG_NO_SERVER_NAME))
+ if (lws_add_http_header_by_token(wsi, WSI_TOKEN_HTTP_SERVER,
+ (unsigned char *)wsi->context->server_string,
+ wsi->context->server_string_len, p, end))
+ return 1;
if (wsi->vhost->options & LWS_SERVER_OPTION_STS)
if (lws_add_http_header_by_name(wsi, (unsigned char *)
return 0;
}
-/**
- * lws_return_http_status() - Return simple http status
- * @wsi: Websocket instance (available from user callback)
- * @code: Status index, eg, 404
- * @html_body: User-readable HTML description < 1KB, or NULL
- *
- * Helper to report HTTP errors back to the client cleanly and
- * consistently
- */
LWS_VISIBLE int
lws_return_http_status(struct lws *wsi, unsigned int code,
const char *html_body)
struct lws_context *context = lws_get_context(wsi);
struct lws_context_per_thread *pt = &context->pt[(int)wsi->tsi];
unsigned char *p = pt->serv_buf + LWS_PRE;
- unsigned char *start = p, *body = p + 512;
+ unsigned char *start = p;
unsigned char *end = p + context->pt_serv_buf_size - LWS_PRE;
- int n, m, len;
+ int n = 0, m, len;
char slen[20];
if (!html_body)
html_body = "";
- len = sprintf((char *)body, "<html><body><h1>%u</h1>%s</body></html>",
- code, html_body);
-
if (lws_add_http_header_status(wsi, code, &p, end))
return 1;
(unsigned char *)"text/html", 9,
&p, end))
return 1;
+
+ len = 37 + strlen(html_body) + sprintf(slen, "%d", code);
n = sprintf(slen, "%d", len);
+
if (lws_add_http_header_by_token(wsi, WSI_TOKEN_HTTP_CONTENT_LENGTH,
(unsigned char *)slen, n,
&p, end))
if (lws_finalize_http_header(wsi, &p, end))
return 1;
- m = lws_write(wsi, start, p - start, LWS_WRITE_HTTP_HEADERS);
- if (m != (int)(p - start))
- return 1;
+#if defined(LWS_USE_HTTP2)
+ {
+ unsigned char *body = p + 512;
+
+ m = lws_write(wsi, start, p - start, LWS_WRITE_HTTP_HEADERS);
+ if (m != (int)(p - start))
+ return 1;
- m = lws_write(wsi, body, len, LWS_WRITE_HTTP);
+ len = sprintf((char *)body, "<html><body><h1>%u</h1>%s</body></html>",
+ code, html_body);
+
+ n = len;
+ m = lws_write(wsi, body, len, LWS_WRITE_HTTP);
+ }
+#else
+ p += lws_snprintf((char *)p, end - p - 1,
+ "<html><body><h1>%u</h1>%s</body></html>",
+ code, html_body);
+
+ n = (int)(p - start);
+ m = lws_write(wsi, start, n, LWS_WRITE_HTTP);
+ if (m != n)
+ return 1;
+#endif
return m != n;
}