1
0
Fork 0
mirror of https://github.com/restic/restic.git synced 2025-01-05 06:55:23 +00:00
restic/storagetest/main.go

142 lines
2.6 KiB
Go
Raw Normal View History

2014-04-19 17:46:20 +00:00
package main
import (
2014-04-21 21:25:31 +00:00
"bytes"
2014-04-19 17:46:20 +00:00
"crypto/sha256"
"io"
"log"
"os"
2014-04-21 21:25:31 +00:00
"path/filepath"
2014-04-19 17:46:20 +00:00
"github.com/fd0/khepri/storage"
)
func hash(filename string) (storage.ID, error) {
h := sha256.New()
f, err := os.Open(filename)
if err != nil {
return nil, err
}
io.Copy(h, f)
return h.Sum([]byte{}), nil
}
2014-04-21 21:25:31 +00:00
func archive_dir(repo storage.Repository, path string) (storage.ID, error) {
2014-04-20 14:48:47 +00:00
log.Printf("archiving dir %q", path)
2014-04-21 21:25:31 +00:00
dir, err := os.Open(path)
if err != nil {
log.Printf("open(%q): %v\n", path, err)
return nil, err
}
entries, err := dir.Readdir(-1)
if err != nil {
log.Printf("readdir(%q): %v\n", path, err)
return nil, err
}
// use nil ID for empty directories
if len(entries) == 0 {
return nil, nil
}
2014-04-21 21:25:31 +00:00
t := storage.NewTree()
for _, e := range entries {
node := storage.NodeFromFileInfo(e)
var id storage.ID
var err error
2014-04-20 14:48:47 +00:00
2014-04-21 21:25:31 +00:00
if e.IsDir() {
id, err = archive_dir(repo, filepath.Join(path, e.Name()))
} else {
id, err = repo.PutFile(filepath.Join(path, e.Name()))
}
node.Content = id
2014-04-20 14:48:47 +00:00
2014-04-21 21:25:31 +00:00
t.Nodes = append(t.Nodes, node)
2014-04-20 14:48:47 +00:00
2014-04-21 21:25:31 +00:00
if err != nil {
log.Printf(" error storing %q: %v\n", e.Name(), err)
continue
}
}
log.Printf(" dir %q: %v entries", path, len(t.Nodes))
var buf bytes.Buffer
t.Save(&buf)
id, err := repo.PutRaw(buf.Bytes())
if err != nil {
log.Printf("error saving tree to repo: %v", err)
}
log.Printf("tree for %q saved at %s", path, id)
return id, nil
2014-04-20 14:48:47 +00:00
}
2014-04-19 17:46:20 +00:00
func main() {
2014-04-21 21:25:31 +00:00
if len(os.Args) <= 2 {
log.Fatalf("usage: %s repo [add|link|putdir] ...", os.Args[0])
}
repo, err := storage.NewDirRepository(os.Args[1])
2014-04-19 17:46:20 +00:00
if err != nil {
log.Fatalf("error: %v", err)
}
2014-04-21 21:25:31 +00:00
switch os.Args[2] {
2014-04-19 17:46:20 +00:00
case "add":
2014-04-21 21:25:31 +00:00
for _, file := range os.Args[3:] {
2014-04-19 17:46:20 +00:00
f, err := os.Open(file)
if err != nil {
log.Printf("error opening file %q: %v", file, err)
continue
}
id, err := repo.Put(f)
if err != nil {
log.Printf("Put() error: %v", err)
continue
}
log.Printf("archived file %q as ID %v", file, id)
}
case "link":
2014-04-21 21:25:31 +00:00
file := os.Args[3]
name := os.Args[4]
2014-04-19 17:46:20 +00:00
id, err := hash(file)
if err != nil {
log.Fatalf("error hashing filq %q: %v", file, err)
}
present, err := repo.Test(id)
if err != nil {
log.Fatalf("error testing presence of id %v: %v", id, err)
}
if !present {
log.Printf("adding file to repo as ID %v", id)
_, err = repo.PutFile(file)
if err != nil {
log.Fatalf("error adding file %q: %v", file, err)
}
}
err = repo.Link(name, id)
if err != nil {
log.Fatalf("error linking name %q to id %v", name, id)
}
2014-04-20 14:48:47 +00:00
case "putdir":
2014-04-21 21:25:31 +00:00
for _, dir := range os.Args[3:] {
2014-04-20 14:48:47 +00:00
archive_dir(repo, dir)
}
2014-04-19 17:46:20 +00:00
default:
2014-04-21 21:25:31 +00:00
log.Fatalf("unknown command: %q", os.Args[2])
2014-04-19 17:46:20 +00:00
}
}