airshipctl/pkg/document/dochelper_utils.go
Alan Meadows e2cca32748 Add Redfish Authentication Support
This commit also introduces a dochelper concept.  This provides
some convenience methods to the document pkg that help extract data
from known document types as well as walk document relationships to
discover related information such as BMC credentials for baremetal
hosts.

Once merged, a follow up patchset will leverage these within the
cloud-init code to deduplicate some of these lookups.

Change-Id: Ie6a770ce4b34adbea30281917f0cb2fdc460b4fb
2020-03-27 15:29:07 -07:00

45 lines
1.1 KiB
Go

package document
import (
b64 "encoding/base64"
)
// GetSecretDataKey understands how to retrieve a specific top level key from a secret
// that may have the data stored under a data or stringData field in which
// case the key may be base64 encoded or it may be plain text
//
// it is meant to be used by other high level dochelpers
func GetSecretDataKey(cfg Document, key string) (string, error) {
var needsBase64Decode = true
var docName = cfg.GetName()
// this purposely doesn't handle binaryData as that isn't
// something we could support anyways
data, err := cfg.GetStringMap("stringData")
if err == nil {
needsBase64Decode = false
} else {
data, err = cfg.GetStringMap("data")
if err != nil {
return "", ErrDocumentMalformed{
DocName: docName,
Message: "The secret document lacks a data or stringData top level field",
}
}
}
res, ok := data[key]
if !ok {
return "", ErrDocumentDataKeyNotFound{DocName: docName, Key: key}
}
if needsBase64Decode {
byteSlice, err := b64.StdEncoding.DecodeString(res)
if err != nil {
return "", err
}
return string(byteSlice), nil
}
return res, nil
}