justlog/archiver/gzip.go

48 lines
1,003 B
Go
Raw Permalink Normal View History

2018-12-06 22:58:42 +01:00
package archiver
import (
"bufio"
"compress/gzip"
"io/ioutil"
"os"
2018-12-06 23:03:58 +01:00
log "github.com/sirupsen/logrus"
2018-12-06 22:58:42 +01:00
)
func (a *Archiver) gzipFile(filePath string) {
file, err := os.Open(filePath)
if err != nil {
log.Errorf("File not found: %s Error: %s", filePath, err.Error())
return
}
defer file.Close()
2018-12-06 23:03:58 +01:00
log.Infof("Archiving: %s", filePath)
2018-12-06 22:58:42 +01:00
reader := bufio.NewReader(file)
content, err := ioutil.ReadAll(reader)
if err != nil {
log.Errorf("Failure reading file: %s Error: %s", filePath, err.Error())
return
}
gzipFile, err := os.Create(filePath + ".gz")
if err != nil {
log.Errorf("Failure creating file: %s.gz Error: %s", filePath, err.Error())
return
}
defer gzipFile.Close()
w := gzip.NewWriter(gzipFile)
_, err = w.Write(content)
if err != nil {
log.Errorf("Failure writing content in file: %s.gz Error: %s", filePath, err.Error())
}
w.Close()
err = os.Remove(filePath)
if err != nil {
log.Errorf("Failure deleting file: %s Error: %s", filePath, err.Error())
}
}