Archivo de la etiqueta: toba

Consumir Web Service del SIU-Mapuche desde SIU-Toba

Claramente lo primero que tengo que tener, es correctamente instalada la libreria WSF/PHP en el servidor del SIU-Mapuche, y tambien en el servidor en el cual estamos desarrollando la aplicación ya que es fundamental para el manejo de WS en SIU-Toba esta librería.

Generando el entorno (Seguridad)

Los WS service del SIU, por convención TODOS, menos los de prueba (eco y ping) deben funcionar «seguros», esto quiere decir que deben viajar encriptados y firmados (utilizando criptografía asimétrica). Para realizar esto es necesario utilizar dos pares de certificados (unos para el cliente, otros para el servidor).

Robada Tomada desde Wikipedia

Para crear los certificados debemos tener un archivo openssl.ini el cual vamos usar para facilitar el ejemplo y al cual le podemos editar las siguientes partes:

y la parte:

con la información particular de la institución donde trabajan.

Para generar los certificados debemos ejecutar:

Y repetir la operación para generar los certificados para el servidor:

Configuración del servidor (SIU-Mapuche)

Primero que nada, hay que saber que los WS del SIU-Mapuche, tienen un sistema de seguridad por el cual se permite la activación y desactivación de los mismos

El sistema SIU-Mapuche por default trae desactivados todos los WS exepto 2 que son de prueba (echo y ping). Para activar los WS se debe ir a Configuración, una vez que estamos dentro de la operación Configuración se debe ingresar a Servicios Web -> General, ahí tildar los servicios que necesitamos, y guardar los cambios.

Una vez habilitados los WS, debemos configurar los certificados (3 de los 4 que creamos antes).

Debemos subir 3 certificados al servidor donde se encuentra el SIU-Mapuche

  • server.crt (Certificado servidor)
  • server.key (Clave servidor)
  • cliente.crt (Certificado cliente)

Cuando se tengan estros tres archivos subidos al servidor, vamos a Configuración -> Servicios Web -> Seguridad,  y llenamos con las 3 rutas completas a los archivos que acabamos de subir según corresponda y guardamos.

Configuración del cliente (nuestro proyecto en SIU-Toba)

Dentro de nuestro proyecto, debemos crear un nuevo «servicio web accesible», esto lo podemos realizar desde el toba_editor en la pestaña «Datos» -> «Servicios Web Accesibles», aquí hacemos click en el botón agregar.

En el ejemplo que voy a mostrar, vamos a trabajar con los WS de agentes.

Y guardamos los cambios.

Nota: La URL siempre esta formada por el punto de acceso a los servicios web del SIU-Mapuche (http://{ruta_al_siu_mapuhce}/servicios.php) mas el nombre del WS que puede verse en el SIU-Mapuche en «Ayuda» -> «Servicios Web» (ServicioWebAgentes, ServicioWebCargos, ServicioWebPruebas, etc).

Lo próximo que tenemos que hacer es configurar el «certificado del servidor» en la «instancia cliente» (nuestro proyecto). Esto lo podemos hacer con un comando de consola de toba:

Con todo esto, ya deberíamos tener todo configurado y listo para poder trabajar (codear!).

NOTA: Tomo por sentado de que tienen conocimientos de como crear operaciones en SIU-Toba.

Para este ejemplo, creamos una operación la llamamos Legajo y le agregamos un CI, al CI le agregamos un cuadro con 3 columnas (legajo, nombre y apellido) y extendemos el CI.

agregamos el siguiente código:

FIN!

Proximamente voy a subir como hacer para consumir los WS del SIU-Mapuche desde afuera del SIU-Toba.

Pueden bajarse el proyecto demo que realice y poder utilizarlo de ejemplo, solo tienen que cargar el proyecto en un SIU-Toba 2.3.4 y cargarlo con el siguiente comando de toba:

Referencias:

  • http://toba.siu.edu.ar/trac/toba/wiki/Referencia/ServiciosWeb
  • Evento Anual en la UNLP curso de WS SIU-Toba

Instalación de WSF/PHP en Debian Lenny

Antes que nada probé realizarlo en Ubuntu 12.04 sin ningún éxito con el README.INSTALL que esta en el paquete y no funciono, y probé instalarlo en Debian Lenny también con el mismo tutorial sin éxito.

Sobre Ubuntu, compilaba todo perfectamente pero al tratar de probar la librería me tiraba un error que tras googlear no se encontraba solución aparente y acusaban de que era un problema con Ubuntu desde la versión 11.04, en Debian Lenny, fue mucho mas grave, directamente no podía compilarlo. Según pude leer el ./configure no tiene los chequeos suficientes que debe tener.

Como realmente creo que muy pocas veces se valla a instalar sobre Ubuntu, mas que para pruebas, opte por avanzar con la investigación sobre una maquina virtual Debian instalada absolutamente desde 0 con solo el fin de probar la librería.

Y ahora… la magia en castellano!

1- Instalar prerrequisitos desde apt-get

2- Compilar y instalar Apache Axis2/C

NOTA: Como ♪nada es para siempre♪, y no puedo asegurar la disponibilidad del link con el axis2c lo pueden descargar de mi blog ( axis2c-src-1.6.0.tar )… pero por las dudas siempre traten de bajar el de la URL anterior.

3- Bajar y descomprimir los fuentes de  WSF/PHP

EDITADO 11/11/2012: Un comentario interesante, en una instalación que estoy haciendo precisamente ahora, por alguna razón cuando hago el «wget» me dice que me lo prohíbe (Error 403), no se si le agregaron alguna restricción al servidor para que si el cliente es wget no permita descargas. Probé bajarlo con Firefox, y no hubo problemas, solo un comentario, para que nadie enloquezca.

Como tampoco confío cuanto tiempo va a estar publicada esta librería también les dejo mi propia descarga ( FALTA! )

4- Compilar y instalar WSF/PHP

5- Configurar PHP

Agrego el modulo de wsf a los modulos que corren con php.

Configuro para que las librerias de wsf sean accesibles en el include_path de php. Para esto editar el php.ini y agregar una linea que se cambie de:

y se transforme en:

5- Verificar

Crear un archivo phpinfo.php y verificar que «Additional .ini files parsed» contiene «wso2.ini». Chequear que las extensiones «wsf» y «xsl» esta instaladas.
Correr el siguiente test script.

6- Ser feliz!

Sigue leyendo