Skip to content
forked from gorilla/websocket

A fast, well-tested and widely used WebSocket implementation for Go.

License

Notifications You must be signed in to change notification settings

calbot/websocket

This branch is 7 commits ahead of, 76 commits behind gorilla/websocket:main.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

1dad860 · Nov 27, 2020
Sep 12, 2020
Aug 25, 2019
Nov 27, 2020
Mar 4, 2018
Jun 5, 2018
Apr 18, 2014
Mar 19, 2020
Aug 20, 2020
Feb 18, 2017
Nov 27, 2020
Aug 20, 2020
Oct 13, 2017
Jan 24, 2017
Aug 22, 2018
Nov 27, 2020
Aug 24, 2018
Aug 25, 2019
Mar 6, 2018
Mar 6, 2018
Mar 19, 2020
Nov 27, 2020
Nov 27, 2020
Mar 19, 2020
Feb 5, 2019
Feb 5, 2019
Jul 18, 2017
Aug 22, 2018
Nov 23, 2017
Jan 1, 2017
Aug 24, 2018
Mar 19, 2020
Aug 22, 2018
Mar 6, 2019
Aug 22, 2020
Aug 24, 2018
Aug 24, 2018
Aug 24, 2018
Oct 6, 2018
Oct 6, 2018
Dec 1, 2017

Repository files navigation

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

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

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.

About

A fast, well-tested and widely used WebSocket implementation for Go.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 100.0%