Detailed log errors for the /websockify path

This commit is contained in:
Lauri Kasanen 2022-06-06 17:36:00 +03:00
parent f22d8347ed
commit 87e39f896c

View File

@ -628,6 +628,8 @@ int decode_hybi(unsigned char *src, size_t srclength,
int parse_handshake(ws_ctx_t *ws_ctx, char *handshake) { int parse_handshake(ws_ctx_t *ws_ctx, char *handshake) {
char *start, *end; char *start, *end;
headers_t *headers = ws_ctx->headers; headers_t *headers = ws_ctx->headers;
const uint8_t extralogs = !!strstr(handshake, "/websockify");
#define err(x) if (extralogs) { wserr("/websockify request failed websocket checks, " x "\n"); }
headers->key1[0] = '\0'; headers->key1[0] = '\0';
headers->key2[0] = '\0'; headers->key2[0] = '\0';
@ -635,16 +637,17 @@ int parse_handshake(ws_ctx_t *ws_ctx, char *handshake) {
if ((strlen(handshake) < 92) || (bcmp(handshake, "GET ", 4) != 0) || if ((strlen(handshake) < 92) || (bcmp(handshake, "GET ", 4) != 0) ||
(!strcasestr(handshake, "Upgrade: websocket"))) { (!strcasestr(handshake, "Upgrade: websocket"))) {
err("not a GET request, or missing Upgrade header");
return 0; return 0;
} }
start = handshake+4; start = handshake+4;
end = strstr(start, " HTTP/1.1"); end = strstr(start, " HTTP/1.1");
if (!end) { return 0; } if (!end) { err("not HTTP"); return 0; }
strncpy(headers->path, start, end-start); strncpy(headers->path, start, end-start);
headers->path[end-start] = '\0'; headers->path[end-start] = '\0';
start = strstr(handshake, "\r\nHost: "); start = strstr(handshake, "\r\nHost: ");
if (!start) { return 0; } if (!start) { err("missing Host header"); return 0; }
start += 8; start += 8;
end = strstr(start, "\r\n"); end = strstr(start, "\r\n");
strncpy(headers->host, start, end-start); strncpy(headers->host, start, end-start);
@ -656,7 +659,7 @@ int parse_handshake(ws_ctx_t *ws_ctx, char *handshake) {
start += 10; start += 10;
} else { } else {
start = strcasestr(handshake, "\r\nSec-WebSocket-Origin: "); start = strcasestr(handshake, "\r\nSec-WebSocket-Origin: ");
if (!start) { return 0; } if (!start) { err("missing Sec-WebSocket-Origin header"); return 0; }
start += 24; start += 24;
} }
end = strstr(start, "\r\n"); end = strstr(start, "\r\n");
@ -674,21 +677,21 @@ int parse_handshake(ws_ctx_t *ws_ctx, char *handshake) {
ws_ctx->hybi = strtol(headers->version, NULL, 10); ws_ctx->hybi = strtol(headers->version, NULL, 10);
start = strcasestr(handshake, "\r\nSec-WebSocket-Key: "); start = strcasestr(handshake, "\r\nSec-WebSocket-Key: ");
if (!start) { return 0; } if (!start) { err("missing Sec-WebSocket-Key header"); return 0; }
start += 21; start += 21;
end = strstr(start, "\r\n"); end = strstr(start, "\r\n");
strncpy(headers->key1, start, end-start); strncpy(headers->key1, start, end-start);
headers->key1[end-start] = '\0'; headers->key1[end-start] = '\0';
start = strstr(handshake, "\r\nConnection: "); start = strstr(handshake, "\r\nConnection: ");
if (!start) { return 0; } if (!start) { err("missing Connection header"); return 0; }
start += 14; start += 14;
end = strstr(start, "\r\n"); end = strstr(start, "\r\n");
strncpy(headers->connection, start, end-start); strncpy(headers->connection, start, end-start);
headers->connection[end-start] = '\0'; headers->connection[end-start] = '\0';
start = strcasestr(handshake, "\r\nSec-WebSocket-Protocol: "); start = strcasestr(handshake, "\r\nSec-WebSocket-Protocol: ");
if (!start) { return 0; } if (!start) { err("missing Sec-WebSocket-Protocol header"); return 0; }
start += 26; start += 26;
end = strstr(start, "\r\n"); end = strstr(start, "\r\n");
strncpy(headers->protocols, start, end-start); strncpy(headers->protocols, start, end-start);
@ -698,7 +701,7 @@ int parse_handshake(ws_ctx_t *ws_ctx, char *handshake) {
ws_ctx->hybi = 0; ws_ctx->hybi = 0;
start = strstr(handshake, "\r\n\r\n"); start = strstr(handshake, "\r\n\r\n");
if (!start) { return 0; } if (!start) { err("headers too large"); return 0; }
start += 4; start += 4;
if (strlen(start) == 8) { if (strlen(start) == 8) {
ws_ctx->hixie = 76; ws_ctx->hixie = 76;
@ -706,14 +709,14 @@ int parse_handshake(ws_ctx_t *ws_ctx, char *handshake) {
headers->key3[8] = '\0'; headers->key3[8] = '\0';
start = strcasestr(handshake, "\r\nSec-WebSocket-Key1: "); start = strcasestr(handshake, "\r\nSec-WebSocket-Key1: ");
if (!start) { return 0; } if (!start) { err("missing Sec-WebSocket-Key1 header"); return 0; }
start += 22; start += 22;
end = strstr(start, "\r\n"); end = strstr(start, "\r\n");
strncpy(headers->key1, start, end-start); strncpy(headers->key1, start, end-start);
headers->key1[end-start] = '\0'; headers->key1[end-start] = '\0';
start = strcasestr(handshake, "\r\nSec-WebSocket-Key2: "); start = strcasestr(handshake, "\r\nSec-WebSocket-Key2: ");
if (!start) { return 0; } if (!start) { err("missing Sec-WebSocket-Key2 header"); return 0; }
start += 22; start += 22;
end = strstr(start, "\r\n"); end = strstr(start, "\r\n");
strncpy(headers->key2, start, end-start); strncpy(headers->key2, start, end-start);
@ -724,6 +727,8 @@ int parse_handshake(ws_ctx_t *ws_ctx, char *handshake) {
} }
#undef err
return 1; return 1;
} }