blob: d0080c5b90e4cf0a144944de94bef61c99d0a099 [file] [log] [blame]
// Copyright (C) 2013 The Android Open Source Project
//
// 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.googlesource.gerrit.plugins.github.velocity;
import com.google.gerrit.extensions.annotations.PluginName;
import com.google.gerrit.server.config.SitePaths;
import com.google.inject.Inject;
import com.google.inject.Provider;
import com.google.inject.ProvisionException;
import com.google.inject.Singleton;
import java.net.URL;
import java.net.URLClassLoader;
import java.util.Properties;
import org.apache.velocity.runtime.RuntimeConstants;
import org.apache.velocity.runtime.RuntimeInstance;
import org.apache.velocity.runtime.log.Log4JLogChute;
import org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader;
import org.apache.velocity.runtime.resource.loader.JarResourceLoader;
@Singleton
public class PluginVelocityRuntimeProvider implements Provider<RuntimeInstance> {
private static final String VELOCITY_FILE_RESOURCE_LOADER_PATH = "file.resource.loader.path";
private static final String VELOCITY_FILE_RESOURCE_LOADER_CLASS = "file.resource.loader.class";
private static final String VELOCITY_CLASS_RESOURCE_LOADER_CLASS = "class.resource.loader.class";
private static final String VELOCITY_JAR_RESOURCE_LOADER_CLASS = "jar.resource.loader.class";
private static final String VELOCITY_JAR_RESOURCE_LOADER_PATH = "jar.resource.loader.path";
private static final String VELOCITY_RESOURCE_LOADER = "resource.loader";
private final SitePaths site;
private String pluginName;
@Inject
PluginVelocityRuntimeProvider(SitePaths site, @PluginName String pluginName) {
this.site = site;
this.pluginName = pluginName;
}
@Override
public RuntimeInstance get() {
String pkg = "org.apache.velocity.runtime.resource.loader";
Properties p = new Properties();
p.setProperty(RuntimeConstants.VM_PERM_INLINE_LOCAL, "true");
p.setProperty(RuntimeConstants.RUNTIME_LOG_LOGSYSTEM_CLASS, Log4JLogChute.class.getName());
p.setProperty(RuntimeConstants.RUNTIME_REFERENCES_STRICT, "true");
p.setProperty("runtime.log.logsystem.log4j.category", "velocity");
p.setProperty(VELOCITY_RESOURCE_LOADER, "file, class, jar");
p.setProperty(VELOCITY_FILE_RESOURCE_LOADER_CLASS, pkg + ".FileResourceLoader");
p.setProperty(
VELOCITY_FILE_RESOURCE_LOADER_PATH,
site.static_dir.getParent().toAbsolutePath().toString());
p.setProperty(VELOCITY_CLASS_RESOURCE_LOADER_CLASS, ClasspathResourceLoader.class.getName());
p.setProperty(VELOCITY_JAR_RESOURCE_LOADER_CLASS, JarResourceLoader.class.getName());
p.setProperty(VELOCITY_JAR_RESOURCE_LOADER_PATH, detectPluginJar());
RuntimeInstance ri = new RuntimeInstance();
try {
ri.init(p);
} catch (Exception err) {
throw new ProvisionException("Cannot configure Velocity templates", err);
}
return ri;
}
private String detectPluginJar() {
ClassLoader myClassLoader = this.getClass().getClassLoader();
if (!URLClassLoader.class.isAssignableFrom(myClassLoader.getClass())) {
throw new IllegalStateException(pluginName + " plugin can be loaded only from a Jar file");
}
@SuppressWarnings("resource")
URLClassLoader jarClassLoader = (URLClassLoader) myClassLoader;
URL[] jarUrls = jarClassLoader.getURLs();
for (URL url : jarUrls) {
if (url.getProtocol().equals("file") && url.getPath().endsWith(".jar")) {
return "jar:" + url.toString();
}
}
throw new IllegalStateException(
"Cannot find any Jar file in "
+ pluginName
+ " plugin class loader URLs "
+ jarUrls
+ ": unable to initialize Velocity resource loading.");
}
}