https://github.com/gorilla/websocket.git

hellflame e8629af678 improve echo example (#671) 4 vuotta sitten
.circleci c3dd95aea9 build: use build matrix; drop Go <= 1.10 (#629) 5 vuotta sitten
.github c3e18be99d Create release-drafter.yml (#538) 6 vuotta sitten
examples e8629af678 improve echo example (#671) 4 vuotta sitten
.gitignore 6656ddce91 add newline and remove extra space 7 vuotta sitten
AUTHORS 5ed622c449 Update LICENSE file to reflect Google employee contributions. 7 vuotta sitten
LICENSE 15aed3b4a4 Relicense to the Gorilla WebSocket Authors. 11 vuotta sitten
README.md 836e821143 Changed the link of API references to pkg.go.dev (#577) 5 vuotta sitten
client.go 873e67e4d5 Fix how the client checks for presence of Upgrade: websocket, Connection: upgrade (#604) 5 vuotta sitten
client_clone.go 3f3e394da2 Update cloneTLSConfig to use Go 1.8 Config.Clone method 8 vuotta sitten
client_clone_legacy.go 3f3e394da2 Update cloneTLSConfig to use Go 1.8 Config.Clone method 8 vuotta sitten
client_server_test.go 873e67e4d5 Fix how the client checks for presence of Upgrade: websocket, Connection: upgrade (#604) 5 vuotta sitten
client_test.go 71fa72d484 Replace parseURL() with net/url.Parse() (#290) 8 vuotta sitten
compression.go eb457539f7 fix flate write pool size to work with best compression 8 vuotta sitten
compression_test.go b378caee5b Add write buffer pooling 7 vuotta sitten
conn.go d11356942f Duration order consistency when multiplying number by time unit (#570) 5 vuotta sitten
conn_broadcast_test.go a9dd6e8839 miscellaneous cleanup 7 vuotta sitten
conn_test.go 5b740c2926 Read Limit Fix (#537) 6 vuotta sitten
conn_write.go eb92580837 Use net.Buffers to write multiple slices to connection 7 vuotta sitten
conn_write_legacy.go eb92580837 Use net.Buffers to write multiple slices to connection 7 vuotta sitten
doc.go 8c288dca3e docs: Fix typo. (#568) 5 vuotta sitten
example_test.go 0a093fcde5 Fix a couple of small typo's (#567) 5 vuotta sitten
go.mod 5b740c2926 Read Limit Fix (#537) 6 vuotta sitten
go.sum b65e62901f build: clean up go.sum (#584) 5 vuotta sitten
join.go 8ab6030ad9 Add JoinMessages 6 vuotta sitten
join_test.go 8ab6030ad9 Add JoinMessages 6 vuotta sitten
json.go 92f772e4b3 Misc cleanup 8 vuotta sitten
json_test.go b378caee5b Add write buffer pooling 7 vuotta sitten
mask.go 23059f2957 Update with gofmt on tip 8 vuotta sitten
mask_safe.go adf16b3178 Add safe maskBytes 9 vuotta sitten
mask_test.go a9dd6e8839 miscellaneous cleanup 7 vuotta sitten
prepared.go 015e196e21 Use empty struct to protect writing (#566) 5 vuotta sitten
prepared_test.go b378caee5b Add write buffer pooling 7 vuotta sitten
proxy.go 0ec3d1bd7f Fix typo 6 vuotta sitten
server.go 78ab81e242 docs: clarify that sub protocols are not set via responseHeader arg. 5 vuotta sitten
server_test.go a9dd6e8839 miscellaneous cleanup 7 vuotta sitten
trace.go ceae45234a Add context in the Dialer 7 vuotta sitten
trace_17.go ceae45234a Add context in the Dialer 7 vuotta sitten
util.go a51a35ae32 Improve header parsing code 7 vuotta sitten
util_test.go a51a35ae32 Improve header parsing code 7 vuotta sitten
x_net_proxy.go b89020ee79 Add SOCKS5 support 8 vuotta sitten

README.md

Gorilla WebSocket

GoDoc CircleCI

Gorilla WebSocket is a Go implementation of the WebSocket protocol.

Documentation

Status

The Gorilla WebSocket package provides a complete and tested implementation of the WebSocket protocol. The package API is stable.

Installation

go get github.com/gorilla/websocket

Protocol Compliance

The Gorilla WebSocket package passes the server tests in the Autobahn Test Suite using the application in the examples/autobahn subdirectory.

Gorilla WebSocket compared with other packages

Notes:

  1. Large messages are fragmented in Chrome's new WebSocket implementation.
  2. The application can get the type of a received data message by implementing a Codec marshal function.
  3. The go.net io.Reader and io.Writer operate across WebSocket frame boundaries. Read returns when the input buffer is full or a frame boundary is encountered. Each call to Write sends a single frame message. The Gorilla io.Reader and io.WriteCloser operate on a single WebSocket message.
github.com/gorilla golang.org/x/net
RFC 6455 Features
Passes Autobahn Test SuiteYesNo
Receive fragmented messageYesNo, see note 1
Send close messageYesNo
Send pings and receive pongsYesNo
Get the type of a received data messageYesYes, see note 2
Other Features
Compression ExtensionsExperimentalNo
Read message using io.ReaderYesNo, see note 3
Write message using io.WriteCloserYesNo, see note 3