From f762b160efd5cafd919a6fd7f9587f578eceb454 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Sun, 02 Oct 2011 16:59:44 -0400 Subject: [PATCH] Merge branch 'master' into rpc --- src/com/gitblit/WebXmlSettings.java | 91 +++++++++++++++++++++------------------------ 1 files changed, 43 insertions(+), 48 deletions(-) diff --git a/src/com/gitblit/WebXmlSettings.java b/src/com/gitblit/WebXmlSettings.java index 00084bf..4b0358d 100644 --- a/src/com/gitblit/WebXmlSettings.java +++ b/src/com/gitblit/WebXmlSettings.java @@ -1,65 +1,60 @@ +/* + * Copyright 2011 gitblit.com. + * + * Licensed 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 com.gitblit; -import java.util.List; +import java.util.Enumeration; +import java.util.Properties; import javax.servlet.ServletContext; -public class WebXmlSettings implements IStoredSettings { +import com.gitblit.utils.StringUtils; + +/** + * Loads Gitblit settings from the context-parameter values of a web.xml file. + * + * @author James Moger + * + */ +public class WebXmlSettings extends IStoredSettings { + + private final Properties properties = new Properties(); public WebXmlSettings(ServletContext context) { - + super(WebXmlSettings.class); + Enumeration<?> keys = context.getInitParameterNames(); + while (keys.hasMoreElements()) { + String key = keys.nextElement().toString(); + String value = context.getInitParameter(key); + properties.put(key, decodeValue(value)); + logger.debug(key + "=" + properties.getProperty(key)); + } } - - @Override - public List<String> getAllKeys(String startingWith) { - // TODO Auto-generated method stub - return null; + + private String decodeValue(String value) { + // decode escaped backslashes and HTML entities + return StringUtils.decodeFromHtml(value).replace("\\\\", "\\"); } @Override - public boolean getBoolean(String name, boolean defaultValue) { - // TODO Auto-generated method stub - return false; + protected Properties read() { + return properties; } - @Override - public int getInteger(String name, int defaultValue) { - // TODO Auto-generated method stub - return 0; - } - - @Override - public String getString(String name, String defaultValue) { - // TODO Auto-generated method stub - return null; - } - - @Override - public List<String> getStrings(String name) { - // TODO Auto-generated method stub - return null; - } - - @Override - public List<String> getStringsFromValue(String value) { - // TODO Auto-generated method stub - return null; - } - - @Override - public List<String> getStrings(String name, String separator) { - // TODO Auto-generated method stub - return null; - } - - @Override - public List<String> getStringsFromValue(String value, String separator) { - // TODO Auto-generated method stub - return null; - } - @Override public String toString() { - return getClass().getSimpleName() + ": web.xml"; + return "WEB.XML"; } } -- Gitblit v1.9.1