All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.camel.quarkus.component.jasypt.CamelJasyptConfig Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apache.camel.quarkus.component.jasypt;

import java.lang.reflect.InvocationTargetException;
import java.util.Optional;
import java.util.Set;

import io.quarkus.runtime.annotations.ConfigPhase;
import io.quarkus.runtime.annotations.ConfigRoot;
import io.smallrye.config.ConfigMapping;
import io.smallrye.config.WithDefault;
import org.apache.camel.util.ObjectHelper;
import org.apache.camel.util.StringHelper;
import org.jasypt.encryption.pbe.StandardPBEByteEncryptor;
import org.jasypt.encryption.pbe.config.EnvironmentStringPBEConfig;
import org.jasypt.encryption.pbe.config.PBEConfig;
import org.jasypt.iv.NoIvGenerator;
import org.jasypt.iv.RandomIvGenerator;
import org.jasypt.salt.RandomSaltGenerator;

@ConfigMapping(prefix = "quarkus.camel.jasypt")
@ConfigRoot(phase = ConfigPhase.RUN_TIME)
public interface CamelJasyptConfig {
    String NAME = "camel-jasypt";
    String DEFAULT_ALGORITHM = StandardPBEByteEncryptor.DEFAULT_ALGORITHM;

    /**
     * The algorithm to be used for decryption.
     */
    @WithDefault(DEFAULT_ALGORITHM)
    String algorithm();

    /**
     * The master password used by Jasypt for decrypting configuration values.
     * This option supports prefixes which influence the master password lookup behaviour.
     * 

* sys: will to look up the value from a JVM system property. * sysenv: will look up the value from the OS system environment with the given key. *

*/ Optional password(); /** * Configures the Jasypt StandardPBEStringEncryptor with a RandomIvGenerator using the given algorithm. */ @WithDefault(RandomIvGenerator.DEFAULT_SECURE_RANDOM_ALGORITHM) String randomIvGeneratorAlgorithm(); /** * Configures the Jasypt StandardPBEStringEncryptor with a RandomSaltGenerator using the given algorithm. */ @WithDefault(RandomSaltGenerator.DEFAULT_SECURE_RANDOM_ALGORITHM) String randomSaltGeneratorAlgorithm(); /** * The fully qualified class name of an org.apache.camel.quarkus.component.jasypt.JasyptConfigurationCustomizer * implementation. This provides the optional capability of having full control over the Jasypt configuration. */ Optional configurationCustomizerClassName(); String SYS_CONFIG_PREFIX = "sys:"; String SYS_ENV_CONFIG_PREFIX = "sysenv:"; Set ALGORITHMS_THAT_REQUIRE_IV = Set.of( "PBEWITHHMACSHA1ANDAES_128", "PBEWITHHMACSHA1ANDAES_256", "PBEWITHHMACSHA224ANDAES_128", "PBEWITHHMACSHA224ANDAES_256", "PBEWITHHMACSHA256ANDAES_128", "PBEWITHHMACSHA256ANDAES_256", "PBEWITHHMACSHA384ANDAES_128", "PBEWITHHMACSHA384ANDAES_256", "PBEWITHHMACSHA512ANDAES_128", "PBEWITHHMACSHA512ANDAES_256"); default PBEConfig pbeConfig() { EnvironmentStringPBEConfig config = new EnvironmentStringPBEConfig(); String password = null; if (password().isPresent()) { password = password().get(); if (ObjectHelper.isNotEmpty(password)) { // Preserve backwards compat with the Camel way of configuring the master password if (password.startsWith(SYS_ENV_CONFIG_PREFIX)) { password = System.getenv(StringHelper.after(password, SYS_ENV_CONFIG_PREFIX)); } else if (password.startsWith(SYS_CONFIG_PREFIX)) { password = System.getProperty(StringHelper.after(password, SYS_CONFIG_PREFIX)); } } } config.setPassword(password); config.setAlgorithm(algorithm()); config.setIvGenerator(ALGORITHMS_THAT_REQUIRE_IV.contains(algorithm().toUpperCase()) ? new RandomIvGenerator(randomIvGeneratorAlgorithm()) : new NoIvGenerator()); config.setSaltGenerator(new RandomSaltGenerator(randomSaltGeneratorAlgorithm())); if (configurationCustomizerClassName().isPresent()) { try { Class encryptorClass = Thread.currentThread().getContextClassLoader() .loadClass(configurationCustomizerClassName().get()); JasyptConfigurationCustomizer customizer = (JasyptConfigurationCustomizer) encryptorClass .getDeclaredConstructor().newInstance(); customizer.customize(config); } catch (ClassNotFoundException | InvocationTargetException | InstantiationException | IllegalAccessException | NoSuchMethodException e) { throw new RuntimeException(e); } } // Avoid potentially confusing runtime NPEs and fail fast if no password has been configured try { config.getPassword(); } catch (NullPointerException e) { throw new IllegalStateException("The jasypt password has not been configured."); } return config; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy