cmd/k8s-operator: redact auth key from debug logs (#11523)
Updates#cleanup Signed-off-by: Irbe Krumina <irbe@tailscale.com>
This commit is contained in:
parent
55baf9474f
commit
4cbef20569
|
@ -34,6 +34,7 @@ import (
|
||||||
"tailscale.com/net/netutil"
|
"tailscale.com/net/netutil"
|
||||||
"tailscale.com/tailcfg"
|
"tailscale.com/tailcfg"
|
||||||
"tailscale.com/types/opt"
|
"tailscale.com/types/opt"
|
||||||
|
"tailscale.com/types/ptr"
|
||||||
"tailscale.com/util/dnsname"
|
"tailscale.com/util/dnsname"
|
||||||
"tailscale.com/util/mak"
|
"tailscale.com/util/mak"
|
||||||
)
|
)
|
||||||
|
@ -352,12 +353,12 @@ func (a *tailscaleSTSReconciler) createOrGetSecret(ctx context.Context, logger *
|
||||||
}
|
}
|
||||||
|
|
||||||
if orig != nil {
|
if orig != nil {
|
||||||
logger.Debugf("patching existing state Secret with values %s", secret.Data[tailscaledConfigKey])
|
logger.Debugf("patching the existing proxy Secret with tailscaled config %s", sanitizeConfigBytes(secret.Data[tailscaledConfigKey]))
|
||||||
if err := a.Patch(ctx, secret, client.MergeFrom(orig)); err != nil {
|
if err := a.Patch(ctx, secret, client.MergeFrom(orig)); err != nil {
|
||||||
return "", "", err
|
return "", "", err
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
logger.Debugf("creating new state Secret with authkey %s", secret.Data[tailscaledConfigKey])
|
logger.Debugf("creating a new Secret for the proxy with tailscaled config %s", sanitizeConfigBytes([]byte(secret.StringData[tailscaledConfigKey])))
|
||||||
if err := a.Create(ctx, secret); err != nil {
|
if err := a.Create(ctx, secret); err != nil {
|
||||||
return "", "", err
|
return "", "", err
|
||||||
}
|
}
|
||||||
|
@ -365,6 +366,23 @@ func (a *tailscaleSTSReconciler) createOrGetSecret(ctx context.Context, logger *
|
||||||
return secret.Name, hash, nil
|
return secret.Name, hash, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// sanitizeConfigBytes returns ipn.ConfigVAlpha in string form with redacted
|
||||||
|
// auth key.
|
||||||
|
func sanitizeConfigBytes(bs []byte) string {
|
||||||
|
c := &ipn.ConfigVAlpha{}
|
||||||
|
if err := json.Unmarshal(bs, c); err != nil {
|
||||||
|
return "invalid config"
|
||||||
|
}
|
||||||
|
if c.AuthKey != nil {
|
||||||
|
c.AuthKey = ptr.To("**redacted**")
|
||||||
|
}
|
||||||
|
sanitizedBytes, err := json.Marshal(c)
|
||||||
|
if err != nil {
|
||||||
|
return "invalid config"
|
||||||
|
}
|
||||||
|
return string(sanitizedBytes)
|
||||||
|
}
|
||||||
|
|
||||||
// DeviceInfo returns the device ID and hostname for the Tailscale device
|
// DeviceInfo returns the device ID and hostname for the Tailscale device
|
||||||
// associated with the given labels.
|
// associated with the given labels.
|
||||||
func (a *tailscaleSTSReconciler) DeviceInfo(ctx context.Context, childLabels map[string]string) (id tailcfg.StableNodeID, hostname string, ips []string, err error) {
|
func (a *tailscaleSTSReconciler) DeviceInfo(ctx context.Context, childLabels map[string]string) (id tailcfg.StableNodeID, hostname string, ips []string, err error) {
|
||||||
|
|
Loading…
Reference in New Issue