photoprism/internal/commands/clients_mod.go
Michael Mayer d0ad3c23fb OAuth2: Remove client soft delete and fix client add command #213 #3943
Signed-off-by: Michael Mayer <michael@photoprism.app>
2024-01-29 21:08:01 +01:00

96 lines
2.6 KiB
Go

package commands
import (
"fmt"
"github.com/urfave/cli"
"github.com/photoprism/photoprism/internal/config"
"github.com/photoprism/photoprism/internal/entity"
"github.com/photoprism/photoprism/internal/form"
"github.com/photoprism/photoprism/pkg/clean"
"github.com/photoprism/photoprism/pkg/report"
)
// ClientsModCommand configures the command name, flags, and action.
var ClientsModCommand = cli.Command{
Name: "mod",
Usage: "Updates client application settings",
ArgsUsage: "[client id]",
Flags: ClientModFlags,
Action: clientsModAction,
}
// clientsModAction updates client application settings.
func clientsModAction(ctx *cli.Context) error {
return CallWithDependencies(ctx, func(conf *config.Config) error {
conf.MigrateDb(false, nil)
frm := form.ModClientFromCli(ctx)
// Name or UID provided?
if frm.ID() == "" {
log.Infof("no valid client id specified")
return cli.ShowSubcommandHelp(ctx)
}
// Find client record.
var client *entity.Client
client = entity.FindClientByUID(frm.ID())
if client == nil {
return fmt.Errorf("client %s not found", clean.Log(frm.ID()))
}
// Update client from form values.
client.SetFormValues(frm)
if ctx.IsSet("enable") || ctx.IsSet("disable") {
client.AuthEnabled = frm.AuthEnabled
log.Infof("disabled client authentication")
}
if client.AuthEnabled {
log.Infof("client authentication is enabled")
} else {
log.Warnf("client authentication is disabled")
}
// Update client record if valid.
if err := client.Validate(); err != nil {
return fmt.Errorf("invalid values: %s", err)
} else if err = client.Save(); err != nil {
return err
} else {
log.Infof("client %s has been updated", clean.LogQuote(client.ClientName))
}
// Change client secret if requested.
var secret, message string
var err error
if ctx.IsSet("regenerate") && ctx.Bool("regenerate") {
if secret, err = client.NewSecret(); err != nil {
return fmt.Errorf("failed to regenerate client secret: %s", err)
}
message = fmt.Sprintf(ClientSecretInfo, "FOLLOWING RANDOMLY GENERATED")
} else if secret = frm.Secret(); secret == "" {
log.Debugf("client secret remains unchanged")
} else if err = client.SetSecret(secret); err != nil {
return fmt.Errorf("failed to set client secret: %s", err)
} else {
message = fmt.Sprintf(ClientSecretInfo, "NEW")
}
// Show new client secret.
if secret != "" && err == nil {
fmt.Printf(message)
result := report.Credentials("Client ID", client.ClientUID, "Client Secret", secret)
fmt.Printf("\n%s\n", result)
}
return nil
})
}