Nenhuma descrição

thinkerou 43f0f29dbd chore: remove go1.8/1.9 and support go1.13 5 anos atrás
.travis.yml 43f0f29dbd chore: remove go1.8/1.9 and support go1.13 5 anos atrás
LICENSE b7eeebd898 Adds MIT license (file) 9 anos atrás
README.md 22d885f9ec Update .travis.yml, update README.md and add support for gin-gonic/gin/pull/781 7 anos atrás
go.mod 47eaab5c5b add go module file 5 anos atrás
go.sum 47eaab5c5b add go module file 5 anos atrás
sse-decoder.go ee05b128a7 Adds some comments 8 anos atrás
sse-decoder_test.go fe6ea2c8e3 Conforms to w3.org standard + experimental decoder 9 anos atrás
sse-encoder.go 22d885f9ec Update .travis.yml, update README.md and add support for gin-gonic/gin/pull/781 7 anos atrás
sse_test.go a7658810eb Update sse_test.go 5 anos atrás
writer.go 404710eaa4 Performance improvements. 9 anos atrás

README.md

Server-Sent Events

GoDoc Build Status codecov Go Report Card

Server-sent events (SSE) is a technology where a browser receives automatic updates from a server via HTTP connection. The Server-Sent Events EventSource API is standardized as part of HTML5[1] by the W3C.

Sample code

import "github.com/gin-contrib/sse"

func httpHandler(w http.ResponseWriter, req *http.Request) {
	// data can be a primitive like a string, an integer or a float
	sse.Encode(w, sse.Event{
		Event: "message",
		Data:  "some data\nmore data",
	})

	// also a complex type, like a map, a struct or a slice
	sse.Encode(w, sse.Event{
		Id:    "124",
		Event: "message",
		Data: map[string]interface{}{
			"user":    "manu",
			"date":    time.Now().Unix(),
			"content": "hi!",
		},
	})
}
event: message
data: some data\\nmore data

id: 124
event: message
data: {"content":"hi!","date":1431540810,"user":"manu"}
 

Content-Type

fmt.Println(sse.ContentType)
text/event-stream

Decoding support

There is a client-side implementation of SSE coming soon.