Compare commits
	
		
			13 Commits
		
	
	
		
			v0.12.10
			...
			0c9b20d47f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0c9b20d47f | |||
| 1e33734ab1 | |||
| 0c6e90e644 | |||
| 3d5a4a1482 | |||
| a0b561237a | |||
| ad1e06229f | |||
| e99a8dbcd6 | |||
| d3513ae4fa | |||
| 99264c6715 | |||
| 3c70ad2377 | |||
| af451c08b8 | |||
| 75fd09620c | |||
| 8fa8153ba6 | 
| @@ -7,15 +7,17 @@ import ( | ||||
| 	"net/http" | ||||
| 	"sync" | ||||
| 	"sync/atomic" | ||||
| 	"time" | ||||
| ) | ||||
|  | ||||
| var _ Server = (*event)(nil) | ||||
|  | ||||
| type Server interface { | ||||
| 	GinHandle(ctx *gin.Context, user any) | ||||
| 	HandlerFunc() mux.HandlerFunc | ||||
| 	Push(user, name, msg string) bool | ||||
| 	GinHandlerFunc(auth func(c *gin.Context) (string, error)) gin.HandlerFunc | ||||
| 	Push(user any, name, msg string) bool | ||||
| 	Broadcast(name, msg string) | ||||
| 	ClientCount() int32 | ||||
| } | ||||
|  | ||||
| type clientChan struct { | ||||
| @@ -31,9 +33,8 @@ type msgChan struct { | ||||
| type event struct { | ||||
| 	SessionList sync.Map | ||||
| 	Count       atomic.Int32 | ||||
|  | ||||
| 	Register   chan clientChan | ||||
| 	Unregister chan any | ||||
| 	Register    chan clientChan | ||||
| 	Unregister  chan any | ||||
| } | ||||
|  | ||||
| func NewServer() Server { | ||||
| @@ -67,44 +68,81 @@ func (stream *event) listen() { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (stream *event) GinHandle(ctx *gin.Context, user any) { | ||||
| 	if user == nil { | ||||
| 		ctx.AbortWithStatus(http.StatusUnauthorized) | ||||
| 		return | ||||
| 	} | ||||
| 	e := make(chan msgChan) | ||||
| 	client := clientChan{ | ||||
| 		User: user, | ||||
| 		Chan: e, | ||||
| 	} | ||||
| 	stream.Register <- client | ||||
| 	defer func() { | ||||
| 		stream.Unregister <- user | ||||
| 	}() | ||||
|  | ||||
| 	ctx.Writer.Header().Set("Content-Type", "text/event-stream") | ||||
| 	ctx.Writer.Header().Set("Cache-Control", "no-cache") | ||||
| 	ctx.Writer.Header().Set("Connection", "keep-alive") | ||||
| 	ctx.Writer.Header().Set("Transfer-Encoding", "chunked") | ||||
|  | ||||
| 	ctx.Stream(func(w io.Writer) bool { | ||||
| 		if msg, ok := <-e; ok { | ||||
| 			ctx.SSEvent(msg.Name, msg.Message) | ||||
| 			return true | ||||
| 		} | ||||
| 		return false | ||||
| 	}) | ||||
|  | ||||
| 	ctx.Next() | ||||
| } | ||||
|  | ||||
| func (stream *event) HandlerFunc() mux.HandlerFunc { | ||||
| 	return func(c mux.Context) { | ||||
| 		stream.GinHandle(c.Context(), c.Auth()) | ||||
| 		auth := c.Auth() | ||||
| 		if auth == nil { | ||||
| 			c.Context().AbortWithStatus(http.StatusBadRequest) | ||||
| 			return | ||||
| 		} | ||||
|  | ||||
| 		e := make(chan msgChan) | ||||
| 		client := clientChan{ | ||||
| 			User: auth, | ||||
| 			Chan: e, | ||||
| 		} | ||||
| 		stream.Register <- client | ||||
| 		defer func() { | ||||
| 			stream.Unregister <- auth | ||||
| 		}() | ||||
|  | ||||
| 		c.Context().Writer.Header().Set("Content-Type", "text/event-stream") | ||||
| 		c.Context().Writer.Header().Set("Cache-Control", "no-cache") | ||||
| 		c.Context().Writer.Header().Set("Connection", "keep-alive") | ||||
| 		c.Context().Writer.Header().Set("Transfer-Encoding", "chunked") | ||||
|  | ||||
| 		time.AfterFunc(time.Second, func() { | ||||
| 			e <- msgChan{Name: "message", Message: "success"} | ||||
| 		}) | ||||
|  | ||||
| 		c.Context().Stream(func(w io.Writer) bool { | ||||
| 			if msg, ok := <-e; ok { | ||||
| 				c.Context().SSEvent(msg.Name, msg.Message) | ||||
| 				return true | ||||
| 			} | ||||
| 			return false | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (stream *event) Push(user, name, msg string) bool { | ||||
| func (stream *event) GinHandlerFunc(auth func(c *gin.Context) (string, error)) gin.HandlerFunc { | ||||
| 	return func(c *gin.Context) { | ||||
| 		user, err := auth(c) | ||||
| 		if err != nil { | ||||
| 			c.AbortWithStatus(http.StatusBadRequest) | ||||
| 			return | ||||
| 		} | ||||
|  | ||||
| 		e := make(chan msgChan) | ||||
| 		client := clientChan{ | ||||
| 			User: user, | ||||
| 			Chan: e, | ||||
| 		} | ||||
| 		stream.Register <- client | ||||
| 		defer func() { | ||||
| 			stream.Unregister <- user | ||||
| 		}() | ||||
|  | ||||
| 		c.Writer.Header().Set("Content-Type", "text/event-stream") | ||||
| 		c.Writer.Header().Set("Cache-Control", "no-cache") | ||||
| 		c.Writer.Header().Set("Connection", "keep-alive") | ||||
| 		c.Writer.Header().Set("Transfer-Encoding", "chunked") | ||||
|  | ||||
| 		time.AfterFunc(time.Second, func() { | ||||
| 			e <- msgChan{Name: "message", Message: "success"} | ||||
| 		}) | ||||
|  | ||||
| 		c.Stream(func(w io.Writer) bool { | ||||
| 			if msg, ok := <-e; ok { | ||||
| 				c.SSEvent(msg.Name, msg.Message) | ||||
| 				return true | ||||
| 			} | ||||
| 			return false | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (stream *event) Push(user any, name, msg string) bool { | ||||
| 	value, ok := stream.SessionList.Load(user) | ||||
| 	if ok { | ||||
| 		val := value.(chan msgChan) | ||||
| @@ -120,3 +158,7 @@ func (stream *event) Broadcast(name, msg string) { | ||||
| 		return true | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| func (stream *event) ClientCount() int32 { | ||||
| 	return stream.Count.Load() | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user