2020-06-06 07:44:36 +00:00
|
|
|
package httputil
|
|
|
|
|
|
|
|
import (
|
2020-06-13 07:29:32 +00:00
|
|
|
"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
|
|
|
|
|
2020-06-13 07:29:32 +00:00
|
|
|
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
|
|
|
}
|
|
|
|
|
2020-06-13 07:29:32 +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
|
|
|
|
}
|