forked from mhausenblas/burry.sh
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathauxiliary.go
131 lines (123 loc) · 3.87 KB
/
auxiliary.go
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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
package main
import (
"fmt"
log "github.com/sirupsen/logrus"
azip "github.com/pierrre/archivefile/zip"
"io/ioutil"
"os"
"path/filepath"
"strings"
)
func about() {
fmt.Printf("This is burry in version %s\n", VERSION)
}
// lookupst returns the storage target index
// based on a name (or -1 if not known)
func lookupst(name string) int {
switch strings.ToLower(name) {
case STORAGE_TARGET_TTY:
return 0
case STORAGE_TARGET_LOCAL:
return 1
case STORAGE_TARGET_S3:
return 2
case STORAGE_TARGET_MINIO:
return 3
default:
return -1
}
}
// reapsimple reaps a node at a path.
// note that the actual processing is
// determined by the storage target
func reapsimple(path string, val string) {
stidx := lookupst(brf.StorageTarget)
switch {
case stidx == 0: // TTY
log.WithFields(log.Fields{"func": "reapsimple"}).Info(fmt.Sprintf("%s", path))
log.WithFields(log.Fields{"func": "reapsimple"}).Debug(fmt.Sprintf("%v", val))
case stidx >= 1: // some kind of actual storage
store(path, val)
default:
log.WithFields(log.Fields{"func": "reapsimple"}).Fatal(fmt.Sprintf("Storage target %s unknown or not yet supported", brf.StorageTarget))
}
}
// store stores value val at path path
// in the local filesystem
func store(path string, val string) {
cwd, _ := os.Getwd()
fpath := ""
if path == "/" {
log.WithFields(log.Fields{"func": "store"}).Info(fmt.Sprintf("Rewriting root"))
fpath, _ = filepath.Abs(filepath.Join(cwd, based))
} else {
// escape ":" in the path so that we have no issues storing it in the filesystem:
fpath, _ = filepath.Abs(filepath.Join(cwd, based, strings.Replace(path, ":", "BURRY_ESC_COLON", -1)))
}
if err := os.MkdirAll(fpath, os.ModePerm); err != nil {
log.WithFields(log.Fields{"func": "store"}).Error(fmt.Sprintf("%s", err))
return
} else {
cpath, _ := filepath.Abs(filepath.Join(fpath, CONTENT_FILE))
if c, cerr := os.Create(cpath); cerr != nil {
log.WithFields(log.Fields{"func": "store"}).Error(fmt.Sprintf("%s", cerr))
} else {
defer c.Close()
if nbytes, err := c.WriteString(val); err != nil {
log.WithFields(log.Fields{"func": "store"}).Error(fmt.Sprintf("%s", err))
} else {
log.WithFields(log.Fields{"func": "store"}).Debug(fmt.Sprintf("Stored %s in %s with %d bytes", path, fpath, nbytes))
}
}
}
}
// arch creates a ZIP archive of snapshot that store() has generated
func arch() string {
defer func() {
_ = os.RemoveAll(based)
}()
cwd, _ := os.Getwd()
opath := filepath.Join(cwd, based+".zip")
ipath := filepath.Join(cwd, based, "/")
progress := func(apath string) {
log.WithFields(log.Fields{"func": "arch"}).Debug(fmt.Sprintf("%s", apath))
}
// add metadata ot the archive:
addmeta(ipath)
if err := azip.ArchiveFile(ipath, opath, progress); err != nil {
log.WithFields(log.Fields{"func": "arch"}).Panic(fmt.Sprintf("%s", err))
} else {
log.WithFields(log.Fields{"func": "arch"}).Debug(fmt.Sprintf("Backup available in %s", opath))
}
return opath
}
// unarch creates a directory with contents of the snapshot
// based on the ZIP archive from an earlier backup operation
func unarch(localarch string) string {
cwd, _ := os.Getwd()
ipath := localarch
opath := cwd
progress := func(apath string) {
log.WithFields(log.Fields{"func": "unarch"}).Debug(fmt.Sprintf("%s", apath))
}
if err := azip.UnarchiveFile(ipath, opath, progress); err != nil {
log.WithFields(log.Fields{"func": "unarch"}).Panic(fmt.Sprintf("%s", err))
} else {
log.WithFields(log.Fields{"func": "unarch"}).Debug(fmt.Sprintf("Backup restored in %s", opath))
}
return filepath.Join(cwd, based, "/")
}
// readc reads a file from the specified path and
// returns its content as a byte slice
func readc(path string) ([]byte, error) {
c := []byte{}
if _, ferr := os.Stat(path); ferr != nil {
return c, ferr
} else { // content file exists
if c, rerr := ioutil.ReadFile(path); rerr != nil {
return c, rerr
} else {
return c, nil
}
}
}