From e6935876b97a63bae2ec087b4fc390c832aef155 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Thu, 22 Dec 2011 17:06:35 -0500 Subject: [PATCH] Drop recent activity y-axis labels --- src/com/gitblit/WebXmlSettings.java | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 52 insertions(+), 0 deletions(-) diff --git a/src/com/gitblit/WebXmlSettings.java b/src/com/gitblit/WebXmlSettings.java index 4b0358d..7c8120b 100644 --- a/src/com/gitblit/WebXmlSettings.java +++ b/src/com/gitblit/WebXmlSettings.java @@ -15,7 +15,14 @@ */ package com.gitblit; +import java.io.File; +import java.io.FileInputStream; +import java.io.FileOutputStream; +import java.io.InputStream; +import java.io.OutputStream; +import java.text.MessageFormat; import java.util.Enumeration; +import java.util.Map; import java.util.Properties; import javax.servlet.ServletContext; @@ -32,6 +39,8 @@ private final Properties properties = new Properties(); + private File overrideFile; + public WebXmlSettings(ServletContext context) { super(WebXmlSettings.class); Enumeration<?> keys = context.getInitParameterNames(); @@ -43,6 +52,23 @@ } } + public void applyOverrides(File overrideFile) { + this.overrideFile = overrideFile; + + // apply any web-configured overrides + if (overrideFile.exists()) { + try { + InputStream is = new FileInputStream(overrideFile); + properties.load(is); + is.close(); + } catch (Throwable t) { + logger.error( + MessageFormat.format("Failed to apply {0} setting overrides", + overrideFile.getAbsolutePath()), t); + } + } + } + private String decodeValue(String value) { // decode escaped backslashes and HTML entities return StringUtils.decodeFromHtml(value).replace("\\\\", "\\"); @@ -54,6 +80,32 @@ } @Override + public synchronized boolean saveSettings(Map<String, String> settings) { + try { + Properties props = new Properties(); + // load pre-existing web-configuration + if (overrideFile.exists()) { + InputStream is = new FileInputStream(overrideFile); + props.load(is); + is.close(); + } + + // put all new settings and persist + props.putAll(settings); + OutputStream os = new FileOutputStream(overrideFile); + props.store(os, null); + os.close(); + + // override current runtime settings + properties.putAll(settings); + return true; + } catch (Throwable t) { + logger.error("Failed to save settings!", t); + } + return false; + } + + @Override public String toString() { return "WEB.XML"; } -- Gitblit v1.9.1