180 lines
3.9 KiB
Go
180 lines
3.9 KiB
Go
package commands
|
|
|
|
import (
|
|
"fmt"
|
|
"strconv"
|
|
"syscall"
|
|
|
|
"github.com/cortezaproject/corteza-server/pkg/auth"
|
|
"github.com/cortezaproject/corteza-server/pkg/cli"
|
|
"github.com/cortezaproject/corteza-server/pkg/filter"
|
|
"github.com/cortezaproject/corteza-server/system/service"
|
|
"github.com/cortezaproject/corteza-server/system/types"
|
|
"github.com/spf13/cobra"
|
|
"golang.org/x/crypto/ssh/terminal"
|
|
)
|
|
|
|
func Users(app serviceInitializer) *cobra.Command {
|
|
var (
|
|
flagNoPassword bool
|
|
)
|
|
|
|
// User management commands.
|
|
cmd := &cobra.Command{
|
|
Use: "users",
|
|
Short: "User management",
|
|
}
|
|
|
|
// List users.
|
|
listCmd := &cobra.Command{
|
|
Use: "list",
|
|
Short: "List users",
|
|
|
|
PreRunE: commandPreRunInitService(app),
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
var (
|
|
ctx = auth.SetSuperUserContext(cli.Context())
|
|
|
|
queryFlag = cmd.Flags().Lookup("query").Value.String()
|
|
limitFlag = cmd.Flags().Lookup("limit").Value.String()
|
|
|
|
limit int
|
|
err error
|
|
)
|
|
|
|
limit, err = strconv.Atoi(limitFlag)
|
|
cli.HandleError(err)
|
|
|
|
uf := types.UserFilter{Query: queryFlag}
|
|
uf.Sort = filter.SortExprSet{&filter.SortExpr{Column: "updated_at"}}
|
|
uf.Limit = uint(limit)
|
|
|
|
users, _, err := service.DefaultStore.SearchUsers(ctx, uf)
|
|
cli.HandleError(err)
|
|
|
|
fmt.Fprintf(
|
|
cmd.OutOrStdout(),
|
|
" Created Updated EmailAddress\n",
|
|
)
|
|
|
|
for _, u := range users {
|
|
upd := "---- -- --"
|
|
|
|
if u.UpdatedAt != nil {
|
|
upd = u.UpdatedAt.Format("2006-01-02")
|
|
}
|
|
|
|
fmt.Fprintf(
|
|
cmd.OutOrStdout(),
|
|
"%20d %s %s %-100s %s\n",
|
|
u.ID,
|
|
u.CreatedAt.Format("2006-01-02"),
|
|
upd,
|
|
u.Email,
|
|
u.Name,
|
|
)
|
|
}
|
|
},
|
|
}
|
|
|
|
listCmd.Flags().IntP("limit", "l", 20, "How many entry to display")
|
|
listCmd.Flags().StringP("query", "q", "", "Query and filter by handle, email, name")
|
|
|
|
addCmd := &cobra.Command{
|
|
Use: "add [email]",
|
|
Short: "Add new user",
|
|
Args: cobra.MinimumNArgs(1),
|
|
|
|
PreRunE: commandPreRunInitService(app),
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
var (
|
|
ctx = auth.SetSuperUserContext(cli.Context())
|
|
|
|
authSvc = service.Auth()
|
|
|
|
// @todo email validation
|
|
user = &types.User{Email: args[0]}
|
|
|
|
err error
|
|
password []byte
|
|
)
|
|
|
|
// Update current settings to be sure that we do not have outdated values
|
|
cli.HandleError(service.DefaultSettings.UpdateCurrent(ctx))
|
|
|
|
if user, err = service.DefaultUser.Create(ctx, user); err != nil {
|
|
cli.HandleError(err)
|
|
}
|
|
|
|
cmd.Printf("User created [%d].\n", user.ID)
|
|
|
|
if !flagNoPassword {
|
|
cmd.Print("Set password: ")
|
|
if password, err = terminal.ReadPassword(syscall.Stdin); err != nil {
|
|
cli.HandleError(err)
|
|
}
|
|
|
|
if len(password) == 0 {
|
|
// Password not set, that's ok too.
|
|
return
|
|
}
|
|
|
|
if err = authSvc.SetPassword(ctx, user.ID, string(password)); err != nil {
|
|
cli.HandleError(err)
|
|
}
|
|
}
|
|
},
|
|
}
|
|
|
|
addCmd.Flags().BoolVar(
|
|
&flagNoPassword,
|
|
"no-password",
|
|
false,
|
|
"Create user without password")
|
|
|
|
pwdCmd := &cobra.Command{
|
|
Use: "password [email]",
|
|
Short: "Change password for user",
|
|
Args: cobra.MinimumNArgs(1),
|
|
PreRunE: commandPreRunInitService(app),
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
var (
|
|
ctx = auth.SetSuperUserContext(cli.Context())
|
|
|
|
user *types.User
|
|
err error
|
|
password []byte
|
|
)
|
|
|
|
// Update current settings to be sure that we do not have outdated values
|
|
cli.HandleError(service.DefaultSettings.UpdateCurrent(ctx))
|
|
|
|
if user, err = service.DefaultUser.FindByEmail(ctx, args[0]); err != nil {
|
|
cli.HandleError(err)
|
|
}
|
|
|
|
cmd.Print("Set password: ")
|
|
if password, err = terminal.ReadPassword(syscall.Stdin); err != nil {
|
|
cli.HandleError(err)
|
|
}
|
|
|
|
if len(password) == 0 {
|
|
// Password not set, that's ok too.
|
|
return
|
|
}
|
|
|
|
if err = service.DefaultAuth.SetPassword(ctx, user.ID, string(password)); err != nil {
|
|
cli.HandleError(err)
|
|
}
|
|
},
|
|
}
|
|
|
|
cmd.AddCommand(
|
|
listCmd,
|
|
addCmd,
|
|
pwdCmd,
|
|
)
|
|
|
|
return cmd
|
|
}
|