mirror of
https://github.com/thomiceli/opengist.git
synced 2025-07-09 17:38:04 +02:00
Add/Remove admins (#337)
This commit is contained in:
@ -12,6 +12,7 @@ var CmdAdmin = cli.Command{
|
||||
Usage: "Admin commands",
|
||||
Subcommands: []*cli.Command{
|
||||
&CmdAdminResetPassword,
|
||||
&CmdAdminToggleAdmin,
|
||||
},
|
||||
}
|
||||
|
||||
@ -48,3 +49,30 @@ var CmdAdminResetPassword = cli.Command{
|
||||
return nil
|
||||
},
|
||||
}
|
||||
|
||||
var CmdAdminToggleAdmin = cli.Command{
|
||||
Name: "toggle-admin",
|
||||
Usage: "Toggle the admin status for a given user",
|
||||
ArgsUsage: "[username]",
|
||||
Action: func(ctx *cli.Context) error {
|
||||
initialize(ctx)
|
||||
if ctx.NArg() < 1 {
|
||||
return fmt.Errorf("username is required")
|
||||
}
|
||||
username := ctx.Args().Get(0)
|
||||
|
||||
user, err := db.GetUserByUsername(username)
|
||||
if err != nil {
|
||||
fmt.Printf("Cannot get user %s: %s\n", username, err)
|
||||
return err
|
||||
}
|
||||
|
||||
user.IsAdmin = !user.IsAdmin
|
||||
if err = user.Update(); err != nil {
|
||||
fmt.Printf("Cannot update user %s: %s\n", username, err)
|
||||
}
|
||||
|
||||
fmt.Printf("User %s admin set to %t\n", username, user.IsAdmin)
|
||||
return nil
|
||||
},
|
||||
}
|
||||
|
Reference in New Issue
Block a user