feat: finish users import and improve error printing

License: MIT
Signed-off-by: Henrique Dias <hacdias@gmail.com>
This commit is contained in:
Henrique Dias 2019-01-07 23:04:56 +00:00
parent ac12619d20
commit f9b18d88d7
2 changed files with 32 additions and 8 deletions

View File

@ -12,7 +12,7 @@ import (
func init() { func init() {
usersCmd.AddCommand(usersImportCmd) usersCmd.AddCommand(usersImportCmd)
usersImportCmd.Flags().Bool("overwrite", false, "overwrite existing users,") usersImportCmd.Flags().Bool("overwrite", false, "overwrite users with the same id/username combo")
} }
var usersImportCmd = &cobra.Command{ var usersImportCmd = &cobra.Command{
@ -24,22 +24,44 @@ var usersImportCmd = &cobra.Command{
checkErr(err) checkErr(err)
defer fd.Close() defer fd.Close()
list := []users.User{} list := []*users.User{}
err = json.NewDecoder(fd).Decode(&list) err = json.NewDecoder(fd).Decode(&list)
checkErr(err) checkErr(err)
for _, user := range list {
err = user.Clean("")
checkErr(err)
}
overwrite := mustGetBool(cmd, "overwrite") overwrite := mustGetBool(cmd, "overwrite")
for _, user := range list { for _, user := range list {
// TODO: check for ID/Username conflicts too. old, err := d.store.Users.Get("", user.ID)
_, err := d.store.Users.Get("", user.ID)
if err == nil && !overwrite { // User exists in DB.
checkErr(errors.New("user " + strconv.Itoa(int(user.ID)) + " is already registred")) if err == nil {
if !overwrite {
checkErr(errors.New("user " + strconv.Itoa(int(user.ID)) + " is already registred"))
}
// If the usernames mismatch, check if there is another one in the DB
// with the new username. If there is, print an error and cancel the
// operation
if user.Username != old.Username {
conflictuous, err := d.store.Users.Get("", user.Username)
if err == nil {
checkErr(usernameConflictError(user.Username, conflictuous.ID, user.ID))
}
}
} }
err = d.store.Users.Save(&user) err = d.store.Users.Save(user)
checkErr(err) checkErr(err)
} }
}, pythonConfig{}), }, pythonConfig{}),
} }
func usernameConflictError(username string, original, new uint) error {
return errors.New("can't import user with ID " + strconv.Itoa(int(new)) + " and username \"" + username + "\" because the username is already registred with the user " + strconv.Itoa(int(original)))
}

View File

@ -2,6 +2,7 @@ package cmd
import ( import (
"crypto/rand" "crypto/rand"
"fmt"
"log" "log"
"os" "os"
@ -39,7 +40,8 @@ func vadd(f *pflag.FlagSet, k string, i interface{}, u string) {
func checkErr(err error) { func checkErr(err error) {
if err != nil { if err != nil {
panic(err) fmt.Println(err)
os.Exit(1)
} }
} }