From 3b87fabe42564cb964cffa56848ca639385a38dd Mon Sep 17 00:00:00 2001 From: Tom Wieczorek Date: Fri, 26 Apr 2024 18:35:26 +0200 Subject: [PATCH] More helpful error message for empty/absent token files An empty token file is a typical error condition when k0s gets installed via k0sctl, but fails to join the cluster when first started. The previous error message was a little bit cryptic. Try to be more helpful by suggesting to create a new token or try to reinstall the node. Signed-off-by: Tom Wieczorek --- pkg/component/worker/utils.go | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/pkg/component/worker/utils.go b/pkg/component/worker/utils.go index dba1a7c48c9f..f801e7254941 100644 --- a/pkg/component/worker/utils.go +++ b/pkg/component/worker/utils.go @@ -18,6 +18,7 @@ package worker import ( "context" + "errors" "fmt" "os" "path" @@ -75,10 +76,22 @@ func BootstrapKubeletKubeconfig(ctx context.Context, k0sVars *config.CfgVars, wo if workerOpts.TokenArg != "" { tokenData = workerOpts.TokenArg } else { + var problem string data, err := os.ReadFile(workerOpts.TokenFile) - if err != nil { + if errors.Is(err, os.ErrNotExist) { + problem = "not found" + } else if err != nil { return fmt.Errorf("failed to read token file: %w", err) + } else if len(data) == 0 { + problem = "is empty" } + if problem != "" { + return fmt.Errorf("token file %q %s"+ + `: obtain a new token via "k0s token create ..." and store it in the file`+ + ` or reinstall this node via "k0s install --force ..." or "k0sctl apply --force ..."`, + workerOpts.TokenFile, problem) + } + tokenData = string(data) }