cchat-gtk/internal/gts/httputil/httputil.go

59 lines
1.4 KiB
Go
Raw Normal View History

2020-06-06 07:44:36 +00:00
package httputil
import (
"context"
2020-06-06 07:44:36 +00:00
"net/http"
"os"
"path/filepath"
"time"
"github.com/gregjones/httpcache"
"github.com/gregjones/httpcache/diskcache"
"github.com/peterbourgon/diskv"
"github.com/pkg/errors"
)
2021-01-05 02:05:33 +00:00
var basePath = filepath.Join(os.TempDir(), "cchat-gtk-caching-is-hard")
2020-06-06 07:44:36 +00:00
2020-07-10 23:26:07 +00:00
var dskcached = http.Client{
Timeout: 15 * time.Second,
2021-01-05 02:05:33 +00:00
Transport: &httpcache.Transport{
Transport: &http.Transport{
// Be generous: use a 128KB buffer instead of 4KB to hopefully
// reduce cgo calls.
WriteBufferSize: 128 * 1024,
ReadBufferSize: 128 * 1024,
},
Cache: diskcache.NewWithDiskv(diskv.New(diskv.Options{
2020-06-06 07:44:36 +00:00
BasePath: basePath,
TempDir: filepath.Join(basePath, "tmp"),
PathPerm: 0750,
FilePerm: 0750,
2021-01-05 02:05:33 +00:00
Compression: diskv.NewZlibCompressionLevel(4),
CacheSizeMax: 25 * 1024 * 1024, // 25 MiB in memory
2020-06-06 07:44:36 +00:00
})),
2021-01-05 02:05:33 +00:00
MarkCachedResponses: true,
},
2020-06-06 07:44:36 +00:00
}
2021-01-05 02:05:33 +00:00
// TODO: log cache misses with httpcache.XFromCache
func get(ctx context.Context, url string, cached bool) (r *http.Response, err error) {
q, err := http.NewRequestWithContext(ctx, "GET", url, nil)
if err != nil {
return nil, errors.Wrap(err, "Failed to make a request")
2020-06-06 07:44:36 +00:00
}
r, err = dskcached.Do(q)
2020-06-06 07:44:36 +00:00
if err != nil {
return nil, err
}
if r.StatusCode < 200 || r.StatusCode > 299 {
r.Body.Close()
return nil, errors.Errorf("Unexpected status %d", r.StatusCode)
}
return r, nil
}