add init command

pull/46/head
Yasuhiro Matsumoto 2017-04-27 00:56:13 +09:00
parent add25dd05b
commit 3fb35ec728
1 changed files with 23 additions and 2 deletions

View File

@ -94,7 +94,7 @@ func prompt() (string, string, error) {
return email, password, nil return email, password, nil
} }
func getConfig(c *cli.Context) (string, *mastodon.Config, error) { func configFile(c *cli.Context) (string, error) {
dir := os.Getenv("HOME") dir := os.Getenv("HOME")
if runtime.GOOS == "windows" { if runtime.GOOS == "windows" {
dir = os.Getenv("APPDATA") dir = os.Getenv("APPDATA")
@ -106,7 +106,7 @@ func getConfig(c *cli.Context) (string, *mastodon.Config, error) {
dir = filepath.Join(dir, ".config", "mstdn") dir = filepath.Join(dir, ".config", "mstdn")
} }
if err := os.MkdirAll(dir, 0700); err != nil { if err := os.MkdirAll(dir, 0700); err != nil {
return "", nil, err return "", err
} }
var file string var file string
profile := c.String("profile") profile := c.String("profile")
@ -115,6 +115,14 @@ func getConfig(c *cli.Context) (string, *mastodon.Config, error) {
} else { } else {
file = filepath.Join(dir, "settings.json") file = filepath.Join(dir, "settings.json")
} }
return file, nil
}
func getConfig(c *cli.Context) (string, *mastodon.Config, error) {
file, err := configFile(c)
if err != nil {
return "", nil, err
}
b, err := ioutil.ReadFile(file) b, err := ioutil.ReadFile(file)
if err != nil && !os.IsNotExist(err) { if err != nil && !os.IsNotExist(err) {
return "", nil, err return "", nil, err
@ -267,6 +275,11 @@ func makeApp() *cli.App {
Usage: "delete status", Usage: "delete status",
Action: cmdDelete, Action: cmdDelete,
}, },
{
Name: "init",
Usage: "initialize profile",
Action: func(c *cli.Context) error { return nil },
},
} }
app.Setup() app.Setup()
return app return app
@ -323,6 +336,14 @@ func run() int {
app := makeApp() app := makeApp()
app.Before = func(c *cli.Context) error { app.Before = func(c *cli.Context) error {
if c.Args().Get(0) == "init" {
file, err := configFile(c)
if err != nil {
return err
}
os.Remove(file)
}
file, config, err := getConfig(c) file, config, err := getConfig(c)
if err != nil { if err != nil {
return err return err