View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements. See the NOTICE file distributed with
4    * this work for additional information regarding copyright ownership.
5    * The ASF licenses this file to You under the Apache license, Version 2.0
6    * (the "License"); you may not use this file except in compliance with
7    * the License. You may obtain a copy of the License at
8    *
9    *      http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the license for the specific language governing permissions and
15   * limitations under the license.
16   */
17  package org.apache.log4j.config;
18  
19  import java.io.IOException;
20  import java.io.InputStream;
21  
22  import org.apache.logging.log4j.core.LoggerContext;
23  import org.apache.logging.log4j.core.config.Configuration;
24  import org.apache.logging.log4j.core.config.ConfigurationException;
25  import org.apache.logging.log4j.core.config.ConfigurationFactory;
26  import org.apache.logging.log4j.core.config.ConfigurationSource;
27  import org.apache.logging.log4j.core.config.builder.api.ConfigurationBuilder;
28  import org.apache.logging.log4j.core.config.builder.impl.BuiltConfiguration;
29  
30  /**
31   * Experimental ConfigurationFactory for Log4j 1.2 properties configuration files.
32   */
33  // TODO
34  // @Plugin(name = "Log4j1ConfigurationFactory", category = ConfigurationFactory.CATEGORY)
35  //
36  // Best Value?
37  // @Order(50)
38  public class Log4j1ConfigurationFactory extends ConfigurationFactory {
39  
40      private static final String[] SUFFIXES = {".properties"};
41  
42      @Override
43      public Configuration getConfiguration(final LoggerContext loggerContext, final ConfigurationSource source) {
44          final ConfigurationBuilder<BuiltConfiguration> builder;
45          try (final InputStream configStream = source.getInputStream()) {
46              builder = new Log4j1ConfigurationParser().buildConfigurationBuilder(configStream);
47          } catch (final IOException e) {
48              throw new ConfigurationException("Unable to load " + source, e);
49          }
50          return builder.build();
51      }
52  
53      @Override
54      protected String[] getSupportedTypes() {
55          return SUFFIXES;
56      }
57  
58  }