seaweedfs/weed/operation/compress.go

60 lines
1.3 KiB
Go
Raw Normal View History

package operation
import (
"bytes"
"compress/flate"
"compress/gzip"
"io/ioutil"
"strings"
"github.com/chrislusf/seaweedfs/weed/glog"
)
/*
* Default more not to gzip since gzip can be done on client side.
2013-02-27 14:54:22 +08:00
*/
2012-10-24 01:59:40 +08:00
func IsGzippable(ext, mtype string) bool {
2013-01-17 16:56:56 +08:00
if strings.HasPrefix(mtype, "text/") {
return true
}
2013-01-17 16:56:56 +08:00
switch ext {
case ".zip", ".rar", ".gz", ".bz2", ".xz":
return false
2014-07-09 00:32:55 +08:00
case ".pdf", ".txt", ".html", ".htm", ".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
}
2013-01-17 16:56:56 +08:00
func GzipData(input []byte) ([]byte, error) {
buf := new(bytes.Buffer)
w, _ := gzip.NewWriterLevel(buf, flate.BestCompression)
if _, err := w.Write(input); err != nil {
glog.V(2).Infoln("error compressing data:", err)
2013-01-17 16:56:56 +08:00
return nil, err
}
if err := w.Close(); err != nil {
glog.V(2).Infoln("error closing compressed data:", err)
2013-01-17 16:56:56 +08:00
return nil, err
}
2013-01-17 16:56:56 +08:00
return buf.Bytes(), nil
}
2013-01-17 16:56:56 +08:00
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 {
glog.V(2).Infoln("error uncompressing data:", err)
}
2013-01-17 16:56:56 +08:00
return output, err
}