jBPM + SEAM en 07 pasos (Un simple tutorial para ver la integracion del JBpm en SEAM)

Como mucho de ustedes saben, SEAM es un framework que integra Java EE standards para que trabajen de una forma integrada y armoniosa. Dentro del nucleo de SEAM se encuentran el Enterprise JavaBeans 3 (EJB3), el Java Server Faces (JSF) y una de las mas importantes integraciones (la cual es la razon de este pequeño articulo) es la integracion del JBOSS jBPM. Empezando este pequeño tutorial, primeramente se pasa a explicar la instalación del Eclipse (Un IDE que solo lo utilizo para mis desarrollos relacionados al jBPM, pues no me agrada mucho) con los plugins necesarios para el desarrollo en SEAM 01. Instalacion del IDE – Primero es necesario descargar el IDE (eclipse-jee-europa-winter-win32.zip) y el paquete JBossTools-2.1.1.GA-ALL-win32.zip – Descomprime el Eclipse y copia el contenido del JBossTools en el IDE descompreso, es decir:


Eclipse-small 


Figura 01. Copiado del JBoss-Tools al Eclipse


– Finalmente desde el command pad teclea en la carpeta donde descomprimiste el IDE: >eclipese -clean   – Listo, ya tienes el IDE funcionando 02. Desarrollando el proyecto SEAM


– Primero crea un nuevo proyecto SEAM 



Newseam-small


Figura 02. Desarrollo de un proyecto SEAM


– Setea el “Target Runtime” y el “Target Server” en funcion del lugar en el que descomprimiste tu JBoss AS y en configuraciones apunta a SEAM 2.0


 Newseam-small1


Figura 03. Seteo del JBoss AS


– Haz click en “Next” hasta llegar a la ventana de “Seam Facet” en donde etableces el tipo de DB con la cual a de funcionar tu proyecto. Como solo estamos probando como funciona SEAM dejalo con la DB HSQL e instala su driver (que te lo tienes que descargar) – Tambien es necesario que descargues “jboss-seam-2.0.2.SP1”, lo descomprimas y establece su ubicacion  en “Seam Runtime” como se parecia en la figura.


 Newseam-small2


Figura 04. Seteo del jboss-seam y la Base de Datos


– Ahora ya tienes el proyecto listo para ser utilizado


 Newseam-small3


Figura 05. Estructura del nuevo proyecto 03. Creacion del flujo jBPM


– En la carpeta “resources” crea un jBPM “Process Definition”


 Newseam-small4


Figura 06. Creacion de un nuevo flujo jbpm


 


Newseam-small5


   Figura 07. Flujo jbpm


– Crea tu flujo


 Newseam-small6


 Figura 08. Ubicacion del flujo jbpm


Como pueden apreciar, el mio se llama “Tareas” – Copia y luego pega “processdefinition.xml” a la carpeta “src/model”


 Newseam-small7


Figura 09. Traslado del archivo “processdefinition.xml”  


 


04. Configuracion del archivo “components.xml”


– Ubicacion 


Newseam-small8


Figura 10. Ubicacion del archivo “components.xml”


 – Edicion: Descomenta esta seccion del codigo


 Newseam-small9


Figura 11. Edicion del archivo “components.xml”


– Adiciona el nombre del archivo jpdl de tu flujo, en este caso “processdefinition.xml” 


Newseam-small10 


Figura 12. Agregacion de “processdefinition.xml” en “components.xml” 05. Creacion de los archivos “hibernate.cfg.xml “ y “jbpm.cfg.xml”


– La forma mas simple es copiar y pegar ambos archivos de uno de los ejemplos que vienen en “jboss-seam-2.0.2.SP1”. El mas completo es el “dvdStore”. – Una vez ubicados ambos archivos, procede a editar el “hibernate.cfg.xml” de la siguiente forma: Primero escribe el nombre de tu proyecto 


 Newseam-small11


Figura 13. Edicion del archivo “hibernate.cfg.xml”


Escribe el valor del Datasource en funcion del nombre de tu proyecto, asi si tu proyecto se llama Test, el valor de tu DS sera: java:/TestDatasource 


Newseam-small12 


Figura 14. Edicion del “connection.datasource”


 – El archivo “jbpm.cfg.xml” dejalo sin modificiaciones. Deberia presentar la siguiente extructura: 


Newseam-small13 


Figura 15. El archivo “jbpm.cfg.xml” 06. Desarrollo de Beans  y paginas XHTML


– Login: El codigo del login es:


  Newseam-small14


Figura 16. Codigo del bean Login.class


Como se puede apreciar es muy simple y la unica funcion que tiene es setear el actorId en jBPM mediante la clase Actor del SEAM. Una vez invocada la accion “setLog()” la pagina que sera desplegada ha de ser: “TaskPage.xml” 


Newseam-small15 


Figura 17. Vista de login.xhtml  


– TaskPage:


Esta pagina tiene la funcion de desplegar todas las tareas del actor que se haya logeado en la pagina “login” 


Newseam-small16 


Figura 18. Vista de TaskPage.xhtml 


El bean correspondiente a esta pagina es: 


Newseam-small17 


Figura 19. Codigo del bean TaskRouter.class


Este codigo es muy simple tambien, y las acciones utilizadas iniciaran cada uno de los nodos de tu flujo. 


Newseam-small18 


Figura 20. Vista de la accion “Aceptar Importancia”


– Inicio del flujo


 Newseam-small22


Figura 21. Vista de la accion “Esperar respuesta” de “inicio.xhtml”   


Newseam-small23 


Figura 22. Codigo del bean Inicio.class


El inicio del flujo es invocado cuando el metodo create() es instanciado. Como se puede apreciar esto es posible gracias a la utilizacion de la anotacion @CreateProcess cuyo argumento es el nombre del flujo anteriormente desarrollado. – ConfirmDate y ConfirmTask Las dos paginas y codigos son similares asi que solo explicare uno de ellos. – ConfrimDate 


Figura 23. Vista de la accion “Confirmar Fecha” en “confirmDate.xhtml” 


Newseam-small20 


Figura 24. Codigo del bean ConfirmDate.class


Como se puede apreciar en las anteriores figuras, aca no se presenta nada novedoso, con la exepcion de las anotaciones de biyeccion @In y @Out, que cumplen la funcion de introducir variables en el jBPM o extraerlas del mismo. La unica accion que utilizamos aca es la finalizacion del nodo “Fecha” mediante el metodo “endDate()” Como se habran dado cuenta, siempre que iniciamos una tarea en un nodo utilizamos la anotacion @StartTak y cuando la queremos finalizar utilizamos @EndTask, esto es muy importante, pues si falta alguna de ellas el flujo no funciona. – Resultado Finalmente tenemos las pagina que es desplegado cuando estamos en el ultimo nodo de nuestro flujo jBPM, la cual simplemente desplegara toda la informacion apuntada en los anteriores nodos 


Figura 25. Vista de la accion “Aceptar!” en “resultado.xhtml”  


El bean asociado a esta pagina es Resultado.class


Newseam-small25


 Figura 26. Codigo del bean Resultado.class


Como se puede apreciar, este codigo lo unico que hace es culminar la terea y finalizar el nodo. 07. Probar el proyecto Una vez concluido todas las paginas, configuraciones y beans, inicia el servidor JBoss desde el Eclipse y notaras que tu proyecto ya se encuentra deployado en el mismo 


Newseam-small26 


Figura 27. El proyecto SEAM en el servidor JBoss


Despues de haber iniciado el servidor, con un browser entra a la siguiente direccion: http://127.0.0.1:8080/Test01 y listo, se tiene que desplegar la pagina “home.seam” mediante la cual puedes dirigirte a la pagina de “login.seam” para empezar el flujo Para un mayor entendimiento de lo explicado anteriormente, les dejo el codigo del proyecto desarrollado en su totalidad: NUEVO LINK!!!


Espero que les sea de utlidad  





  • Digg
  • Del.icio.us
  • StumbleUpon
  • Reddit
  • Twitter
  • RSS

0 Response to "jBPM + SEAM en 07 pasos (Un simple tutorial para ver la integracion del JBpm en SEAM)"

Publicar un comentario