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

org.apache.jackrabbit.j2ee.JNDIConfig 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.jackrabbit.j2ee;

import java.util.Enumeration;
import java.util.Iterator;
import java.util.Properties;

import javax.servlet.ServletConfig;
import javax.servlet.ServletException;

/**
 * The JNDI config hold information about JNDI connection details.
 *
 * It supports the following properties and init parameters:
 * 
 * +-------------------+--------------------+
 * | Property Name     | Init-Param Name    |
 * +-------------------+--------------------+
 * | jndi.enable       | {provider spec.}   |
 * | java.naming.*     | java.naming.*      |
 * +-------------------+--------------------+
 * 
*/ public class JNDIConfig extends AbstractConfig { private boolean jndiEnabled; private String jndiName; private final BootstrapConfig parentConfig; private Properties jndiEnv = new Properties(); public JNDIConfig(BootstrapConfig parentConfig) { this.parentConfig = parentConfig; } public String getJndiName() { return jndiName; } public void setJndiName(String jndiName) { this.jndiName = jndiName; } public boolean enabled() { return jndiEnabled; } public String getJndiEnabled() { return String.valueOf(jndiEnabled); } public void setJndiEnabled(String jndiEnabled) { this.jndiEnabled = Boolean.valueOf(jndiEnabled).booleanValue(); } public Properties getJndiEnv() { return jndiEnv; } public void init(Properties props) throws ServletException { super.init(props); // add all props whose name starts with 'java.namming.' to the env Iterator iter = props.keySet().iterator(); while (iter.hasNext()) { String name = (String) iter.next(); if (name.startsWith("java.naming.")) { jndiEnv.put(name, props.getProperty(name)); } } } public void init(ServletConfig ctx) throws ServletException { super.init(ctx); // add all params whose name starts with 'java.namming.' to the env Enumeration names = ctx.getInitParameterNames(); while (names.hasMoreElements()) { String name = (String) names.nextElement(); if (name.startsWith("java.naming.")) { jndiEnv.put(name, ctx.getInitParameter(name)); } } // enable jndi if url is specified jndiEnabled = jndiEnv.containsKey("java.naming.provider.url"); } public void validate() { if (jndiName == null) { jndiName = parentConfig.getRepositoryName(); } valid = true; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy