From 916e778dfccc2aa5ce95056b97e11f134bc941f7 Mon Sep 17 00:00:00 2001 From: demo Date: Sun, 10 May 2026 21:56:24 -0400 Subject: refactor: move 'fetch' to its own package --- internal/fetch/fetch.go | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 internal/fetch/fetch.go (limited to 'internal/fetch/fetch.go') diff --git a/internal/fetch/fetch.go b/internal/fetch/fetch.go new file mode 100644 index 0000000..f508922 --- /dev/null +++ b/internal/fetch/fetch.go @@ -0,0 +1,32 @@ +package fetch + +import ( + "bufio" + "fmt" + "io" + "net/http" + "time" +) + +func fetch(rawURL string, timeoutSecs int) (io.Reader, error) { + client := http.Client{ + Timeout: time.Duration(timeoutSecs) * time.Second, + } + + req, err := http.NewRequest(http.MethodGet, rawURL, nil) + if err != nil { + return nil, fmt.Errorf("can't create %s request for %s", http.MethodGet, rawURL) + } + + resp, err := client.Do(req) + if err != nil { + return nil, fmt.Errorf("client failed to perform %s request for %s", http.MethodGet, rawURL) + } + defer resp.Body.Close() + + if resp.StatusCode != http.StatusOK { + return nil, fmt.Errorf("status for %s for %s: %s", http.MethodGet, rawURL, resp.Status) + } + + return bufio.NewReader(resp.Body), nil +} -- cgit v1.2.3