Some bugfixes

ccm-docs
Jens Pelzetter 2020-12-24 12:03:33 +01:00
parent a8a8ac3acf
commit 201a4bf038
5 changed files with 99 additions and 11 deletions

View File

@ -0,0 +1,83 @@
/*
* Copyright (C) 2020 LibreCCM Foundation.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301 USA
*/
package org.libreccm.mvc.freemarker;
import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;
import org.eclipse.krazo.engine.ViewEngineBase;
import org.eclipse.krazo.engine.ViewEngineConfig;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.nio.charset.Charset;
import java.util.HashMap;
import java.util.Map;
import javax.annotation.Priority;
import javax.enterprise.context.ApplicationScoped;
import javax.inject.Inject;
import javax.mvc.engine.ViewEngine;
import javax.mvc.engine.ViewEngineContext;
import javax.mvc.engine.ViewEngineException;
import javax.servlet.http.HttpServletRequest;
/**
*
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/
@ApplicationScoped
@Priority(ViewEngine.PRIORITY_APPLICATION)
public class FreemarkerViewEngine extends ViewEngineBase {
@Inject
@ViewEngineConfig
private Configuration configuration;
@Override
public boolean supports(String view) {
return view.endsWith(".ftl");
}
@Override
public void processView(final ViewEngineContext context)
throws ViewEngineException {
final Charset charset = resolveCharsetAndSetContentType(context);
try (final Writer writer = new OutputStreamWriter(
context.getOutputStream(), charset
)) {
final Template template = configuration.getTemplate(
resolveView(context)
);
final Map<String, Object> model = new HashMap<>(
context.getModels().asMap()
);
model.put("request", context.getRequest(HttpServletRequest.class));
template.process(model, writer);
} catch (TemplateException | IOException e) {
throw new ViewEngineException(e);
}
}
}

View File

@ -53,7 +53,9 @@ class KrazoTemplateLoader implements TemplateLoader {
@Override @Override
public Object findTemplateSource(final String name) throws IOException { public Object findTemplateSource(final String name) throws IOException {
if (name.startsWith("@themes") || name.startsWith("/@themes")) { if (name.startsWith("@themes")
|| name.startsWith("/@themes")
|| name.startsWith("WEB-INF/views/@themes")) {
return null; return null;
} else { } else {
// Freemarker drops "/" // Freemarker drops "/"

View File

@ -28,12 +28,11 @@ import org.eclipse.krazo.engine.ViewEngineConfig;
import org.eclipse.krazo.ext.freemarker.DefaultConfigurationProducer; import org.eclipse.krazo.ext.freemarker.DefaultConfigurationProducer;
import org.libreccm.theming.Themes; import org.libreccm.theming.Themes;
import javax.enterprise.context.ApplicationScoped; import javax.enterprise.inject.Produces;
import javax.enterprise.inject.Alternative;
import javax.enterprise.inject.Specializes; import javax.enterprise.inject.Specializes;
import javax.inject.Inject; import javax.inject.Inject;
import javax.servlet.ServletContext; import javax.servlet.ServletContext;
import javax.ws.rs.Produces;
/** /**
* Extends the default configuration for Freemarker of Eclipse Krazo to * Extends the default configuration for Freemarker of Eclipse Krazo to
@ -41,9 +40,10 @@ import javax.ws.rs.Produces;
* *
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
@ApplicationScoped //@ApplicationScoped
@Alternative //@Alternative
@Specializes //@Specializes
//@Priority(3000)
public class MvcFreemarkerConfigurationProducer public class MvcFreemarkerConfigurationProducer
extends DefaultConfigurationProducer { extends DefaultConfigurationProducer {
@ -55,7 +55,7 @@ public class MvcFreemarkerConfigurationProducer
@Produces @Produces
@ViewEngineConfig @ViewEngineConfig
@Alternative // @Alternative
@Specializes @Specializes
@Override @Override
public Configuration getConfiguration() { public Configuration getConfiguration() {

View File

@ -66,7 +66,9 @@ class ThemesTemplateLoader implements TemplateLoader {
*/ */
@Override @Override
public Object findTemplateSource(final String path) throws IOException { public Object findTemplateSource(final String path) throws IOException {
if (path.startsWith("@themes") || path.startsWith("/@themes")) { if (path.startsWith("@themes")
|| path.startsWith("/@themes")
|| path.startsWith("WEB-INF/views/@themes")) {
final String[] tokens; final String[] tokens;
if (path.startsWith("/")) { if (path.startsWith("/")) {
tokens = path.substring(1).split("/"); tokens = path.substring(1).split("/");

View File

@ -5,9 +5,10 @@
http://xmlns.jcp.org/xml/ns/javaee/beans_1_1.xsd" http://xmlns.jcp.org/xml/ns/javaee/beans_1_1.xsd"
bean-discovery-mode="all"> bean-discovery-mode="all">
<alternatives> <!-- <alternatives>
<class>org.libreccm.mvc.freemarker.MvcFreemarkerConfigurationProducer</class> <class>org.libreccm.mvc.freemarker.MvcFreemarkerConfigurationProducer</class>
</alternatives> <class>org.eclipse.krazo.ext.freemarker.DefaultConfigurationProducer</class>
</alternatives>-->
<interceptors> <interceptors>
<class>org.libreccm.security.AuthorizationInterceptor</class> <class>org.libreccm.security.AuthorizationInterceptor</class>