Semaphore/util/util.go
tom whiston 17fa7bb407 add gometalinter to tools and run it in circle.
extract some error checking and logging in places where linting needed or errors not checked
2018-04-05 21:24:19 +00:00

53 lines
1.3 KiB
Go

package util
import (
"net/http"
"strconv"
"strings"
"github.com/gorilla/mux"
log "github.com/Sirupsen/logrus"
)
func isXHR(w http.ResponseWriter, r *http.Request) bool {
accept := r.Header.Get("Accept")
return !strings.Contains(accept, "text/html")
}
// AuthFailed write a status unauthorized header unless it is an XHR request
// TODO - never called!
func AuthFailed(w http.ResponseWriter, r *http.Request) {
if !isXHR(w, r) {
http.Redirect(w, r, "/?hai", http.StatusFound)
return
}
w.WriteHeader(http.StatusUnauthorized)
}
// GetIntParam fetches a parameter from the route variables as an integer
// redirects to a 404 or writes bad request state depending on error state
func GetIntParam(name string, w http.ResponseWriter, r *http.Request) (int, error) {
intParam, err := strconv.Atoi(mux.Vars(r)[name])
if err != nil {
if !isXHR(w, r) {
http.Redirect(w, r, "/404", http.StatusFound)
} else {
w.WriteHeader(http.StatusBadRequest)
}
return 0, err
}
return intParam, nil
}
// ScanErrorChecker deals with errors encountered while scanning lines
// since we do not fail on these errors currently we can simply note them
// and move on
func ScanErrorChecker(n int, err error) {
if err != nil {
log.Warn("An input error occured:" + err.Error())
}
}