Skip to content

Commit

Permalink
Remove duplicate and unused newDecodeConfigEntry func (#17979)
Browse files Browse the repository at this point in the history
  • Loading branch information
cthain authored Jun 30, 2023
1 parent 9ce89c4 commit 0b1299c
Show file tree
Hide file tree
Showing 2 changed files with 1 addition and 67 deletions.
2 changes: 1 addition & 1 deletion agent/structs/config_entry.go
Original file line number Diff line number Diff line change
Expand Up @@ -574,7 +574,7 @@ func (e *ProxyConfigEntry) UnmarshalBinary(data []byte) error {
// into a concrete type.
//
// There is an 'api' variation of this in
// command/config/write/config_write.go:newDecodeConfigEntry
// command/helpers/helpers.go:newDecodeConfigEntry
func DecodeConfigEntry(raw map[string]interface{}) (ConfigEntry, error) {
var entry ConfigEntry

Expand Down
66 changes: 0 additions & 66 deletions command/config/write/config_write.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,17 +7,12 @@ import (
"flag"
"fmt"
"io"
"time"

"github.com/hashicorp/go-multierror"
"github.com/mitchellh/cli"
"github.com/mitchellh/mapstructure"

"github.com/hashicorp/consul/api"
"github.com/hashicorp/consul/command/config"
"github.com/hashicorp/consul/command/flags"
"github.com/hashicorp/consul/command/helpers"
"github.com/hashicorp/consul/lib/decode"
)

func New(ui cli.Ui) *cmd {
Expand Down Expand Up @@ -109,67 +104,6 @@ func (c *cmd) Run(args []string) int {
return 0
}

// There is a 'structs' variation of this in
// agent/structs/config_entry.go:DecodeConfigEntry
func newDecodeConfigEntry(raw map[string]interface{}) (api.ConfigEntry, error) {
var entry api.ConfigEntry

kindVal, ok := raw["Kind"]
if !ok {
kindVal, ok = raw["kind"]
}
if !ok {
return nil, fmt.Errorf("Payload does not contain a kind/Kind key at the top level")
}

if kindStr, ok := kindVal.(string); ok {
newEntry, err := api.MakeConfigEntry(kindStr, "")
if err != nil {
return nil, err
}
entry = newEntry
} else {
return nil, fmt.Errorf("Kind value in payload is not a string")
}

var md mapstructure.Metadata
decodeConf := &mapstructure.DecoderConfig{
DecodeHook: mapstructure.ComposeDecodeHookFunc(
decode.HookWeakDecodeFromSlice,
decode.HookTranslateKeys,
mapstructure.StringToTimeDurationHookFunc(),
mapstructure.StringToTimeHookFunc(time.RFC3339),
),
Metadata: &md,
Result: &entry,
WeaklyTypedInput: true,
}

decoder, err := mapstructure.NewDecoder(decodeConf)
if err != nil {
return nil, err
}

if err := decoder.Decode(raw); err != nil {
return nil, err
}

for _, k := range md.Unused {
switch k {
case "kind", "Kind":
// The kind field is used to determine the target, but doesn't need
// to exist on the target.
continue
}
err = multierror.Append(err, fmt.Errorf("invalid config key %q", k))
}
if err != nil {
return nil, err
}

return entry, nil
}

func (c *cmd) Synopsis() string {
return synopsis
}
Expand Down

0 comments on commit 0b1299c

Please sign in to comment.