1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
package archive
import (
"archive/tar"
fp "path/filepath"
"compress/gzip"
"io"
"os"
"strings"
)
type Unarchive struct {
Input string
tarReader *tar.Reader
}
// Extracts a tar arcive to the current working directory
// This will overwrite everything. So be careful
func (u *Unarchive) UnTar(compressionType string) error {
f, err := os.Open(u.Input)
if err != nil {
return err
}
defer f.Close()
var treader *tar.Reader
switch compressionType {
case "gz":
gzreader, err := gzip.NewReader(f)
if err != nil {
return err
}
// Read from the gzip reader instead of the file
treader = tar.NewReader(gzreader)
default:
// Read from the file directly
treader = tar.NewReader(f)
}
for {
hdr, err := treader.Next()
if err == io.EOF {
// We've reached the end! Whoee
break
}
if err != nil {
return err
}
// Fix windows slashes...
fileName := strings.Replace(hdr.Name, "\\", "/", -1)
info := hdr.FileInfo()
if info.IsDir() {
// I don't like hard-coded permissions but it
// it helps with overall platform compatibility
if err = os.MkdirAll(fileName, 0775); err != nil {
return err
}
continue
}
if err = os.MkdirAll(fp.Dir(fileName), 0775); err != nil {
return err
}
// Create a file handle to work with
// f, err := os.Create(fileName)
f, err := os.OpenFile(fileName, os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0664)
if err != nil {
return err
}
defer f.Close()
if _, err := io.Copy(f, treader); err != nil {
return err
}
}
return nil
}
|