mirror of
https://github.com/octoleo/restic.git
synced 2024-11-25 06:07:44 +00:00
Add command "key list"
This commit is contained in:
parent
ad7e1d043f
commit
d0a63cd49f
50
cmd/khepri/cmd_key.go
Normal file
50
cmd/khepri/cmd_key.go
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"github.com/fd0/khepri"
|
||||||
|
"github.com/fd0/khepri/backend"
|
||||||
|
)
|
||||||
|
|
||||||
|
func list_keys(be backend.Server, key *khepri.Key) error {
|
||||||
|
tab := NewTable()
|
||||||
|
tab.Header = fmt.Sprintf("%-10s %-10s %-10s %s", "ID", "User", "Host", "Created")
|
||||||
|
tab.RowFormat = "%-10s %-10s %-10s %s"
|
||||||
|
|
||||||
|
plen, err := backend.PrefixLength(be, backend.Key)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
backend.Each(be, backend.Key, func(id backend.ID, data []byte, err error) {
|
||||||
|
k := khepri.Key{}
|
||||||
|
err = json.Unmarshal(data, &k)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
tab.Rows = append(tab.Rows, []interface{}{id[:plen],
|
||||||
|
k.Username, k.Hostname, k.Created.Format(TimeFormat)})
|
||||||
|
})
|
||||||
|
|
||||||
|
tab.Print(os.Stdout)
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func commandKey(be backend.Server, key *khepri.Key, args []string) error {
|
||||||
|
if len(args) < 1 {
|
||||||
|
return errors.New("usage: key [list]")
|
||||||
|
}
|
||||||
|
|
||||||
|
switch args[0] {
|
||||||
|
case "list":
|
||||||
|
return list_keys(be, key)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
@ -129,6 +129,7 @@ func init() {
|
|||||||
commands["snapshots"] = commandSnapshots
|
commands["snapshots"] = commandSnapshots
|
||||||
commands["cat"] = commandCat
|
commands["cat"] = commandCat
|
||||||
commands["ls"] = commandLs
|
commands["ls"] = commandLs
|
||||||
|
commands["key"] = commandKey
|
||||||
|
|
||||||
// set GOMAXPROCS to number of CPUs
|
// set GOMAXPROCS to number of CPUs
|
||||||
runtime.GOMAXPROCS(runtime.NumCPU())
|
runtime.GOMAXPROCS(runtime.NumCPU())
|
||||||
|
Loading…
Reference in New Issue
Block a user