2018-10-23 11:05:44 -04:00
|
|
|
package registry
|
2017-08-15 06:58:49 -04:00
|
|
|
|
|
|
|
import (
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
|
2018-10-23 11:05:44 -04:00
|
|
|
"github.com/docker/cli/cli/command/formatter"
|
2022-03-04 08:38:45 -05:00
|
|
|
registrytypes "github.com/docker/docker/api/types/registry"
|
2017-08-15 06:58:49 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
2023-07-10 14:18:28 -04:00
|
|
|
defaultSearchTableFormat = "table {{.Name}}\t{{.Description}}\t{{.StarCount}}\t{{.IsOfficial}}"
|
2017-08-15 06:58:49 -04:00
|
|
|
|
|
|
|
starsHeader = "STARS"
|
|
|
|
officialHeader = "OFFICIAL"
|
|
|
|
automatedHeader = "AUTOMATED"
|
|
|
|
)
|
|
|
|
|
|
|
|
// NewSearchFormat returns a Format for rendering using a network Context
|
2018-10-23 11:05:44 -04:00
|
|
|
func NewSearchFormat(source string) formatter.Format {
|
2017-08-15 06:58:49 -04:00
|
|
|
switch source {
|
2023-07-10 14:18:28 -04:00
|
|
|
case "", formatter.TableFormatKey:
|
2017-08-15 06:58:49 -04:00
|
|
|
return defaultSearchTableFormat
|
|
|
|
}
|
2018-10-23 11:05:44 -04:00
|
|
|
return formatter.Format(source)
|
2017-08-15 06:58:49 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// SearchWrite writes the context
|
2022-03-04 08:38:45 -05:00
|
|
|
func SearchWrite(ctx formatter.Context, results []registrytypes.SearchResult) error {
|
2018-10-23 11:05:44 -04:00
|
|
|
render := func(format func(subContext formatter.SubContext) error) error {
|
2017-08-15 06:58:49 -04:00
|
|
|
for _, result := range results {
|
|
|
|
searchCtx := &searchContext{trunc: ctx.Trunc, s: result}
|
|
|
|
if err := format(searchCtx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
searchCtx := searchContext{}
|
2018-10-23 11:05:44 -04:00
|
|
|
searchCtx.Header = formatter.SubHeaderContext{
|
|
|
|
"Name": formatter.NameHeader,
|
|
|
|
"Description": formatter.DescriptionHeader,
|
2017-08-15 06:58:49 -04:00
|
|
|
"StarCount": starsHeader,
|
|
|
|
"IsOfficial": officialHeader,
|
|
|
|
"IsAutomated": automatedHeader,
|
|
|
|
}
|
|
|
|
return ctx.Write(&searchCtx, render)
|
|
|
|
}
|
|
|
|
|
|
|
|
type searchContext struct {
|
2018-10-23 11:05:44 -04:00
|
|
|
formatter.HeaderContext
|
2017-08-15 06:58:49 -04:00
|
|
|
trunc bool
|
|
|
|
json bool
|
2022-03-04 08:38:45 -05:00
|
|
|
s registrytypes.SearchResult
|
2017-08-15 06:58:49 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *searchContext) MarshalJSON() ([]byte, error) {
|
|
|
|
c.json = true
|
2018-10-23 11:05:44 -04:00
|
|
|
return formatter.MarshalJSON(c)
|
2017-08-15 06:58:49 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *searchContext) Name() string {
|
|
|
|
return c.s.Name
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *searchContext) Description() string {
|
linting: address assorted issues found by gocritic
internal/test/builders/config.go:36:15: captLocal: `ID' should not be capitalized (gocritic)
func ConfigID(ID string) func(config *swarm.Config) {
^
internal/test/builders/secret.go:45:15: captLocal: `ID' should not be capitalized (gocritic)
func SecretID(ID string) func(secret *swarm.Secret) {
^
internal/test/builders/service.go:21:16: captLocal: `ID' should not be capitalized (gocritic)
func ServiceID(ID string) func(*swarm.Service) {
^
cli/command/image/formatter_history.go:100:15: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(c.h.CreatedBy, "\t", " ", -1)` (gocritic)
createdBy := strings.Replace(c.h.CreatedBy, "\t", " ", -1)
^
e2e/image/push_test.go:246:34: badCall: suspicious Join on 1 argument (gocritic)
assert.NilError(t, os.RemoveAll(filepath.Join(dir.Join("trust"))))
^
e2e/image/push_test.go:313:34: badCall: suspicious Join on 1 argument (gocritic)
assert.NilError(t, os.RemoveAll(filepath.Join(dir.Join("trust"))))
^
cli/config/configfile/file_test.go:185:2: assignOp: replace `c.GetAllCallCount = c.GetAllCallCount + 1` with `c.GetAllCallCount++` (gocritic)
c.GetAllCallCount = c.GetAllCallCount + 1
^
cli/command/context/inspect_test.go:20:58: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(si.MetadataPath, `\`, `\\`, -1)` (gocritic)
expected = strings.Replace(expected, "<METADATA_PATH>", strings.Replace(si.MetadataPath, `\`, `\\`, -1), 1)
^
cli/command/context/inspect_test.go:21:53: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(si.TLSPath, `\`, `\\`, -1)` (gocritic)
expected = strings.Replace(expected, "<TLS_PATH>", strings.Replace(si.TLSPath, `\`, `\\`, -1), 1)
^
cli/command/container/formatter_stats.go:119:46: captLocal: `Stats' should not be capitalized (gocritic)
func statsFormatWrite(ctx formatter.Context, Stats []StatsEntry, osType string, trunc bool) error {
^
cli/command/container/stats_helpers.go:209:4: assignOp: replace `blkRead = blkRead + bioEntry.Value` with `blkRead += bioEntry.Value` (gocritic)
blkRead = blkRead + bioEntry.Value
^
cli/command/container/stats_helpers.go:211:4: assignOp: replace `blkWrite = blkWrite + bioEntry.Value` with `blkWrite += bioEntry.Value` (gocritic)
blkWrite = blkWrite + bioEntry.Value
^
cli/command/registry/formatter_search.go:67:10: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(c.s.Description, "\n", " ", -1)` (gocritic)
desc := strings.Replace(c.s.Description, "\n", " ", -1)
^
cli/command/registry/formatter_search.go:68:9: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(desc, "\r", " ", -1)` (gocritic)
desc = strings.Replace(desc, "\r", " ", -1)
^
cli/command/service/list_test.go:164:5: assignOp: replace `tc.doc = tc.doc + " with quiet"` with `tc.doc += " with quiet"` (gocritic)
tc.doc = tc.doc + " with quiet"
^
cli/command/service/progress/progress.go:274:11: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(errMsg, "\n", " ", -1)` (gocritic)
errMsg = strings.Replace(errMsg, "\n", " ", -1)
^
cli/manifest/store/store.go:153:9: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(fileName, "/", "_", -1)` (gocritic)
return strings.Replace(fileName, "/", "_", -1)
^
cli/manifest/store/store.go:152:14: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(ref, ":", "-", -1)` (gocritic)
fileName := strings.Replace(ref, ":", "-", -1)
^
cli/command/plugin/formatter.go:79:10: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(c.p.Config.Description, "\n", "", -1)` (gocritic)
desc := strings.Replace(c.p.Config.Description, "\n", "", -1)
^
cli/command/plugin/formatter.go:80:9: wrapperFunc: use strings.ReplaceAll method in `strings.Replace(desc, "\r", "", -1)` (gocritic)
desc = strings.Replace(desc, "\r", "", -1)
^
cli/compose/convert/service.go:642:23: captLocal: `DNS' should not be capitalized (gocritic)
func convertDNSConfig(DNS []string, DNSSearch []string) *swarm.DNSConfig {
^
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
2023-11-20 07:30:05 -05:00
|
|
|
desc := strings.ReplaceAll(c.s.Description, "\n", " ")
|
|
|
|
desc = strings.ReplaceAll(desc, "\r", " ")
|
2017-08-15 06:58:49 -04:00
|
|
|
if c.trunc {
|
2018-10-23 11:05:44 -04:00
|
|
|
desc = formatter.Ellipsis(desc, 45)
|
2017-08-15 06:58:49 -04:00
|
|
|
}
|
|
|
|
return desc
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *searchContext) StarCount() string {
|
|
|
|
return strconv.Itoa(c.s.StarCount)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *searchContext) formatBool(value bool) string {
|
|
|
|
switch {
|
|
|
|
case value && c.json:
|
|
|
|
return "true"
|
|
|
|
case value:
|
|
|
|
return "[OK]"
|
|
|
|
case c.json:
|
|
|
|
return "false"
|
|
|
|
default:
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *searchContext) IsOfficial() string {
|
|
|
|
return c.formatBool(c.s.IsOfficial)
|
|
|
|
}
|
|
|
|
|
2023-07-10 14:18:28 -04:00
|
|
|
// IsAutomated formats the IsAutomated field for printing.
|
|
|
|
//
|
|
|
|
// Deprecated: the "is_automated" field is deprecated and will always be "false" in the future.
|
2017-08-15 06:58:49 -04:00
|
|
|
func (c *searchContext) IsAutomated() string {
|
2023-08-07 14:21:39 -04:00
|
|
|
return c.formatBool(c.s.IsAutomated) //nolint:staticcheck // ignore SA1019 (IsAutomated is deprecated).
|
2017-08-15 06:58:49 -04:00
|
|
|
}
|