mirror of
https://github.com/photoprism/photoprism.git
synced 2025-12-12 00:34:13 +01:00
Security: Improve credential handling across the cluster tooling #98
Signed-off-by: Michael Mayer <michael@photoprism.app>
This commit is contained in:
57
internal/commands/cluster_join_token.go
Normal file
57
internal/commands/cluster_join_token.go
Normal file
@@ -0,0 +1,57 @@
|
||||
package commands
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
"github.com/manifoldco/promptui"
|
||||
"github.com/urfave/cli/v2"
|
||||
|
||||
"github.com/photoprism/photoprism/internal/config"
|
||||
"github.com/photoprism/photoprism/pkg/clean"
|
||||
"github.com/photoprism/photoprism/pkg/fs"
|
||||
"github.com/photoprism/photoprism/pkg/rnd"
|
||||
)
|
||||
|
||||
var joinTokenSaveFlag = SaveFlag("write the generated join token to config/portal/secrets/join_token")
|
||||
|
||||
// ClusterJoinTokenCommand generates cluster join tokens for nodes.
|
||||
var ClusterJoinTokenCommand = &cli.Command{
|
||||
Name: "join-token",
|
||||
Usage: "Generates a portal join token for registering nodes",
|
||||
Flags: []cli.Flag{
|
||||
joinTokenSaveFlag,
|
||||
YesFlag(),
|
||||
},
|
||||
Action: clusterJoinTokenAction,
|
||||
}
|
||||
|
||||
// clusterJoinTokenAction generates a portal join token for registering nodes.
|
||||
func clusterJoinTokenAction(ctx *cli.Context) error {
|
||||
// Always print a freshly generated token; saving it is optional.
|
||||
token := rnd.JoinToken()
|
||||
fmt.Println(token)
|
||||
|
||||
if !ctx.Bool("save") {
|
||||
return nil
|
||||
}
|
||||
|
||||
return CallWithDependencies(ctx, func(conf *config.Config) error {
|
||||
tokenFile := conf.PortalJoinTokenFile()
|
||||
|
||||
if fs.FileExistsNotEmpty(tokenFile) && !RunNonInteractively(ctx.Bool("yes")) {
|
||||
prompt := promptui.Prompt{Label: fmt.Sprintf("Replace existing join token in %s?", clean.Log(tokenFile)), IsConfirm: true}
|
||||
if _, err := prompt.Run(); err != nil {
|
||||
log.Infof("cluster: join token was not updated")
|
||||
return nil
|
||||
}
|
||||
}
|
||||
|
||||
_, savedFile, err := conf.SaveJoinToken(token)
|
||||
if err != nil {
|
||||
return cli.Exit(fmt.Errorf("failed to write join token: %w", err), 1)
|
||||
}
|
||||
|
||||
log.Infof("cluster: new join token saved to %s", clean.Log(savedFile))
|
||||
return nil
|
||||
})
|
||||
}
|
||||
Reference in New Issue
Block a user