Description
Usually we define externalize configuration in properties files to just make the application configuration independent. But one problem we face is that this information is usually endpoints and login credentials, like username and password. For this first type of information, there is usually no need to have them encrypted, but there typically is a requirement for this when storing credentials information.
I’m going to explain how to do this in SwitchYard.
Thanks to Nacim Boukhedimi for this post
The steps to be able to use vaulted configuration is:
- Create a vault file and store the property there
- Configure the application to read
Create a vault file
Vault mechanism is the mechanism provided by JBoss EAP 6 to enable you to encrypt sensitive strings and store them in an encrypted keystore. This mechanism relies upon tools that are included in all supported Java Development Kit (JDK) implementations. Below is a step by step description of how to encrypt your properties stored in an external properties file.
- Create a directory to hold your keystore and other important information. (for instance ${jboss.server.config.dir})
- Enter the following command to create a keystore file named vault.keystore:
keytool -genkey -alias vault -keyalg RSA -keysize 1024 -keystore vault.keystore
- Mask the Keystore Password and Initialize the Password Vault. From EAP_HOME/bin folder, run vault.sh and start a new interactive session
The salt value, together with the iteration count (below), are used to create the hash value. Make a note of generated vault Configuration in a secure location. It will be used in the next step to configure EAP to use vault. - Configure JBoss EAP 6 to Use the Password Vault. Copy and paste the generated vault Configuration in EAP config file:
<vault> <vault-option name="KEYSTORE_URL" value="${jboss.server.config.dir}/vault.keystore"/> <vault-option name="KEYSTORE_PASSWORD" value="MASK-18JTA2ZfD4eISrndbFgJRk"/> <vault-option name="KEYSTORE_ALIAS" value="vault"/> <vault-option name="SALT" value="8675309K"/> <vault-option name="ITERATION_COUNT" value="50"/> <vault-option name="ENC_FILE_DIR" value="${jboss.server.config.dir}/vault/"/> </vault><management>
Store your data in the vault
- Store encrypted Sensitive strings in the Java Keystore:
- run vault.sh and start a new interactive session
- Enter the path to the keystore, the keystore password, vault name, salt, and iteration count to perform a handshake.
- Select the option 0 to store a value.
- Enter the value, vault block, and attribute name.
- As a result, the value is stored and a message is displayed showing the vault block, attribute name, shared key, and advice about using the string in your configuration.
Vault Block:container Attribute Name:file.name Configuration should be done as follows: VAULT::container::file.name::1
Please make note of the vaultID to use in your properties file
Use the encrypted property in your properties file
Now it is time to use the property. As we want the property to be externalized, we will define the property in a properties file, and then instruct the server to use that properties file.
- In your properties, refer to this property as:
file.name=${VAULT::container::file.name::1}
You need to start the server with the P option to provide the path to the properties file. |
./standalone.sh -P=file:<path_to_properties>
Use the property in your switchyard.xml
You can refer then to this property from your switchyard.xml
<file:binding.file> <file:directory>/tmp/input</file:directory> <file:fileName>${file.name}</file:fileName> <file:consume> <file:initialDelay>10</file:initialDelay> <file:delay>10</file:delay> <file:delete>true</file:delete> </file:consume> </file:binding.file>
The file endpoint will be scanning for files under /tmp/input/<your secret filename>
No hay comentarios:
Publicar un comentario