feat: add import and export
This commit is contained in:
parent
9f0043786a
commit
4b775101c8
1 changed files with 92 additions and 9 deletions
87
gpm/cli.go
87
gpm/cli.go
|
@ -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
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue