diff options
Diffstat (limited to 'src/weed/storage/compress.go')
| -rw-r--r-- | src/weed/storage/compress.go | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/src/weed/storage/compress.go b/src/weed/storage/compress.go new file mode 100644 index 000000000..256789c9c --- /dev/null +++ b/src/weed/storage/compress.go @@ -0,0 +1,57 @@ +package storage + +import ( + "bytes" + "compress/flate" + "compress/gzip" + "io/ioutil" + "strings" +) + +/* +* Default more not to gzip since gzip can be done on client side. +*/ +func IsGzippable(ext, mtype string) bool { + if strings.HasPrefix(mtype, "text/") { + return true + } + switch ext { + case ".zip", ".rar", ".gz", ".bz2", ".xz": + return false + case ".pdf", ".txt", ".html", ".css", ".js", ".json": + return true + } + if strings.HasPrefix(mtype, "application/") { + if strings.HasSuffix(mtype, "xml") { + return true + } + if strings.HasSuffix(mtype, "script") { + return true + } + } + return false +} + +func GzipData(input []byte) ([]byte, error) { + buf := new(bytes.Buffer) + w, _ := gzip.NewWriterLevel(buf, flate.BestCompression) + if _, err := w.Write(input); err != nil { + println("error compressing data:", err) + return nil, err + } + if err := w.Close(); err != nil { + println("error closing compressed data:", err) + return nil, err + } + return buf.Bytes(), nil +} +func UnGzipData(input []byte) ([]byte, error) { + buf := bytes.NewBuffer(input) + r, _ := gzip.NewReader(buf) + defer r.Close() + output, err := ioutil.ReadAll(r) + if err != nil { + println("error uncompressing data:", err) + } + return output, err +} |
