From 906388d91a0017a90a158ddb6a102cd4af798d3b Mon Sep 17 00:00:00 2001 From: Brad Fitzpatrick Date: Sat, 5 Jan 2013 17:17:38 -0800 Subject: [PATCH] get handler: remove old sniffing for demos which no longer works and makes things much slower Change-Id: I1d9e7368881894cba9a1febab6c5efcf765b0d59 --- pkg/blobserver/gethandler/get.go | 26 ++------------------------ 1 file changed, 2 insertions(+), 24 deletions(-) diff --git a/pkg/blobserver/gethandler/get.go b/pkg/blobserver/gethandler/get.go index 946099dbe..142cb1f2c 100644 --- a/pkg/blobserver/gethandler/get.go +++ b/pkg/blobserver/gethandler/get.go @@ -17,7 +17,6 @@ limitations under the License. package gethandler import ( - "bufio" "bytes" "encoding/json" "fmt" @@ -30,13 +29,12 @@ import ( "strconv" "strings" "time" - "unicode/utf8" "camlistore.org/pkg/auth" "camlistore.org/pkg/blobref" "camlistore.org/pkg/blobserver" "camlistore.org/pkg/httputil" - "camlistore.org/pkg/misc/httprange" + "camlistore.org/pkg/misc/httprange" // TODO: delete this package, use http.ServeContent ) var kGetPattern *regexp.Regexp = regexp.MustCompile(`/camli/([a-z0-9]+)-([a-f0-9]+)$`) @@ -126,31 +124,11 @@ func serveBlobRef(conn http.ResponseWriter, req *http.Request, remainBytes = reqRange.LimitBytes() } - // Assume this generic content type by default. For better - // demos we'll try to sniff and guess the "right" MIME type in - // certain cases (no Range requests, etc) but this isn't part - // of the Camli spec at all. We just do it to ease demos. - contentType := "application/octet-stream" if reqRange.IsWholeFile() { - const peekSize = 1024 - bufReader := bufio.NewReaderSize(input, peekSize) - header, _ := bufReader.Peek(peekSize) - if len(header) >= 8 { - switch { - case utf8.Valid(header): - contentType = "text/plain; charset=utf-8" - case bytes.HasPrefix(header, []byte{0xff, 0xd8, 0xff, 0xe2}): - contentType = "image/jpeg" - case bytes.HasPrefix(header, []byte{0x89, 0x50, 0x4e, 0x47, 0xd, 0xa, 0x1a, 0xa}): - contentType = "image/png" - } - } - input = bufReader - conn.Header().Set("Content-Length", strconv.FormatInt(size, 10)) } - conn.Header().Set("Content-Type", contentType) + conn.Header().Set("Content-Type", "application/octet-stream") if !reqRange.IsWholeFile() { conn.Header().Set("Content-Range", fmt.Sprintf("bytes %d-%d/%d", reqRange.SkipBytes(),