mirror of
https://github.com/celogeek/piwigo-cli.git
synced 2025-05-25 18:22:37 +02:00
add general info
This commit is contained in:
parent
931bd470a5
commit
29880be5b6
52
internal/piwigocli/general.go
Normal file
52
internal/piwigocli/general.go
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
package piwigocli
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"github.com/celogeek/piwigo-cli/internal/piwigo"
|
||||||
|
"github.com/jedib0t/go-pretty/v6/table"
|
||||||
|
)
|
||||||
|
|
||||||
|
type GetInfosCommand struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
type Info struct {
|
||||||
|
Name string `json:"name"`
|
||||||
|
Value interface{} `json:"value"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type GetInfosResponse struct {
|
||||||
|
Infos []Info `json:"infos"`
|
||||||
|
}
|
||||||
|
|
||||||
|
var getInfosCommand GetInfosCommand
|
||||||
|
|
||||||
|
func (c *GetInfosCommand) Execute(args []string) error {
|
||||||
|
p := piwigo.Piwigo{}
|
||||||
|
if err := p.LoadConfig(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
var resp GetInfosResponse
|
||||||
|
|
||||||
|
if err := p.Post("pwg.getInfos", nil, &resp); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
t := table.NewWriter()
|
||||||
|
t.AppendHeader(table.Row{"", "Value"})
|
||||||
|
for _, info := range resp.Infos {
|
||||||
|
t.AppendRow(table.Row{info.Name, info.Value})
|
||||||
|
}
|
||||||
|
|
||||||
|
t.SetOutputMirror(os.Stdout)
|
||||||
|
t.SetStyle(table.StyleLight)
|
||||||
|
t.Render()
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
parser.AddCommand("getinfos", "Get general information", "", &getInfosCommand)
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user