Páginas

domingo, 1 de janeiro de 2012

Um tutorial utilizando Liferay e Struts

O Liferay é um gerenciador de portais que se beneficia da tecnologia Java. No Liferay, as aplicações são divididas em Portlets. O conceitos e funcionalidades dos Portlets são definidas nas JSR 168 e JSR 286.

Também, nesse gerenciador de portais, utiliza-se o conceito de aplicações dritribuidas em plugins. Como vamos ver logo mais, as aplicações desenvolvidas não ficam atreladas diretamente ao Liferay, elas são carregadas separadamente como se fossem aplicações web independentes. Mas o Liferay consegue executar as funções das outras aplicações como plugins. Assim, pode-se dividir as aplicações por funcionalidade, cada uma em um WAR diferente e combina-las de forma diferente. No liferay existem plugins para Temas, Struts, Spring, Tapestry, entre vários outros. Na verdade estes plugins já estão prontos, podemos apenas alterar a lógica a carrega-los no Liferay. Mas podemos criar nosso próprios plugins.

Para este exemplo vamos utilizar o Liferay 5.1.2, para tanto vamos baixar o servidor tomcat com o liferay já configurado. Está disponível no endereço abaixo:

Tomcat with Liferay

ou no link abaixo na sessão download procure por Bundled with tomcat 5.5:

http://www.liferay.com

Também vamos precisar da aplicação de exemplo do Struts que está disponível no link abaixo:

Download Projeto Struts Liferay

ou através do site www.liferay.com na área download/communit plugins procure por Sample Struts.

Depois de baixar o plugin para Struts, descompacte. Nesse plugin utiliza-se do Struts 1.3.9. Ao verificar a estrutura do arquivo descompactado temos a seguinte:

captura_de_tela

Vamos analisar alguns dos descritores que estão contidos na pasta WEB-INF:

struts-confi.xml:

É arquivo onde estarão disponíveis as configurações principais do Struts. Tais como mapeamentos para as Actions, mapeamentos para as ActionForms, plugins para Strus, etc.

tiles-defs.xml:

Este arquivo de configuração define alguns templates utilizando-se o framework Tiles, o qual pode ser integrado com Struts através de um plugin. Será interessante utilizar esta funcionalidade para não ficar repetindo as mesmas declarações nos JSP's que iremos criar.

portlet.xml:

Arquivo onde vamos declarar os nossos portlets. Nesse arquivo vão informações como nome do portlet, qual a página principal, pagina de ajuda, etc. São as configurações iniciais dos portlets.

liferay-display:

Este descritor define uma categoria, ou sub-categoria, onde os portlets da aplicação estarão disponíveis para carga dentro do Liferay.

Vamos então criar um portlet. Primeiro vamos criar um portlet simples, sem a utilização de uma classe Action. Não significa que não vamos utilizar o arquivo de configuração do Struts ou do Tiles neste exemplo.

Vamos começar criando nosso jsp. Segue abaixo o nosso JSP:

Hello World!

Este JSP vai se chamar sample.jsp e ficará armazenado dentro do diretório /html/sample/samplejspportlet do nosso projeto.

Agora nós vamos criar uma pasta denominada common em /html/sample e vamos copiar o arquivo init.jsp da pasta /html/sample_struts_liferay_portlet para dentro dela. Este arquivo vem com as configurações iniciais de importação de tags e importações mais utilizadas. Depois de copiar o arquivo init.jsp com as configurações iniciais vamos criar a página de template. A seguir será listada página template.jsp contendo as definições do nosso template.

<%@ include file="/html/portlet/sample_struts_portlet/init.jsp" %>

<tiles:useAttribute id="tilesPortletContent" name="portlet_content" classname="java.lang.String" ignore="true" />

<div>

<jsp:include page='<%="/html" + tilesPortletContent %>' flush="true" />

div>

Analisando a página podemos ver que o template inclui a página init.jsp que copiamos. Significa que não vamos precisar fazer as mesmas importações para cada página que criarmos. Podemos observar que existe uma tag tiles. Esta tag está criando uma variável chamada tilesPortletContent (através da propriedade id) dentro do jsp, mas que para o tiles vai ser chamada de portlet_content (definido através da propriedade name). Também nesta tag podemos ver que o tipo da valor que a variável receberá será uma String.

Com a página criada vamos mexer nas configurações dos descritores xml.

TILES-DEFS:

O Tiles, como mencionado anteriormente funciona como um gerenciador de template. Vou mostrar o xml de configuração do nosso template e depois vou explicar os itens contidos nele. Segue o xml:

<definitionname="portlet.sample.template"

path="/html/portlet/sample/common/template.jsp"/>

No xml anterior temos duas propriedades, name e path. A propriedade name representa uma identificador único para nosso template. A propriedade path indica o diretório de nosso template.

Com nosso tempalte pronto, vamos configurar a nossa página sample.jsp. As configurações da página no descritor tiles-defs segue abaixo:

<definition name="portlet.sample.samplejspportlet.sample"

extends="portlet.sample.template">

<put name="portlet_content" value="/portlet/sample/samplejspportlet/sample.jsp" />

definition>

Vemos aqui a utilização do nosso template, pois criamos uma nova definição estendendo do template que criamos anteriormente. O que difere da definição do template é que temos uma tag put. Esta tag vai incluir na variável portlet_content (que está definida em nosso template através da tag tiles:useAttribute) o valor “/portlet/sample/samplejspportlet/sample.jsp”. Se voltar ao nosso template vamos perceber que vamos dar um include na página situada no diretório /html/portlet/sample/samplejspportlet/sample.jsp.

STRUTS-CONFIG:

Com o nosso tempalte criado vamos criar um FowardAction que vai redireconar uma determinada url para o nosso mapeamento definido no Tiles. Segue o mapeamento do nosso action:

<action path="/sample/samplejspportlet/sample"

forward="portlet.sample.samplejspportlet.sample"/>

Aqui podemos ver que criamos um identificador para no FowardAction (atributo path) e uma URL para onde será redirecionada a requisição. No caso, cada requisição direcionada ao Servlet do Strtus com a URL “/sample/samplejspportlet/sample” será redirecionada a URL “portlet.sample.samplejspportlet.sample”. O valor contido no atributo não é realmente uma URL, mas sim uma identificador de qual será a página mapeada no Tiles que irá ser carregada. No caso nossa página sample.jsp.

Uma informação interessante, é que o exemplo baixado do site do Liferay já inclui o plugin de integração Struts/Tiles no arquivo struts-config.xml. Para ver como é a inclusão do plugin é só dar uma olhada no final da arquivo strtus-config.xml.

PORTLET:

Vamos incluir agora a declaração do nosso portlet no descritor portlet.xml. Segue abaixo o mapeamento que vamos incluir:

<portlet>

<portlet-name>sample.samplejspportlet.sampleportlet-name>

<display-name>Struts Testdisplay-name>

<portlet-class>org.apache.portals.bridges.struts.StrutsPortletportlet-class>

<init-param>

<name>ServletContextProvidername>

<value>com.liferay.util.bridges.struts.LiferayServletContextProviderWrappervalue>

init-param>

<init-param>

<name>ViewPagename>

<value>/portlet_action/sample/samplejspportlet/samplevalue>

init-param>

<expiration-cache>0expiration-cache>

<supports>

<mime-type>text/htmlmime-type>

supports>

<portlet-info>

<title>XXXXXXXtitle>

portlet-info>

portlet>

Vamos ver as principais tag de mapeamento.

Define o nome do portlet. Este é o identificador do portlet e deve ser único.

É o nome de exibição do portlet.

Define a classe que irá processar o portlet, seus estados, eventos. Neste caso existe uma classe bridge(ponte) entre o Liferay e o Struts, para fazer com que as requisições do portlet sejam processadas através de actions.

referem-se a propriedades de incialização do portlet. Aqui temos dois parâmetro de incialização. Um faz parte da configuração de bridge com o Struts e a outra representa a página inicial da aplicação.

Determina um tempo em segundos que vai definir quando o conteúdo do portlet vai ter expirado.

Aqui definimos atravé da tag qual o tipo de contéudo que será servido em portlet. Também poderíamos definir que nosso portlet suporta WAP, páginas de configuração e de ajuda. Mas para o exemplo não seria interessante.

define algumas configurações de informação do portlet, no caso definimos o título de nosso portlet.

Agora pegue todas as pastas contidas na raís do projeto (WE-INF e html) e zipe-as em um arquivo. Depois altere a extenção para war.

Com estas etapas prontas vamos carregar nossa aplicação no Liferay. Primeiro deve-se incializar o servidor (na pasta bin/startup.sh ou bin/startup.bat). Vamos abrir um browser e ir para url http://localhost:8080/. Então você verá algo como a imagem a seguir:

captura_de_tela-testliferay-welcome-mozilla-firefox

O login padrão do liferay é “test@liferay.com” e a senha é “test”. Após efetuar o login vamos selecionar no menu onde está dizendo “Welcome Joe Blogs” a opção “Add Application”. Vai aparecer o menu flutuante na janela, abra expanda a categoria “Admin” e adicione o portlet Admin.

No portlet que for carregado clique em “plugins” e depois em “Install more Portlet”. Selecione a opção Upload File e no botão “Arquivo...” selecione o arquivo war onde zipamos nossa aplicação. Depois clique em “install”.

Agora vamos ver nossa aplicação. Clique na página Welcome. Depois vá ao menu novamente e selecione “Add Application”. Então selecione a categoria “Sample” e adicione o portlet “XXXXXXX”.

Nosso portlet estará na página principal dizendo “Hello World!”.

Em outra oportunidade vou criar o parte II do tutorial para incluir uma action. Na verdade, não é muito complexo agora que já criamos um FowardAction dentro Struts, bastaria seguir a mesma linha de raciocínio para criar uma classe action.


Nenhum comentário:

Postar um comentário