diff --git a/libbeat/keystore/file_keystore.go b/libbeat/keystore/file_keystore.go index 4ca43ec18bf..35edce45466 100644 --- a/libbeat/keystore/file_keystore.go +++ b/libbeat/keystore/file_keystore.go @@ -13,6 +13,7 @@ import ( "os" "path/filepath" "runtime" + "strings" "sync" "golang.org/x/crypto/pbkdf2" @@ -88,6 +89,9 @@ func (k *FileKeystore) Retrieve(key string) (*SecureString, error) { // Store add the key pair to the secret store and mark the store as dirty. func (k *FileKeystore) Store(key string, value []byte) error { + if err := k.validateKey(key); err != nil { + return err + } k.Lock() defer k.Unlock() @@ -382,3 +386,11 @@ func (k *FileKeystore) checkPermissions(f string) error { func (k *FileKeystore) hashPassword(password, salt []byte) []byte { return pbkdf2.Key(password, salt, iterationsCount, keyLength, sha512.New) } + +func (k *FileKeystore) validateKey(key string) error { + if strings.IndexAny(key, ".") != -1 { + return fmt.Errorf("invalid key format. '.' in keys are not supported yet. key: %s", key) + } + + return nil +} diff --git a/libbeat/keystore/file_keystore_test.go b/libbeat/keystore/file_keystore_test.go index 4d4a9f8d2d3..baaf6599c0c 100644 --- a/libbeat/keystore/file_keystore_test.go +++ b/libbeat/keystore/file_keystore_test.go @@ -13,9 +13,21 @@ import ( "github.com/elastic/beats/libbeat/common" ) -var keyValue = "output.elasticsearch.password" +var keyValue = "output_elasticsearch_password" var secretValue = []byte("secret") +func TestInvalidKey(t *testing.T) { + path := GetTemporaryKeystoreFile() + defer os.Remove(path) + + keystore, err := NewFileKeystore(path) + assert.NoError(t, err) + err = keystore.Store("output.elasticsearch.password", secretValue) + if assert.Error(t, err) { + assert.Equal(t, err.Error(), "invalid key format. '.' in keys are not supported yet. key: output.elasticsearch.password") + } +} + func TestCanCreateAKeyStore(t *testing.T) { path := GetTemporaryKeystoreFile() defer os.Remove(path) @@ -185,18 +197,18 @@ func TestGetConfig(t *testing.T) { keystore := CreateAnExistingKeystore(path) // Add a bit more data of different type - keystore.Store("super.nested", []byte("hello")) + keystore.Store("super_nested", []byte("hello")) keystore.Save() cfg, err := keystore.GetConfig() assert.NotNil(t, cfg) assert.NoError(t, err) - secret, err := cfg.String("output.elasticsearch.password", 0) + secret, err := cfg.String("output_elasticsearch_password", 0) assert.NoError(t, err) assert.Equal(t, secret, "secret") - port, err := cfg.String("super.nested", 0) + port, err := cfg.String("super_nested", 0) assert.Equal(t, port, "hello") } diff --git a/libbeat/keystore/keystore_test.go b/libbeat/keystore/keystore_test.go index 5b7167db0c1..5346cb4784b 100644 --- a/libbeat/keystore/keystore_test.go +++ b/libbeat/keystore/keystore_test.go @@ -27,7 +27,7 @@ func TestResolverWhenTheKeyExist(t *testing.T) { keystore := CreateAnExistingKeystore(path) resolver := ResolverWrap(keystore) - v, err := resolver("output.elasticsearch.password") + v, err := resolver("output_elasticsearch_password") assert.NoError(t, err) assert.Equal(t, v, "secret") }