photoprism/internal/commands/clients_remove.go
Michael Mayer 467f7b1585 OAuth2: Add Client Credentials Authentication #213 #782 #808 #3730 #3943
This adds standard OAuth2 client credentials and bearer token support as
well as scope-based authorization checks for REST API clients. Note that
this initial implementation should not be used in production and that
the access token limit has not been implemented yet.

Signed-off-by: Michael Mayer <michael@photoprism.app>
2023-12-12 18:42:50 +01:00

72 lines
1.6 KiB
Go

package commands
import (
"fmt"
"github.com/manifoldco/promptui"
"github.com/urfave/cli"
"github.com/photoprism/photoprism/internal/config"
"github.com/photoprism/photoprism/internal/entity"
"github.com/photoprism/photoprism/pkg/clean"
)
// ClientsRemoveCommand configures the command name, flags, and action.
var ClientsRemoveCommand = cli.Command{
Name: "rm",
Usage: "Deletes a registered client application",
ArgsUsage: "[id]",
Flags: []cli.Flag{
cli.BoolFlag{
Name: "force, f",
Usage: "don't ask for confirmation",
},
},
Action: clientsRemoveAction,
}
// clientsRemoveAction deletes a registered client application
func clientsRemoveAction(ctx *cli.Context) error {
return CallWithDependencies(ctx, func(conf *config.Config) error {
conf.MigrateDb(false, nil)
id := clean.UID(ctx.Args().First())
// Name or UID provided?
if id == "" {
log.Infof("no valid client id specified")
return cli.ShowSubcommandHelp(ctx)
}
// Find client record.
var m *entity.Client
m = entity.FindClient(id)
if m == nil {
return fmt.Errorf("client %s not found", clean.LogQuote(id))
} else if m.Deleted() {
return fmt.Errorf("client %s has already been deleted", clean.LogQuote(id))
}
if !ctx.Bool("force") {
actionPrompt := promptui.Prompt{
Label: fmt.Sprintf("Delete client %s?", m.UID()),
IsConfirm: true,
}
if _, err := actionPrompt.Run(); err != nil {
log.Infof("client %s was not deleted", m.UID())
return nil
}
}
if err := m.Delete(); err != nil {
return err
}
log.Infof("client %s has been deleted", m.UID())
return nil
})
}