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}