mirror of
https://codeberg.org/shroff/phylum.git
synced 2026-01-26 22:19:32 -06:00
119 lines
3.1 KiB
Go
119 lines
3.1 KiB
Go
package user
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"os"
|
|
"strings"
|
|
"syscall"
|
|
|
|
"github.com/google/uuid"
|
|
"github.com/jackc/pgx/v5/pgtype"
|
|
"github.com/shroff/phylum/server/internal/command/common"
|
|
"github.com/shroff/phylum/server/internal/core/db"
|
|
"github.com/shroff/phylum/server/internal/core/fs"
|
|
"github.com/shroff/phylum/server/internal/core/user"
|
|
"github.com/spf13/cobra"
|
|
"golang.org/x/term"
|
|
)
|
|
|
|
func setupUserAddCommand() *cobra.Command {
|
|
cmd := &cobra.Command{
|
|
Use: "add email",
|
|
Short: "Add User",
|
|
Args: cobra.ExactArgs(1),
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
email := args[0]
|
|
|
|
displayName := email
|
|
if n, err := cmd.Flags().GetString("name"); err != nil {
|
|
fmt.Println("invalid value for flag 'name': " + err.Error())
|
|
os.Exit(1)
|
|
} else if n != "" {
|
|
displayName = email
|
|
}
|
|
|
|
password, err := cmd.Flags().GetString("password")
|
|
if err != nil {
|
|
fmt.Println("invalid password: " + err.Error())
|
|
os.Exit(1)
|
|
} else if password == "" {
|
|
os.Stdout.WriteString("Password: ")
|
|
bytes, err := term.ReadPassword(syscall.Stdin)
|
|
os.Stdout.WriteString("\n")
|
|
if err != nil {
|
|
fmt.Println("unable to read password: " + err.Error())
|
|
os.Exit(1)
|
|
}
|
|
password = string(bytes)
|
|
|
|
os.Stdout.WriteString("Confirm Password: ")
|
|
bytes, err = term.ReadPassword(syscall.Stdin)
|
|
os.Stdout.WriteString("\n")
|
|
if err != nil {
|
|
fmt.Println("unable to read password: " + err.Error())
|
|
os.Exit(1)
|
|
}
|
|
passwordConf := string(bytes)
|
|
|
|
if password != passwordConf {
|
|
fmt.Println("password does not match confirmation")
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
|
|
f := common.RootFileSystem()
|
|
noCreateHome, _ := cmd.Flags().GetBool("no-create-home")
|
|
homePath := ""
|
|
if !noCreateHome {
|
|
basePath, _ := cmd.Flags().GetString("base-dir")
|
|
homePath = strings.TrimRight(basePath, "/") + "/" + email
|
|
}
|
|
|
|
err = db.Get(context.Background()).RunInTx(func(db db.Handler) error {
|
|
userManager := user.ManagerFromDB(db)
|
|
var userID int32
|
|
var home fs.Resource
|
|
if homePath != "" {
|
|
f = f.WithDb(db)
|
|
var err error
|
|
home, err = f.CreateResourceByPath(homePath, uuid.Nil, true, true, fs.ResourceBindConflictResolutionEnsure)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
var homeID pgtype.UUID
|
|
if home.ID() != uuid.Nil {
|
|
homeID = pgtype.UUID{
|
|
Bytes: home.ID(),
|
|
Valid: true,
|
|
}
|
|
}
|
|
if user, err := userManager.CreateUser(email, displayName, password, homeID); err != nil {
|
|
return err
|
|
} else {
|
|
userID = user.ID
|
|
}
|
|
|
|
if homeID.Valid {
|
|
if _, err := home.UpdatePermissions(userID, fs.PermissionRead|fs.PermissionWrite|fs.PermissionShare); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
})
|
|
if err != nil {
|
|
fmt.Println("could not add user: " + err.Error())
|
|
os.Exit(3)
|
|
}
|
|
},
|
|
}
|
|
cmd.Flags().StringP("name", "n", "", "Full Name")
|
|
cmd.Flags().StringP("password", "p", "", "Password")
|
|
cmd.Flags().StringP("base-dir", "b", "/home", "Base directory for home")
|
|
cmd.Flags().BoolP("no-create-home", "M", false, "Do not make home directory")
|
|
return cmd
|
|
}
|