Archetype Maven AngularJS para Large Application

angularjslogoA

olá Pessoal,

Mais um archetype para projetos AngularJS com Java, que criamos aqui na ITS com base em uma necessidade de um novo projeto. A seguir explico a necessidade e quando você pode usá-lo em seus projetos.

lets go…
archetype-webapps-module-angularjs-webdev

No GitHub xxx do projeto veja como instalar e os frameworks que acompanham o archetype.

Por que e quando usar?

Aqui na ITSLabs surgiu um novo projeto bem diferente do que já tinhamos passado com AngularJS + Java. Precisamos ter:

– AngularJS com Java;
– Ter o yeoman;
O problema

Vamos começar pelo problema, tudo começa quando queremos usar o Yeoman em projetos JEE e queremos fazer o deploy do nosso front-end minificado e tirando o proveito de rodar um grunt build. Mas, nem tudo é tão simples assim, como sabemos o mundo JEE tem sua estrutura (webapps/) e o Yeoman gera uma uma estrutura onde tudo fica dentro de app/ .

Se vc tem webapp/app e quando fazer um grunt build o que acontece? Simplesmente seu arquivo para deploy do front vai ficar no mesmo lugar que está seu código fonte que será algo assim app/dist. Mas, para aplicação JEE pouco importa isso e sim o que está dentro de webapp apenas. Uma solução e como já mostrei exemplos aqui no blog com o Yeoman, é não fazer o grunt build e acaba não obtendo a vantagem dos recursos de minificação, mas consegue ter AngularJS + Java + Yeoman.Porém, em projeto bem pequenos isso pode ser um problema, mas se você está construindo uma aplicação grande, pode ser tornar um problema de produtividade, além de não desfrutar de todas as vantagens que temos hoje no mundo JS tais como grunt, bower etc.
Como resolver?

Pensamos em várias soluções, e a que nos atendeu foi a seguir:
Criamos o projeto em modulos:

– xx-parent: o modulo principal.

– xx-core: o modulo para o back-end. É aqui que vai entrar as APIs, framework para todo o código do back-end

– xx-web: o modulo do front-end. Aqui não teremos código AngularJS para desenvolvimento e sim o deploy e os Controllers.

– xx-webdev: esse sim, é o modulo que terá o código de desenvolvimento do front-end. É aqui que vamos ter os css, html, javascript, controllers do angular etc.
Mas, como funciona?

É bem simples, vc pode ter uma equipe de back-end trabalhando somente no modulo xx-core. E outra equipe trabalhando no xx-webdev. O modulo xx-web é usado para criação do Controller que no archetype vem com Sprint + Jersey (vc pode alterar).

Durante o desenvolvimento sua equipe xxx-webdev não precisa subir uma aplicação JEE para testar, basta apenas roda via console grunt server e automaticamente aplicação vai subir 127.0.0.1:9000 e com liveload hablitado. Ou seja, alterou um arquivo em webdev, o browser é reloaded automaticamente.

Para sua equipe de back-end, eles podem trabalhar tranquilamente nos modulos xxx-core e xxx-web e quando precisar subir aplicação pode ir no modulo parent e rodar:

mvn tomcat:run

E aplicação vai subir normalmente em:

http://localhost:8080/suapp

Na Prática

Vamos rodar os comandos Yeoman em webdev tais como :

yo angular:controller

yo angular:factory

 

Entre outros: https://github.com/yeoman/generator-angular
Fazendo Deploy

Para fazer um deploy é simples, quando o código do front-end estier pronto para ser deployed basta executar:

grunt build --force

E aqui vem toda a vantagem, o código será minificado e copiado para o projeto xxx-web/webapp. Precisamos usar o –force pq os arquivos estão sendo copiados para uma outra pasta.

Agora que o código foi copiado para xx-web, podemos subir aplicação. Se vc ainda não fez nenhum deploy vai precisar rodar assim:

mvn clean install

mvn tomcat:run

Agora temos todas as alterações do front-end desenvolvida em webdev na versão final da aplicação.

Observe que com isso não mudamos o mundo de quem trabalha com front-end.Para esses engenheiros tudo continua igual, executar o grunt, bowser, unit test etc. E quando eles terminarem o trabalho deles, apenas precisa fazer um grunt build mandando as mudanças que o time do back-end vai pegar automaticamente.

Vantagens

– mantivemos os beneficios que o Yeoman oferece;

– separamos em modulo e permitindo menos dependências no dia a dia, sendo que cada desenvolvedor pode trabalhar independente e a integração ao termino do trabalho não é impactante;

– Podemos desfrutar das técnicas de minificação, unit test etc;

– deploy especifico;
Outro ponto importante que criamos no archetype é o suporte a parte administrativa. Se você precisar ter suapp/admin sem usar as rotas do angularJS, o archetype já vem com essa configuração no arquivo indexadmin.html que usa um Servlet de redirecionamento. Assim quando o usuário digita suapp/admin vc pode redicionar para uma rota do angularJS.

Usando o archetype

Na página do archetype no github vc tem os passos para instalação. A seguir veja como criar um projeto usando o archetype:

1.Crie um novo projeto maven;

archetypewebdev

2. Agora vamos criar o projeto

archetypewebdevproject

3. E o resultado será

archetypewebdevprojectdone

4. Olhando o projeto principal podemos ver os filhos:

archetypewebdevparent

5. Agora precisamos importar o webdev, vá em File ==> Import e ecolha Maven Project e seguida vá onde está o projeto que acabamos de criar:

archetypewebdevimport

Pronto, temos o esqueleto do projeto para começar a programar.
Conclusão

Espero que tenham gostado do archetype.Se você passou por esse cenário e teve uma solução melhor, não deixe de comentar e compartilhar.

abracos, see ya !!

Série NodeJS: Resolvendo problema com connect 3.0 e Express

Olá Pessoal,

Recentemente passei por um problema com NodeJS usando o Express me deparei com o problema na hora de declarar session, cookieParser, json e urlenconded. Vamos ver como resolver rapidamente.

lets go…

Antes

Quando session, cookieParser, json e urlenconded o modulo estava dentro do express, era assim que definiamos:

app.use(cookieParser());

app.use(session);

app.use(express.json());

app.use(express.urlencoded());

Agora

Precisamos instalar cada modulo separado usando npm install <nome do modulo>. Por exemplo:

npm install express-session

Na página connect há uma relação do passado e presente:

https://github.com/senchalabs/connect#middleware

E para poder usar podemos ver nas respectivas paginas:

Session: https://github.com/expressjs/session

bodyParser: https://github.com/expressjs/body-parser

Um detalhe importante que o bodyParser, ele já tem o json e urlenconded

No código JS vai ficar assim:

 

var express = require('express'), 
cookieParser = require('cookie-parser'),
session = require('express-session'),
bodyParser = require('body-parser'),
load = require('express-load'),
app = express();

app.set('views',__dirname + '/views');

app.set('view engine', 'ejs');
app.use(cookieParser());
app.use(session({ secret: 'camilo lopes', key: 'sid', cookie: { secure: true }}));
app.use(bodyParser());

Pronto problema resolvido. Espero que tenham gostado, vou ficando por aqui.

abracos, see ya !!

Série NodeJS: Instalando o framework Express

olá Pessoal,

Mais um post da série NodeJS. E hoje vamos ver como instalar e criar um projeto com o framework Express.

Lets go..

No exemplo a seguir vou mostrar a instalação do express. O terminal é o git bash.
Requisito:
– NodeJS instalado

Passo 1

digite no terminal npm install -g express-generator

Aguarde a instalação

Passo 2

Feche o terminal

Passo 3

Abre um novo terminal e digite:

express -h

expresshelp

Pronto express instalado.

Para gerar um projeto é bem simples:

express meuprojeto --ejs

 

E o resultado é que o express cria um diretorio com o nome do projeto e monta a estrutura.

Se for programador Java o express seria uma algo parecido como o Maven para criação de projeto Java/JEE.

abracos, vou ficando por aqui.

see ya!!!