Like Prometheus, but for logs.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
loki/pkg/dataobj/explorer/download.go

47 lines
1.3 KiB

package explorer
import (
"fmt"
"io"
"net/http"
"path"
"github.com/go-kit/log/level"
)
func (s *Service) handleDownload(w http.ResponseWriter, r *http.Request) {
if r.Method != http.MethodGet {
http.Error(w, "Method not allowed", http.StatusMethodNotAllowed)
return
}
filename := r.URL.Query().Get("file")
if filename == "" {
http.Error(w, "file parameter is required", http.StatusBadRequest)
return
}
attrs, err := s.bucket.Attributes(r.Context(), filename)
if err != nil {
level.Error(s.logger).Log("msg", "failed to get file attributes", "file", filename, "err", err)
http.Error(w, fmt.Sprintf("failed to get file: %v", err), http.StatusInternalServerError)
return
}
reader, err := s.bucket.Get(r.Context(), filename)
if err != nil {
level.Error(s.logger).Log("msg", "failed to get file", "file", filename, "err", err)
http.Error(w, fmt.Sprintf("failed to get file: %v", err), http.StatusInternalServerError)
return
}
defer reader.Close()
w.Header().Set("Content-Type", "application/octet-stream")
w.Header().Set("Content-Disposition", fmt.Sprintf(`attachment; filename="%s"`, path.Base(filename)))
w.Header().Set("Content-Length", fmt.Sprintf("%d", attrs.Size))
if _, err := io.Copy(w, reader); err != nil {
level.Error(s.logger).Log("msg", "failed to stream file", "file", filename, "err", err)
return
}
}