Package org.keycloak.vault
Class FilesPlainTextVaultProvider
- java.lang.Object
- 
- org.keycloak.vault.AbstractVaultProvider
- 
- org.keycloak.vault.FilesPlainTextVaultProvider
 
 
- 
- All Implemented Interfaces:
- Provider,- VaultProvider
 
 public class FilesPlainTextVaultProvider extends AbstractVaultProvider A text-based vault provider, which stores each secret in a separate file. The file name needs to match a vault secret id (or a key for short) and follows the format provided by the configuredVaultKeyResolver. A typical vault directory layout looks like this:${VAULT}/realma__key1 (contains secret for key 1) ${VAULT}/realma__key2 (contains secret for key 2) etc...Note, that in this case each key is prefixed by realm name. This particular kind of layout is used by Kubernetes by default (when mounting a volume into the pod) and can be used by selecting theREALM_UNDERSCORE_KEYresolver (which is the default resolver when none is defined). Other layouts are available through different resolvers. See https://kubernetes.io/docs/concepts/configuration/secret/ See https://github.com/keycloak/keycloak-community/blob/main/design/secure-credentials-store.md#plain-text-file-per-secret-kubernetes--openshift- Author:
- Sebastian Ćaskawiec
 
- 
- 
Field Summary- 
Fields inherited from class org.keycloak.vault.AbstractVaultProviderrealm, resolvers
 
- 
 - 
Constructor SummaryConstructors Constructor Description FilesPlainTextVaultProvider(Path path, String realmName, List<VaultKeyResolver> resolvers)Creates a newFilesPlainTextVaultProvider.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()protected VaultRawSecretobtainSecretInternal(String vaultSecretId)Subclasses ofAbstractVaultProvidermust implement this method.- 
Methods inherited from class org.keycloak.vault.AbstractVaultProviderobtainSecret
 
- 
 
- 
- 
- 
Constructor Detail- 
FilesPlainTextVaultProviderpublic FilesPlainTextVaultProvider(@Nonnull Path path, @Nonnull String realmName, @Nonnull List<VaultKeyResolver> resolvers)Creates a newFilesPlainTextVaultProvider.- Parameters:
- path- A path to a vault. Can not be null.
- realmName- A realm name. Can not be null.
 
 
- 
 - 
Method Detail- 
obtainSecretInternalprotected VaultRawSecret obtainSecretInternal(String vaultSecretId) Description copied from class:AbstractVaultProviderSubclasses ofAbstractVaultProvidermust implement this method. It is meant to be implemented in the same way as theAbstractVaultProvider.obtainSecret(String)method from theVaultProviderinterface, but the specified vault key must be used as is - i.e. implementations should refrain from processing the key again as the format was already defined by one of the configured key resolvers.- Specified by:
- obtainSecretInternalin class- AbstractVaultProvider
- Parameters:
- vaultSecretId- a- Stringrepresenting the name of the entry that is being fetched from the vault.
- Returns:
- a VaultRawSecretrepresenting the obtained secret. It can be a empty secret if no secret could be obtained using the specified vault key.
 
 - 
closepublic void close() 
 
- 
 
-