feat: add import and export

This commit is contained in:
Adrien Waksberg 2019-10-20 20:10:09 +02:00
parent 9f0043786a
commit 4b775101c8

View file

@ -2,6 +2,8 @@ package gpm
import ( import (
"fmt" "fmt"
"flag"
"io/ioutil"
"os" "os"
"time" "time"
@ -9,6 +11,20 @@ import (
"github.com/gizak/termui/v3/widgets" "github.com/gizak/termui/v3/widgets"
) )
// Options
var (
LENGTH = flag.Int("length", 16, "specify the password length")
CONFIG = flag.String("config", "", "specify the config file")
WALLET = flag.String("wallet", "", "specify the wallet")
PASSWD = flag.Bool("password", false, "generate and print a random password")
DIGIT = flag.Bool("digit", false, "use digit to generate a random password")
LETTER = flag.Bool("letter", false, "use letter to generate a random password")
SPECIAL = flag.Bool("special", false, "use special chars to generate a random password")
EXPORT = flag.String("export", "", "json file path to export a wallet")
IMPORT = flag.String("import", "", "json file path to import entries")
HELP = flag.Bool("help", false, "print this help message")
)
type Cli struct { type Cli struct {
Config Config Config Config
Wallet Wallet Wallet Wallet
@ -321,9 +337,60 @@ func (c *Cli) ListEntries(ch chan<- bool) {
} }
} }
// Import entries from json file
func (c *Cli) ImportWallet() error {
_, err := os.Stat(*IMPORT)
if err != nil {
return err
}
data, err := ioutil.ReadFile(*IMPORT)
if err != nil {
return err
}
err = c.Wallet.Import(data)
if err != nil {
return err
}
err = c.Wallet.Save()
if err != nil {
return err
}
return nil
}
// Export a wallet in json format
func (c *Cli) ExportWallet() error {
data, err := c.Wallet.Export()
if err != nil {
return err
}
err = ioutil.WriteFile(*EXPORT, data, 0600)
if err != nil {
return err
}
return nil
}
// Run the cli interface
func Run() { func Run() {
var c Cli var c Cli
c.Config.Load("")
flag.Parse()
c.Config.Load(*CONFIG)
if *HELP {
flag.PrintDefaults()
os.Exit(1)
} else if *PASSWD {
fmt.Println(RandomString(*LENGTH, *LETTER, *DIGIT, *SPECIAL))
os.Exit(0)
}
if err := ui.Init(); err != nil { if err := ui.Init(); err != nil {
fmt.Printf("failed to initialize termui: %v\n", err) fmt.Printf("failed to initialize termui: %v\n", err)
@ -331,13 +398,28 @@ func Run() {
} }
defer ui.Close() defer ui.Close()
err := c.UnlockWallet("test") err := c.UnlockWallet(*WALLET)
if err != nil { if err != nil {
ui.Close() ui.Close()
fmt.Printf("failed to open the wallet: %v\n", err) fmt.Printf("failed to open the wallet: %v\n", err)
os.Exit(2) os.Exit(2)
} }
if *IMPORT != "" {
err := c.ImportWallet()
if err != nil {
ui.Close()
fmt.Printf("failed to import: %v\n", err)
os.Exit(2)
}
} else if *EXPORT != "" {
err := c.ExportWallet()
if err != nil {
ui.Close()
fmt.Printf("failed to export: %v\n", err)
os.Exit(2)
}
} else {
c1 := make(chan bool) c1 := make(chan bool)
go c.ListEntries(c1) go c.ListEntries(c1)
select { select {
@ -347,3 +429,4 @@ func Run() {
return return
} }
} }
}