Make names more consistent

This commit is contained in:
Deluan 2020-12-12 13:46:36 -05:00
parent e2969aa34c
commit 17833cd9d2

View File

@ -45,13 +45,13 @@ func (c client) String() string {
type broker struct { type broker struct {
// Events are pushed to this channel by the main events-gathering routine // Events are pushed to this channel by the main events-gathering routine
notifier messageChan publish messageChan
// New client connections // New client connections
newClients clientsChan subscribing clientsChan
// Closed client connections // Closed client connections
closingClients clientsChan unsubscribing clientsChan
// Client connections registry // Client connections registry
clients map[client]struct{} clients map[client]struct{}
@ -60,10 +60,10 @@ type broker struct {
func NewBroker() Broker { func NewBroker() Broker {
// Instantiate a broker // Instantiate a broker
broker := &broker{ broker := &broker{
notifier: make(messageChan, 100), publish: make(messageChan, 100),
newClients: make(clientsChan, 1), subscribing: make(clientsChan, 1),
closingClients: make(clientsChan, 1), unsubscribing: make(clientsChan, 1),
clients: make(map[client]struct{}), clients: make(map[client]struct{}),
} }
// Set it running - listening and broadcasting events // Set it running - listening and broadcasting events
@ -72,22 +72,26 @@ func NewBroker() Broker {
return broker return broker
} }
func (broker *broker) SendMessage(evt Event) { func (b *broker) SendMessage(evt Event) {
msg := broker.preparePackage(evt) msg := b.preparePackage(evt)
log.Trace("Broker received new event", "event", msg) log.Trace("Broker received new event", "event", msg)
broker.notifier <- msg b.publish <- msg
} }
func (broker *broker) preparePackage(event Event) message { func (b *broker) newEventID() uint32 {
return atomic.AddUint32(&eventId, 1)
}
func (b *broker) preparePackage(event Event) message {
pkg := message{} pkg := message{}
pkg.ID = atomic.AddUint32(&eventId, 1) pkg.ID = b.newEventID()
pkg.Event = event.EventName() pkg.Event = event.EventName()
data, _ := json.Marshal(event) data, _ := json.Marshal(event)
pkg.Data = string(data) pkg.Data = string(data)
return pkg return pkg
} }
func (broker *broker) ServeHTTP(w http.ResponseWriter, r *http.Request) { func (b *broker) ServeHTTP(w http.ResponseWriter, r *http.Request) {
ctx := r.Context() ctx := r.Context()
// Make sure that the writer supports flushing. // Make sure that the writer supports flushing.
@ -106,31 +110,31 @@ func (broker *broker) ServeHTTP(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Access-Control-Allow-Origin", "*") w.Header().Set("Access-Control-Allow-Origin", "*")
// Each connection registers its own message channel with the Broker's connections registry // Each connection registers its own message channel with the Broker's connections registry
client := broker.subscribe(r) c := b.subscribe(r)
defer broker.unsubscribe(client) defer b.unsubscribe(c)
log.Debug(ctx, "New broker client", "client", client.String()) log.Debug(ctx, "New broker client", "client", c.String())
for { for {
select { select {
case event := <-client.channel: case event := <-c.channel:
// Write to the ResponseWriter // Write to the ResponseWriter
// Server Sent Events compatible // Server Sent Events compatible
log.Trace(ctx, "Sending event to client", "event", event, "client", client.String()) log.Trace(ctx, "Sending event to client", "event", event, "client", c.String())
_, _ = fmt.Fprintf(w, "id: %d\nevent: %s\ndata: %s\n\n", event.ID, event.Event, event.Data) _, _ = fmt.Fprintf(w, "id: %d\nevent: %s\ndata: %s\n\n", event.ID, event.Event, event.Data)
// Flush the data immediately instead of buffering it for later. // Flush the data immediately instead of buffering it for later.
flusher.Flush() flusher.Flush()
case <-ctx.Done(): case <-ctx.Done():
log.Trace(ctx, "Closing event stream connection", "client", client.String()) log.Trace(ctx, "Closing event stream connection", "client", c.String())
return return
} }
} }
} }
func (broker *broker) subscribe(r *http.Request) client { func (b *broker) subscribe(r *http.Request) client {
user, _ := request.UserFrom(r.Context()) user, _ := request.UserFrom(r.Context())
id, _ := uuid.NewRandom() id, _ := uuid.NewRandom()
client := client{ c := client{
id: id.String(), id: id.String(),
username: user.UserName, username: user.UserName,
address: r.RemoteAddr, address: r.RemoteAddr,
@ -139,40 +143,40 @@ func (broker *broker) subscribe(r *http.Request) client {
} }
// Signal the broker that we have a new client // Signal the broker that we have a new client
broker.newClients <- client b.subscribing <- c
return client return c
} }
func (broker *broker) unsubscribe(c client) { func (b *broker) unsubscribe(c client) {
broker.closingClients <- c b.unsubscribing <- c
} }
func (broker *broker) listen() { func (b *broker) listen() {
keepAlive := time.NewTicker(keepAliveFrequency) keepAlive := time.NewTicker(keepAliveFrequency)
defer keepAlive.Stop() defer keepAlive.Stop()
for { for {
select { select {
case s := <-broker.newClients: case c := <-b.subscribing:
// A new client has connected. // A new client has connected.
// Register their message channel // Register their message channel
broker.clients[s] = struct{}{} b.clients[c] = struct{}{}
log.Debug("Client added to event broker", "numClients", len(broker.clients), "newClient", s.String()) log.Debug("Client added to event broker", "numClients", len(b.clients), "newClient", c.String())
// Send a serverStart event to new client // Send a serverStart event to new client
s.channel <- broker.preparePackage(&ServerStart{serverStart}) c.channel <- b.preparePackage(&ServerStart{serverStart})
case s := <-broker.closingClients: case c := <-b.unsubscribing:
// A client has detached and we want to // A client has detached and we want to
// stop sending them messages. // stop sending them messages.
close(s.channel) close(c.channel)
delete(broker.clients, s) delete(b.clients, c)
log.Debug("Removed client from event broker", "numClients", len(broker.clients), "client", s.String()) log.Debug("Removed client from event broker", "numClients", len(b.clients), "client", c.String())
case event := <-broker.notifier: case event := <-b.publish:
// We got a new event from the outside! // We got a new event from the outside!
// Send event to all connected clients // Send event to all connected clients
for client := range broker.clients { for client := range b.clients {
log.Trace("Putting event on client's queue", "client", client.String(), "event", event) log.Trace("Putting event on client's queue", "client", client.String(), "event", event)
// Use non-blocking send // Use non-blocking send
select { select {
@ -184,7 +188,7 @@ func (broker *broker) listen() {
case ts := <-keepAlive.C: case ts := <-keepAlive.C:
// Send a keep alive message every 15 seconds // Send a keep alive message every 15 seconds
broker.SendMessage(&KeepAlive{TS: ts.Unix()}) b.SendMessage(&KeepAlive{TS: ts.Unix()})
} }
} }
} }