Merge pull request #7 from smith-30/feature/client_context_takeover

add: context-takeover option to client
This commit is contained in:
smith30 2018-01-24 20:01:03 +09:00 committed by GitHub
commit 538a96d70f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 22 additions and 7 deletions

View File

@ -78,6 +78,11 @@ type Dialer struct {
// takeover" modes are supported. // takeover" modes are supported.
EnableCompression bool EnableCompression bool
// EnableContextTakeover specifies specifies if the client should attempt to negotiate
// per message compression with context-takeover (RFC 7692).
// but window bits is allowed only 15, because go's flate library support 15 bits only.
EnableContextTakeover bool
// Jar specifies the cookie jar. // Jar specifies the cookie jar.
// If Jar is nil, cookies are not sent in requests and ignored // If Jar is nil, cookies are not sent in requests and ignored
// in responses. // in responses.
@ -196,7 +201,10 @@ func (d *Dialer) Dial(urlStr string, requestHeader http.Header) (*Conn, *http.Re
} }
} }
if d.EnableCompression { switch {
case d.EnableCompression && d.EnableContextTakeover:
req.Header.Set("Sec-Websocket-Extensions", "permessage-deflate; server_max_window_bits=15; client_max_window_bits=15")
case d.EnableCompression:
req.Header.Set("Sec-Websocket-Extensions", "permessage-deflate; server_no_context_takeover; client_no_context_takeover") req.Header.Set("Sec-Websocket-Extensions", "permessage-deflate; server_no_context_takeover; client_no_context_takeover")
} }
@ -307,13 +315,20 @@ func (d *Dialer) Dial(urlStr string, requestHeader http.Header) (*Conn, *http.Re
if ext[""] != "permessage-deflate" { if ext[""] != "permessage-deflate" {
continue continue
} }
_, snct := ext["server_no_context_takeover"]
_, cnct := ext["client_no_context_takeover"] _, cmwb := ext["client_max_window_bits"]
if !snct || !cnct { _, smwb := ext["server_max_window_bits"]
return nil, resp, errInvalidCompression
} switch {
case cmwb && smwb:
conn.contextTakeover = true
conn.newCompressionWriter = compressContextTakeover
conn.newDecompressionReader = decompressContextTakeover
default:
conn.newCompressionWriter = compressNoContextTakeover conn.newCompressionWriter = compressNoContextTakeover
conn.newDecompressionReader = decompressNoContextTakeover conn.newDecompressionReader = decompressNoContextTakeover
}
break break
} }