From bb5491126537ab52dd8682965eeb9c7eaca12103 Mon Sep 17 00:00:00 2001 From: Daniel Fernandes Martins Date: Wed, 22 Mar 2017 21:21:49 -0300 Subject: [PATCH 1/2] Automatically creates the token auth file if it isn't present --- core/controlplane/config/token_config.go | 7 ++++++ core/controlplane/config/token_config_test.go | 25 +++++++++++++++++++ 2 files changed, 32 insertions(+) diff --git a/core/controlplane/config/token_config.go b/core/controlplane/config/token_config.go index eb08aabe4..640234ca5 100644 --- a/core/controlplane/config/token_config.go +++ b/core/controlplane/config/token_config.go @@ -5,6 +5,7 @@ import ( "encoding/csv" "fmt" "io/ioutil" + "os" "path/filepath" "github.com/aws/aws-sdk-go/aws" @@ -152,6 +153,12 @@ func (r *EncryptedAuthTokensOnDisk) Compact() (*CompactAuthTokens, error) { func ReadOrEncryptAuthTokens(dirname string, encryptor CachedEncryptor) (*EncryptedAuthTokensOnDisk, error) { authTokenPath := filepath.Join(dirname, "tokens.csv") + + // Auto-creates the auth token file, useful for those coming from previous versions of kube-aws + if _, err := os.Stat(authTokenPath); os.IsNotExist(err) { + os.OpenFile(authTokenPath, os.O_RDONLY|os.O_CREATE, 0600) + } + if _, err := ReadRawAuthTokens(dirname); err != nil { return nil, err } diff --git a/core/controlplane/config/token_config_test.go b/core/controlplane/config/token_config_test.go index bb077c92a..09dfae4e0 100644 --- a/core/controlplane/config/token_config_test.go +++ b/core/controlplane/config/token_config_test.go @@ -77,6 +77,31 @@ func TestReadOrCreateCompactEmptyAuthTokens(t *testing.T) { }) } +func TestReadOrCreateCompactEmptyAuthTokens(t *testing.T) { + helper.WithDummyCredentials(func(dir string) { + kmsConfig := KMSConfig{ + KMSKeyARN: "keyarn", + Region: model.RegionForName("us-west-1"), + EncryptService: &dummyEncryptService{}, + } + + if err := os.Remove(filepath.Join(dir, "tokens.csv")); err != nil { + t.Errorf("failed to remove tokens.csv for test setup : %v", err) + t.FailNow() + } + + created, err := ReadOrCreateCompactAuthTokens(dir, kmsConfig) + + if err != nil { + t.Errorf("failed to read or update compact auth tokens in %s : %v", dir, err) + } + + if len(created.Contents) > 0 { + t.Errorf("compacted auth tokens expected to be an empty string, but was %s", created.Contents) + } + }) +} + func TestReadOrCreateEmptyUnEcryptedCompactAuthTokens(t *testing.T) { helper.WithDummyCredentials(func(dir string) { t.Run("CachedToPreventUnnecessaryNodeReplacementOnUnencrypted", func(t *testing.T) { From 50b2b2c3fd144b6abad9962d69874fce585b5e46 Mon Sep 17 00:00:00 2001 From: Daniel Fernandes Martins Date: Wed, 22 Mar 2017 21:34:38 -0300 Subject: [PATCH 2/2] Fixed function name --- core/controlplane/config/token_config_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/controlplane/config/token_config_test.go b/core/controlplane/config/token_config_test.go index 09dfae4e0..cf3e7961b 100644 --- a/core/controlplane/config/token_config_test.go +++ b/core/controlplane/config/token_config_test.go @@ -77,7 +77,7 @@ func TestReadOrCreateCompactEmptyAuthTokens(t *testing.T) { }) } -func TestReadOrCreateCompactEmptyAuthTokens(t *testing.T) { +func TestReadOrCreateCompactNonExistentAuthTokens(t *testing.T) { helper.WithDummyCredentials(func(dir string) { kmsConfig := KMSConfig{ KMSKeyARN: "keyarn",