Skip to content

Commit

Permalink
Improve defer response.Body.Close() in SSE (#77)
Browse files Browse the repository at this point in the history
  • Loading branch information
andmat900 authored Sep 26, 2024
1 parent 2c8ae90 commit 9437993
Showing 1 changed file with 5 additions and 4 deletions.
9 changes: 5 additions & 4 deletions pkg/sse/v1/sse.go
Original file line number Diff line number Diff line change
Expand Up @@ -138,10 +138,10 @@ func GetFrom(ctx context.Context, url string, id string) ([]events.Event, error)
if err != nil {
return nil, err
}
defer response.Body.Close()

etosEvents := []events.Event{}
scanner := bufio.NewScanner(response.Body)
defer response.Body.Close()
for scanner.Scan() {
event, err := events.New(scanner.Bytes())
if err != nil {
Expand All @@ -154,7 +154,7 @@ func GetFrom(ctx context.Context, url string, id string) ([]events.Event, error)
}

// GetOne gets a single event from an ESR instance.
func GetOne(ctx context.Context, url string, id string) (events.Event, error) {
func GetOne(ctx context.Context, logger *logrus.Entry, url string, id string) (events.Event, error) {
event := events.Event{}
request, err := http.NewRequestWithContext(ctx, http.MethodGet, url, nil)
if err != nil {
Expand All @@ -169,12 +169,13 @@ func GetOne(ctx context.Context, url string, id string) (events.Event, error) {
if err != nil {
return event, err
}
defer response.Body.Close()

body, err := io.ReadAll(response.Body)
if err != nil {
logger.Errorf("Request failed (could not read response body): %+v", request)
return event, err
}
defer response.Body.Close()
return events.New(body)
}

Expand Down Expand Up @@ -208,7 +209,7 @@ func (h SSEHandler) GetEvent(w http.ResponseWriter, r *http.Request, ps httprout
return
}

event, err := GetOne(r.Context(), url, counter)
event, err := GetOne(r.Context(), logger, url, counter)
if err != nil {
logger.Error(err)
// TODO: Message client
Expand Down

0 comments on commit 9437993

Please sign in to comment.