2022-04-22 17:38:40 +02:00
|
|
|
package commands
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
"github.com/urfave/cli"
|
|
|
|
|
|
|
|
"github.com/photoprism/photoprism/internal/config"
|
|
|
|
"github.com/photoprism/photoprism/pkg/report"
|
|
|
|
)
|
|
|
|
|
2023-01-25 11:41:39 +01:00
|
|
|
// ShowConfigYamlCommand configures the command name, flags, and action.
|
|
|
|
var ShowConfigYamlCommand = cli.Command{
|
|
|
|
Name: "config-yaml",
|
2023-01-15 15:36:20 +01:00
|
|
|
Usage: "Displays supported YAML config options and CLI flags",
|
|
|
|
Flags: report.CliFlags,
|
2023-01-25 11:41:39 +01:00
|
|
|
Action: showConfigYamlAction,
|
2022-04-22 17:38:40 +02:00
|
|
|
}
|
|
|
|
|
2023-01-25 11:41:39 +01:00
|
|
|
// showConfigYamlAction displays supported YAML config options and CLI flag.
|
|
|
|
func showConfigYamlAction(ctx *cli.Context) error {
|
2022-04-22 17:38:40 +02:00
|
|
|
conf := config.NewConfig(ctx)
|
2023-01-15 15:36:20 +01:00
|
|
|
conf.SetLogLevel(logrus.TraceLevel)
|
2022-04-22 17:38:40 +02:00
|
|
|
|
2023-01-15 15:36:20 +01:00
|
|
|
rows, cols := conf.Options().Report()
|
2022-04-22 17:38:40 +02:00
|
|
|
|
|
|
|
// CSV Export?
|
|
|
|
if ctx.Bool("csv") || ctx.Bool("tsv") {
|
2022-10-10 16:34:07 +02:00
|
|
|
result, err := report.RenderFormat(rows, cols, report.CliFormat(ctx))
|
2022-04-22 17:38:40 +02:00
|
|
|
|
|
|
|
fmt.Println(result)
|
|
|
|
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
type Section struct {
|
2022-10-12 14:57:33 +02:00
|
|
|
Start string
|
|
|
|
Title string
|
|
|
|
Info string
|
2022-04-22 17:38:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
s := []Section{
|
2023-01-15 15:36:20 +01:00
|
|
|
{Start: "AuthMode", Title: "Authentication"},
|
|
|
|
{Start: "LogLevel", Title: "Logging"},
|
|
|
|
{Start: "ConfigPath", Title: "Storage"},
|
|
|
|
{Start: "Workers", Title: "Index Workers"},
|
|
|
|
{Start: "ReadOnly", Title: "Feature Flags"},
|
|
|
|
{Start: "DefaultTheme", Title: "Customization"},
|
|
|
|
{Start: "CdnUrl", Title: "Site Information"},
|
2023-10-11 10:10:30 +02:00
|
|
|
{Start: "HttpsProxy", Title: "Web Server"},
|
2023-01-15 15:36:20 +01:00
|
|
|
{Start: "DatabaseDriver", Title: "Database Connection"},
|
2023-10-11 10:10:30 +02:00
|
|
|
{Start: "SipsBin", Title: "File Converters"},
|
2023-01-15 15:36:20 +01:00
|
|
|
{Start: "DownloadToken", Title: "Security Tokens"},
|
|
|
|
{Start: "ThumbColor", Title: "Image Quality"},
|
|
|
|
{Start: "PIDFilename", Title: "Daemon Mode",
|
2022-04-22 17:38:40 +02:00
|
|
|
Info: "If you start the server as a *daemon* in the background, you can additionally specify a filename for the log and the process ID:"},
|
|
|
|
}
|
|
|
|
|
|
|
|
j := 0
|
|
|
|
|
|
|
|
for i, sec := range s {
|
2022-10-12 14:57:33 +02:00
|
|
|
fmt.Printf("### %s ###\n\n", sec.Title)
|
2022-04-22 17:38:40 +02:00
|
|
|
if sec.Info != "" && ctx.Bool("md") {
|
|
|
|
fmt.Printf("%s\n\n", sec.Info)
|
|
|
|
}
|
|
|
|
|
|
|
|
secRows := make([][]string, 0, len(rows))
|
|
|
|
|
|
|
|
for {
|
|
|
|
row := rows[j]
|
|
|
|
|
|
|
|
if len(row) < 1 {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if i < len(s)-1 {
|
|
|
|
if s[i+1].Start == row[0] {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
secRows = append(secRows, row)
|
|
|
|
j++
|
|
|
|
|
|
|
|
if j >= len(rows) {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-10 16:34:07 +02:00
|
|
|
result, err := report.RenderFormat(secRows, cols, report.CliFormat(ctx))
|
2022-04-22 17:38:40 +02:00
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
fmt.Println(result)
|
|
|
|
|
|
|
|
if j >= len(rows) {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|