Merge pull request #423 from jamesragray/http2-websocket-cookies

Fixed so that cookies from Config are sent on websocket connection.
This commit is contained in:
Adam D. Ruppe 2024-01-30 09:16:00 -05:00 committed by GitHub
commit 514a011097
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 19 additions and 0 deletions

19
http2.d
View File

@ -4618,6 +4618,7 @@ class WebSocket {
socket = new Socket(family(uri.unixSocketPath), SocketType.STREAM);
socket.setOption(SocketOptionLevel.TCP, SocketOption.TCP_NODELAY, 1);
cookies = config.cookies;
}
/++
@ -4704,6 +4705,24 @@ class WebSocket {
// FIXME: randomize this
append("Sec-WebSocket-Key: x3JEHMbDL1EzLkh9GBhXDw==\r\n");
if(cookies.length > 0) {
append("Cookie: ");
bool first=true;
foreach(k,v;cookies) {
if(first) first = false;
else append("; ");
append(k);
append("=");
append(v);
}
append("\r\n");
}
/*
//This is equivalent but has dependencies
import std.format;
import std.algorithm : map;
append(format("cookie: %-(%s %)\r\n",cookies.byKeyValue.map!(t=>format("%s=%s",t.key,t.value))));
*/
if(config.protocol.length)
append("Sec-WebSocket-Protocol: ", config.protocol, "\r\n");