|
|
|
@ -1,6 +1,7 @@
|
|
|
|
|
package app
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"encoding/json"
|
|
|
|
|
"fmt"
|
|
|
|
|
"sort"
|
|
|
|
|
"strings"
|
|
|
|
@ -39,22 +40,22 @@ var listAppServerFlag = &cli.StringFlag{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type appStatus struct {
|
|
|
|
|
server string
|
|
|
|
|
recipe string
|
|
|
|
|
appName string
|
|
|
|
|
domain string
|
|
|
|
|
status string
|
|
|
|
|
version string
|
|
|
|
|
upgrade string
|
|
|
|
|
Server string `json:"server"`
|
|
|
|
|
Recipe string `json:"recipe"`
|
|
|
|
|
AppName string `json:"appName"`
|
|
|
|
|
Domain string `json:"domain"`
|
|
|
|
|
Status string `json:"status"`
|
|
|
|
|
Version string `json:"version"`
|
|
|
|
|
Upgrade string `json:"upgrade"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type serverStatus struct {
|
|
|
|
|
apps []appStatus
|
|
|
|
|
appCount int
|
|
|
|
|
versionCount int
|
|
|
|
|
unversionedCount int
|
|
|
|
|
latestCount int
|
|
|
|
|
upgradeCount int
|
|
|
|
|
Apps []appStatus `json:"apps"`
|
|
|
|
|
AppCount int `json:"appCount"`
|
|
|
|
|
VersionCount int `json:"versionCount"`
|
|
|
|
|
UnversionedCount int `json:"unversionedCount"`
|
|
|
|
|
LatestCount int `json:"latestCount"`
|
|
|
|
|
UpgradeCount int `json:"upgradeCount"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var appListCommand = cli.Command{
|
|
|
|
@ -71,6 +72,7 @@ can take some time.
|
|
|
|
|
`,
|
|
|
|
|
Flags: []cli.Flag{
|
|
|
|
|
internal.DebugFlag,
|
|
|
|
|
internal.MachineReadableFlag,
|
|
|
|
|
statusFlag,
|
|
|
|
|
listAppServerFlag,
|
|
|
|
|
recipeFlag,
|
|
|
|
@ -135,7 +137,7 @@ can take some time.
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
appStats := appStatus{}
|
|
|
|
|
stats.appCount++
|
|
|
|
|
stats.AppCount++
|
|
|
|
|
totalAppsCount++
|
|
|
|
|
|
|
|
|
|
if status {
|
|
|
|
@ -150,13 +152,13 @@ can take some time.
|
|
|
|
|
if statusMeta["status"] != "" {
|
|
|
|
|
status = statusMeta["status"]
|
|
|
|
|
}
|
|
|
|
|
stats.versionCount++
|
|
|
|
|
stats.VersionCount++
|
|
|
|
|
} else {
|
|
|
|
|
stats.unversionedCount++
|
|
|
|
|
stats.UnversionedCount++
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
appStats.status = status
|
|
|
|
|
appStats.version = version
|
|
|
|
|
appStats.Status = status
|
|
|
|
|
appStats.Version = version
|
|
|
|
|
|
|
|
|
|
var newUpdates []string
|
|
|
|
|
if version != "unknown" {
|
|
|
|
@ -184,29 +186,36 @@ can take some time.
|
|
|
|
|
|
|
|
|
|
if len(newUpdates) == 0 {
|
|
|
|
|
if version == "unknown" {
|
|
|
|
|
appStats.upgrade = "unknown"
|
|
|
|
|
appStats.Upgrade = "unknown"
|
|
|
|
|
} else {
|
|
|
|
|
appStats.upgrade = "latest"
|
|
|
|
|
stats.latestCount++
|
|
|
|
|
appStats.Upgrade = "latest"
|
|
|
|
|
stats.LatestCount++
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
newUpdates = internal.ReverseStringList(newUpdates)
|
|
|
|
|
appStats.upgrade = strings.Join(newUpdates, "\n")
|
|
|
|
|
stats.upgradeCount++
|
|
|
|
|
appStats.Upgrade = strings.Join(newUpdates, "\n")
|
|
|
|
|
stats.UpgradeCount++
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
appStats.server = app.Server
|
|
|
|
|
appStats.recipe = app.Recipe
|
|
|
|
|
appStats.appName = app.Name
|
|
|
|
|
appStats.domain = app.Domain
|
|
|
|
|
appStats.Server = app.Server
|
|
|
|
|
appStats.Recipe = app.Recipe
|
|
|
|
|
appStats.AppName = app.Name
|
|
|
|
|
appStats.Domain = app.Domain
|
|
|
|
|
|
|
|
|
|
stats.apps = append(stats.apps, appStats)
|
|
|
|
|
stats.Apps = append(stats.Apps, appStats)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
allStats[app.Server] = stats
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if internal.MachineReadable {
|
|
|
|
|
jsonstring, err := json.Marshal(allStats)
|
|
|
|
|
if err != nil {
|
|
|
|
|
logrus.Fatal(err)
|
|
|
|
|
} else {
|
|
|
|
|
fmt.Println(string(jsonstring))
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
alreadySeen := make(map[string]bool)
|
|
|
|
|
for _, app := range apps {
|
|
|
|
|
if _, ok := alreadySeen[app.Server]; ok {
|
|
|
|
@ -222,10 +231,10 @@ can take some time.
|
|
|
|
|
|
|
|
|
|
table := formatter.CreateTable(tableCol)
|
|
|
|
|
|
|
|
|
|
for _, appStat := range serverStat.apps {
|
|
|
|
|
tableRow := []string{appStat.recipe, appStat.domain}
|
|
|
|
|
for _, appStat := range serverStat.Apps {
|
|
|
|
|
tableRow := []string{appStat.Recipe, appStat.Domain}
|
|
|
|
|
if status {
|
|
|
|
|
tableRow = append(tableRow, []string{appStat.status, appStat.version, appStat.upgrade}...)
|
|
|
|
|
tableRow = append(tableRow, []string{appStat.Status, appStat.Version, appStat.Upgrade}...)
|
|
|
|
|
}
|
|
|
|
|
table.Append(tableRow)
|
|
|
|
|
}
|
|
|
|
@ -237,14 +246,14 @@ can take some time.
|
|
|
|
|
fmt.Println(fmt.Sprintf(
|
|
|
|
|
"server: %s | total apps: %v | versioned: %v | unversioned: %v | latest: %v | upgrade: %v",
|
|
|
|
|
app.Server,
|
|
|
|
|
serverStat.appCount,
|
|
|
|
|
serverStat.versionCount,
|
|
|
|
|
serverStat.unversionedCount,
|
|
|
|
|
serverStat.latestCount,
|
|
|
|
|
serverStat.upgradeCount,
|
|
|
|
|
serverStat.AppCount,
|
|
|
|
|
serverStat.VersionCount,
|
|
|
|
|
serverStat.UnversionedCount,
|
|
|
|
|
serverStat.LatestCount,
|
|
|
|
|
serverStat.UpgradeCount,
|
|
|
|
|
))
|
|
|
|
|
} else {
|
|
|
|
|
fmt.Println(fmt.Sprintf("server: %s | total apps: %v", app.Server, serverStat.appCount))
|
|
|
|
|
fmt.Println(fmt.Sprintf("server: %s | total apps: %v", app.Server, serverStat.AppCount))
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|