From 36684273411a56847b08752d4975ea4045bd2a6a Mon Sep 17 00:00:00 2001 From: Starnop Date: Tue, 7 May 2019 11:31:18 +0800 Subject: [PATCH] feature: implement the http util IsExpired Signed-off-by: Starnop --- common/util/http_util.go | 35 ++++++++++++++++++++++++++++++++++- 1 file changed, 34 insertions(+), 1 deletion(-) diff --git a/common/util/http_util.go b/common/util/http_util.go index d0f2f465a..4bec64f79 100644 --- a/common/util/http_util.go +++ b/common/util/http_util.go @@ -23,6 +23,7 @@ import ( "net" "net/http" "reflect" + "strconv" "strings" "time" @@ -190,7 +191,12 @@ func Do(url string, headers map[string]string, timeout time.Duration) (string, e // HTTPGetWithHeaders send an HTTP GET request with headers. func HTTPGetWithHeaders(url string, headers map[string]string) (*http.Response, error) { - req, err := http.NewRequest("GET", url, nil) + return HTTPWithHeaders("GET", url, headers) +} + +// HTTPWithHeaders send an HTTP request with headers and specified method. +func HTTPWithHeaders(method, url string, headers map[string]string) (*http.Response, error) { + req, err := http.NewRequest(method, url, nil) if err != nil { return nil, err } @@ -253,3 +259,30 @@ func CheckConnect(ip string, port int, timeout int) (localIP string, e error) { } return } + +// IsExpired checks if a resource received or stored is the same. +func IsExpired(url string, headers map[string]string, lastModified int64, eTag string) (bool, error) { + if lastModified <= 0 && IsEmptyStr(eTag) { + return true, nil + } + + // set headers + if headers == nil { + headers = make(map[string]string) + } + if lastModified > 0 { + headers["If-Modified-Since"] = strconv.FormatInt(lastModified, 10) + } + if !IsEmptyStr(eTag) { + headers["If-None-Match"] = eTag + } + + // send request + resp, err := HTTPWithHeaders("HEAD", url, headers) + if err != nil { + return false, err + } + resp.Body.Close() + + return resp.StatusCode != http.StatusNotModified, nil +}