713593da4e
You can now run "photoprism auth add" to create new client access tokens that allow external applications to use the built-in REST API. Signed-off-by: Michael Mayer <michael@photoprism.app>
52 lines
1.3 KiB
Go
52 lines
1.3 KiB
Go
package commands
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
|
|
"github.com/manifoldco/promptui"
|
|
"github.com/urfave/cli"
|
|
|
|
"github.com/photoprism/photoprism/internal/config"
|
|
"github.com/photoprism/photoprism/internal/query"
|
|
"github.com/photoprism/photoprism/pkg/clean"
|
|
)
|
|
|
|
// AuthRemoveCommand configures the command name, flags, and action.
|
|
var AuthRemoveCommand = cli.Command{
|
|
Name: "rm",
|
|
Usage: "Deletes the specified session or access token",
|
|
ArgsUsage: "[id]",
|
|
Action: authRemoveAction,
|
|
}
|
|
|
|
// authRemoveAction deletes the specified session.
|
|
func authRemoveAction(ctx *cli.Context) error {
|
|
return CallWithDependencies(ctx, func(conf *config.Config) error {
|
|
id := clean.ID(ctx.Args().First())
|
|
|
|
// ID provided?
|
|
if id == "" {
|
|
return cli.ShowSubcommandHelp(ctx)
|
|
}
|
|
|
|
actionPrompt := promptui.Prompt{
|
|
Label: fmt.Sprintf("Remove session %s?", clean.LogQuote(id)),
|
|
IsConfirm: true,
|
|
}
|
|
|
|
if _, err := actionPrompt.Run(); err == nil {
|
|
if m, err := query.Session(id); err != nil {
|
|
return errors.New("session not found")
|
|
} else if err := m.Delete(); err != nil {
|
|
return err
|
|
} else {
|
|
log.Infof("session %s has been removed", clean.LogQuote(id))
|
|
}
|
|
} else {
|
|
log.Infof("session %s was not removed", clean.LogQuote(id))
|
|
}
|
|
|
|
return nil
|
|
})
|
|
}
|