001/**
002 * Copyright (C) 2006-2022 Talend Inc. - www.talend.com
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016package org.talend.sdk.component.server.configuration;
017
018import java.io.File;
019import java.util.Properties;
020
021import org.apache.logging.log4j.LogManager;
022import org.apache.logging.log4j.core.LoggerContext;
023import org.apache.meecrowave.Meecrowave;
024import org.apache.meecrowave.configuration.Configuration;
025
026public class PropertiesSetup implements Meecrowave.ConfigurationCustomizer {
027
028    @Override
029    public void accept(final Configuration configuration) {
030        // By default we want to skip vault calls zipkin logs, we can still override it...
031        System.setProperty("geronimo.opentracing.client.filter.request.skip", "true");
032        System.setProperty("geronimo.opentracing.filter.skippedTracing.urls", ".*/login$,.*/decrypt/.*");
033        System.setProperty("geronimo.opentracing.filter.skippedTracing.matcherType", "regex");
034        // environment dft ordinal 400
035        final String httpPort = System.getenv("TALEND_COMPONENT_SERVER_PORT");
036        if (httpPort != null) {
037            System.setProperty("http", httpPort);
038            configuration.setHttpPort(Integer.parseInt(httpPort));
039        }
040        final String log4jLayout = System.getenv("LOGGING_LAYOUT");
041        final String appHome = System.getenv("TALEND_APP_HOME");
042        if (log4jLayout != null && appHome != null) {
043            final String initialConfig = System.getProperty("log4j.configurationFile", "default.properties");
044            final String newConfig = String.format("%s/conf/log4j2-component-server-%s.xml", appHome, log4jLayout);
045            if (!newConfig.equals(initialConfig)) {
046                System.setProperty("log4j.configurationFile", newConfig);
047                LoggerContext ctx = (LoggerContext) LogManager.getContext(false);
048                ctx.setConfigLocation(new File(newConfig).toURI());
049                ctx.reconfigure();
050                ctx.updateLoggers();
051            }
052        }
053        //
054        configuration.loadFromProperties(System.getProperties());
055        if (configuration.getProperties() == null) {
056            configuration.setProperties(new Properties());
057        }
058        configuration.getProperties().putAll(System.getProperties());
059        configuration
060                .getProperties()
061                .stringPropertyNames()
062                .stream()
063                .filter(k -> System.getProperty(k) == null)
064                .forEach(k -> System.setProperty(k, configuration.getProperties().getProperty(k)));
065    }
066}