![JAR search and dependency download from the Maven repository](/logo.png)
org.mentawai.template.ConventionController Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mentawai Show documentation
Show all versions of mentawai Show documentation
A Java full-stack web framework with programmatic configuration instead of XML and Annotations.
/*
* Mentawai Web Framework http://mentawai.lohis.com.br/
* Copyright (C) 2005 Sergio Oliveira Jr. ([email protected])
*
* 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 St, Fifth Floor, Boston, MA 02110-1301 USA
*/
package org.mentawai.template;
import java.io.File;
import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.mentawai.core.ApplicationManager;
/**
* Controller responsavel pelo suporte a convencoes. Trabalha com valores
* defaults, porem pode ser extendido e personalizado.
* Ele funciona assim: suponha que haja uma requisicao modules/news/list.page.
* O easytemplates vai pegar o template base, vai setar os valores para os
* blocos comuns, como "topo", "menu", "rodape", etc. e setara no bloco de nome
* "body" (veja o metodo getPrincipalBlock) o valor modules/news/list.jsp
*
* @author Davi Luan Carneiro
*/
public class ConventionController implements PageController {
public void processPage(Page page, HttpServletRequest request,
HttpServletResponse response, ServletContext application) {
String view = getRoot() + page.getPath() + getExtension();
String viewDir = ApplicationManager.getViewDir();
if (viewDir != null && viewDir.length() > 0 && !view.startsWith(viewDir)) {
if (viewDir.endsWith("/") && view.startsWith("/")) {
viewDir = viewDir.substring(0, viewDir.length() - 1);
} else if (!viewDir.endsWith("/") && !view.startsWith("/")) {
viewDir = viewDir + "/";
}
view = viewDir + view;
}
File file = new File(application.getRealPath("/") + view);
if (!file.exists()) {
try {
request.getRequestDispatcher(view).forward(request, response);
return;
} catch (Exception e) {
throw new TemplateException(e);
}
}
if(view.startsWith("/")) view = view.substring(1);
page.setBlock(getPrincipalBlock(), new Page(view));
}
/**
* Pode ser estendido e redefinido. Por exemplo, se voce quiser que todas as
* paginas fiquem dentro de WEB-INF/views, eh so redefinir este metodo.
*
* @return Diretorio raiz das paginas
*/
public String getRoot() {
return "";
}
/**
* Por default, vale "body". Ou seja, ele vai considerar que este eh o bloco
* principal, o corpo, o conteudo da pagina. Pode ser redefinido.
*
* @return Nome do bloco que contera o corpo da pagina
*/
public String getPrincipalBlock() {
return "body";
}
/**
* Por default retorna .jsp. Este metodo existe para o caso de ser criado suporte
* a Freemarker ou Velocity. Assim, a extensao deveria ser diferente.
*
* @return Extensao da pagina
*/
public String getExtension() {
return ".jsp";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy