Something went wrong on our end
-
Christian Pointner authoredChristian Pointner authored
utils.go 1.66 KiB
//
// tank
//
// Import and Playlist Daemon for autoradio project
//
//
// Copyright (C) 2017-2019 Christian Pointner <equinox@helsinki.at>
//
// This file is part of tank.
//
// tank is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// any later version.
//
// tank is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with tank. If not, see <http://www.gnu.org/licenses/>.
//
package auth
import (
"crypto/rand"
"encoding/base64"
"encoding/json"
"net/http"
)
type contextKey int
var (
sessionContextKey contextKey
)
func generateRandomString(len int) (string, error) {
b := make([]byte, len)
if _, err := rand.Read(b[:]); err != nil {
return "", err
}
return base64.RawURLEncoding.EncodeToString(b[:]), nil
}
type HTTPResponse struct {
Message string `json:"message,omitempty"`
Error string `json:"error,omitempty"`
}
func sendHTTPResponse(w http.ResponseWriter, status int, resp HTTPResponse) {
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(status)
json.NewEncoder(w).Encode(resp) // TODO: Error Handling?
}
func sendHTTPResponseInvalidSession(w http.ResponseWriter) {
resp := HTTPResponse{Error: "Request does not contain a valid session cookie or session is already expired."}
sendHTTPResponse(w, http.StatusUnauthorized, resp)
}