While updating, also addressed some redundant fmt.Sprintf()
opts/throttledevice.go:86:2: Consider pre-allocating `out` (prealloc)
var out []string
^
opts/ulimit.go:37:2: Consider pre-allocating `out` (prealloc)
var out []string
^
opts/ulimit.go:47:2: Consider pre-allocating `ulimits` (prealloc)
var ulimits []*units.Ulimit
^
opts/weightdevice.go:68:2: Consider pre-allocating `out` (prealloc)
var out []string
^
cli/context/store/metadatastore.go:96:2: Consider pre-allocating `res` (prealloc)
var res []Metadata
^
cli/context/store/store.go:127:2: Consider pre-allocating `names` (prealloc)
var names []string
^
cli/compose/loader/loader.go:223:2: Consider pre-allocating `keys` (prealloc)
var keys []string
^
cli/compose/loader/loader.go:397:2: Consider pre-allocating `services` (prealloc)
var services []types.ServiceConfig
^
cli/command/stack/loader/loader.go:63:2: Consider pre-allocating `msgs` (prealloc)
var msgs []string
^
cli/command/stack/loader/loader.go:118:2: Consider pre-allocating `configFiles` (prealloc)
var configFiles []composetypes.ConfigFile
^
cli/command/formatter/container.go:245:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli/command/formatter/container.go:265:2: Consider pre-allocating `mounts` (prealloc)
var mounts []string
^
cli/command/formatter/container.go:316:2: Consider pre-allocating `result` (prealloc)
var result []string
^
cli/command/formatter/displayutils.go:43:2: Consider pre-allocating `display` (prealloc)
var (
^
cli/command/formatter/volume.go:103:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli-plugins/manager/manager_test.go:49:2: Consider pre-allocating `dirs` (prealloc)
var dirs []string
^
cli/command/swarm/init.go:69:2: Consider pre-allocating `defaultAddrPool` (prealloc)
var defaultAddrPool []string
^
cli/command/manifest/push.go:195:2: Consider pre-allocating `blobReqs` (prealloc)
var blobReqs []manifestBlob
^
cli/command/secret/formatter.go:111:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli/command/network/formatter.go:104:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli/command/context/list.go:52:2: Consider pre-allocating `contexts` (prealloc)
var contexts []*formatter.ClientContext
^
cli/command/config/formatter.go:104:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli/command/trust/common_test.go:23:2: Consider pre-allocating `targetNames` (prealloc)
var targetNames []string
^
cli/command/service/generic_resource_opts.go:55:2: Consider pre-allocating `generic` (prealloc)
var generic []swarm.GenericResource
^
cli/command/service/generic_resource_opts.go:98:2: Consider pre-allocating `l` (prealloc)
var l []swarm.GenericResource
^
cli/command/service/opts.go:378:2: Consider pre-allocating `netAttach` (prealloc)
var netAttach []swarm.NetworkAttachmentConfig
^
cli/command/service/update.go:731:2: Consider pre-allocating `limits` (prealloc)
var limits []*units.Ulimit
^
cli/command/service/update.go:1315:2: Consider pre-allocating `newNetworks` (prealloc)
var newNetworks []swarm.NetworkAttachmentConfig
^
cli/command/service/update.go:1514:2: Consider pre-allocating `out` (prealloc)
var out []string
^
cli/compose/convert/service.go:713:2: Consider pre-allocating `ulimits` (prealloc)
var ulimits []*units.Ulimit
^
cli/compose/convert/volume.go:13:2: Consider pre-allocating `mounts` (prealloc)
var mounts []mount.Mount
^
cli/command/stack/swarm/list.go:39:2: Consider pre-allocating `stacks` (prealloc)
var stacks []*formatter.Stack
^
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
180 lines
4.4 KiB
Go
180 lines
4.4 KiB
Go
package secret
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/docker/cli/cli/command"
|
|
"github.com/docker/cli/cli/command/formatter"
|
|
"github.com/docker/cli/cli/command/inspect"
|
|
"github.com/docker/docker/api/types/swarm"
|
|
units "github.com/docker/go-units"
|
|
)
|
|
|
|
const (
|
|
defaultSecretTableFormat = "table {{.ID}}\t{{.Name}}\t{{.Driver}}\t{{.CreatedAt}}\t{{.UpdatedAt}}" // #nosec G101
|
|
secretIDHeader = "ID"
|
|
secretCreatedHeader = "CREATED"
|
|
secretUpdatedHeader = "UPDATED"
|
|
secretInspectPrettyTemplate formatter.Format = `ID: {{.ID}}
|
|
Name: {{.Name}}
|
|
{{- if .Labels }}
|
|
Labels:
|
|
{{- range $k, $v := .Labels }}
|
|
- {{ $k }}{{if $v }}={{ $v }}{{ end }}
|
|
{{- end }}{{ end }}
|
|
Driver: {{.Driver}}
|
|
Created at: {{.CreatedAt}}
|
|
Updated at: {{.UpdatedAt}}`
|
|
)
|
|
|
|
// NewFormat returns a Format for rendering using a secret Context
|
|
func NewFormat(source string, quiet bool) formatter.Format {
|
|
switch source {
|
|
case formatter.PrettyFormatKey:
|
|
return secretInspectPrettyTemplate
|
|
case formatter.TableFormatKey:
|
|
if quiet {
|
|
return formatter.DefaultQuietFormat
|
|
}
|
|
return defaultSecretTableFormat
|
|
}
|
|
return formatter.Format(source)
|
|
}
|
|
|
|
// FormatWrite writes the context
|
|
func FormatWrite(ctx formatter.Context, secrets []swarm.Secret) error {
|
|
render := func(format func(subContext formatter.SubContext) error) error {
|
|
for _, secret := range secrets {
|
|
secretCtx := &secretContext{s: secret}
|
|
if err := format(secretCtx); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
return ctx.Write(newSecretContext(), render)
|
|
}
|
|
|
|
func newSecretContext() *secretContext {
|
|
sCtx := &secretContext{}
|
|
|
|
sCtx.Header = formatter.SubHeaderContext{
|
|
"ID": secretIDHeader,
|
|
"Name": formatter.NameHeader,
|
|
"Driver": formatter.DriverHeader,
|
|
"CreatedAt": secretCreatedHeader,
|
|
"UpdatedAt": secretUpdatedHeader,
|
|
"Labels": formatter.LabelsHeader,
|
|
}
|
|
return sCtx
|
|
}
|
|
|
|
type secretContext struct {
|
|
formatter.HeaderContext
|
|
s swarm.Secret
|
|
}
|
|
|
|
func (c *secretContext) MarshalJSON() ([]byte, error) {
|
|
return formatter.MarshalJSON(c)
|
|
}
|
|
|
|
func (c *secretContext) ID() string {
|
|
return c.s.ID
|
|
}
|
|
|
|
func (c *secretContext) Name() string {
|
|
return c.s.Spec.Annotations.Name
|
|
}
|
|
|
|
func (c *secretContext) CreatedAt() string {
|
|
return units.HumanDuration(time.Now().UTC().Sub(c.s.Meta.CreatedAt)) + " ago"
|
|
}
|
|
|
|
func (c *secretContext) Driver() string {
|
|
if c.s.Spec.Driver == nil {
|
|
return ""
|
|
}
|
|
return c.s.Spec.Driver.Name
|
|
}
|
|
|
|
func (c *secretContext) UpdatedAt() string {
|
|
return units.HumanDuration(time.Now().UTC().Sub(c.s.Meta.UpdatedAt)) + " ago"
|
|
}
|
|
|
|
func (c *secretContext) Labels() string {
|
|
mapLabels := c.s.Spec.Annotations.Labels
|
|
if mapLabels == nil {
|
|
return ""
|
|
}
|
|
joinLabels := make([]string, 0, len(mapLabels))
|
|
for k, v := range mapLabels {
|
|
joinLabels = append(joinLabels, k+"="+v)
|
|
}
|
|
return strings.Join(joinLabels, ",")
|
|
}
|
|
|
|
func (c *secretContext) Label(name string) string {
|
|
if c.s.Spec.Annotations.Labels == nil {
|
|
return ""
|
|
}
|
|
return c.s.Spec.Annotations.Labels[name]
|
|
}
|
|
|
|
// InspectFormatWrite renders the context for a list of secrets
|
|
func InspectFormatWrite(ctx formatter.Context, refs []string, getRef inspect.GetRefFunc) error {
|
|
if ctx.Format != secretInspectPrettyTemplate {
|
|
return inspect.Inspect(ctx.Output, refs, string(ctx.Format), getRef)
|
|
}
|
|
render := func(format func(subContext formatter.SubContext) error) error {
|
|
for _, ref := range refs {
|
|
secretI, _, err := getRef(ref)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
secret, ok := secretI.(swarm.Secret)
|
|
if !ok {
|
|
return fmt.Errorf("got wrong object to inspect :%v", ok)
|
|
}
|
|
if err := format(&secretInspectContext{Secret: secret}); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
return ctx.Write(&secretInspectContext{}, render)
|
|
}
|
|
|
|
type secretInspectContext struct {
|
|
swarm.Secret
|
|
formatter.SubContext
|
|
}
|
|
|
|
func (ctx *secretInspectContext) ID() string {
|
|
return ctx.Secret.ID
|
|
}
|
|
|
|
func (ctx *secretInspectContext) Name() string {
|
|
return ctx.Secret.Spec.Name
|
|
}
|
|
|
|
func (ctx *secretInspectContext) Labels() map[string]string {
|
|
return ctx.Secret.Spec.Labels
|
|
}
|
|
|
|
func (ctx *secretInspectContext) Driver() string {
|
|
if ctx.Secret.Spec.Driver == nil {
|
|
return ""
|
|
}
|
|
return ctx.Secret.Spec.Driver.Name
|
|
}
|
|
|
|
func (ctx *secretInspectContext) CreatedAt() string {
|
|
return command.PrettyPrint(ctx.Secret.CreatedAt)
|
|
}
|
|
|
|
func (ctx *secretInspectContext) UpdatedAt() string {
|
|
return command.PrettyPrint(ctx.Secret.UpdatedAt)
|
|
}
|