Introducción a Genie (19ª parte – ¡Hola Julia!)

Publicado el 15 septiembre 2020 por Daniel Rodríguez @analyticslane

Hoy en día se ha vuelto una necesidad poder publicar los resultados de los análisis analíticos o los modelos de aprendizaje automático en la web. Tanto en forma de servicio web como de aplicación. Los usuarios de R cuentan para ellos con Shiny, los de Python cuentan con diferentes frameworks y los de Matlab con las posibilidades de App Designer. En el caso de Julia contamos con Genie para ellos. Genie es un framework para la creación de soluciones web basado en el patrón MVC (Modelo Vista Controlador).

Instalación de Genie

Genie no viene por defecto en Julia, por lo que para poder usarlo es necesario instalarlo. El proceso de instalación es similar al que hemos visto con otros paquetes, es necesario cargar el paquete Pkg y llamar al método add() con 'Genie' como opción.

¡Hola mundo! con Genie

Generalmente una de las primeras cosas que se hacen con un nuevo lenguaje o framework es crear el programa "¡Hola Mundo!". En este caso se puede crear una página con el mensaje simplemente con el siguiente código.

using Genie, Genie.Router

route("/") do
	"¡Hola mundo!"
end

up()

En la primera línea de este ejemplo se importa la librería que necesitamos: Genie y Genie.Route. Posteriormente se llama a la función route() (la cual se encuentra en Genie.Route) para indicar la ruta en la que servirá nuestro mensaje. En este caso la raíz del servidor. A lo que sigue una función en la que se creará el resultado, en este caso una cadena de texto estática con el mensaje "¡Hola mundo!".

Finalmente solamente hay que escribir up() para levantar nuestra primera aplicación web creada con Genie. Ahora solo hay que abrir un navegador y escribir la dirección http://localhost:8000/, apareciendo una página en blanco con el mensaje.

Exportando los resultados en diferentes formatos

En la sección anterior se ha creado una aplicación web que devuelve un mensaje. Pero puede ser que necesitemos devolver los resultados en otro formato, como puede ser JSON. Para esto es necesario cargar las funciones de renderizado. Así se puede crear una serie de servicios con el siguiente código.

using Genie, Genie.Router
using Genie.Renderer, Genie.Renderer.Html, Genie.Renderer.Json

route("/text") do
   respond("¡Hola mundo!", :text)
end

route("/html") do
  html("¡Hola mundo!")
end

route("/json") do
  json("¡Hola mundo!")
end

up(3000, async = false)

En este ejemplo se ha cargado, además de lo visto en la sección anterior: Genie.Renderer, Genie.Renderer.Html y Genie.Renderer.Json. Lo que nos permite generar respuestas, respuestas genéricas, en formato HTML y JSON respectivamente.

El método respond() es un método genérico con el que se puede enviar cualquier tipo de respuesta simple con un tipo MINE. Algunos de los tipos más utilizados son: :text, :xml, :markdown o :javascript.

Por otro lado, como se puede ver en el ejemplo, para responder con una página web o un archivo JSON se puede usar las funciones html() y json() respectivamente.

La función up() admite como parámetro el puerto en el que se publica la aplicación. Por defecto es 8000, pero podemos indicar que esta se publique en el puerto 3000 como es el caso. Además, se le puede indicar al servidor que este se ejecute de forma síncrona o asíncrona. Para que el código siga funcionando después de su ejecución es necesario indicar la opción async = false.

Métodos GET y POST

A la hora de crear la ruta no se ha indicado hasta ahora qué método se usa, un método GET, un método POST o cualquier otro. Para esto se puede utilizar la opción method de la función route(), a la que se le puede pasar el nombre del método. Valor que por defecto es GET. Por ejemplo, para indicar que se use un método POST simplemente se tiene que usar la siguiente ruta.

route("/", method = POST) do
	"Método POST"
end

Obtener los parámetros

Los métodos vistos hasta ahora siempre devuelven el mismo resultado ya que nunca se han pasado parámetros a las funciones. Los parámetros se pueden obtener con el método getpayload() al que se le ha de pasar como primer valor el nombre de parámetro y como segundo el valor. Así para leer la opción nombre de la URL se puede usar

using Genie, Genie.Router, Genie.Requests

route("/hola") do
	name = getpayload(:nombre, "Analytics Lane")
	
	"¡Hola $name!"
end

Lo que devolverá "¡Hola Analytics Lane!" para la URL http://localhost:8000/hola. Mientras que si se pasa una cadena de texto en el parámetro nombre devolverá este, Por ejemplo, para http://localhost:8000/hola?nombre=Daniel devolverá "¡Hola Daniel!"

Obtener el cuerpo

Otra opción es obtener los parámetros del cuerpo del mensaje. Lo que se pude obtener mediante la función postpayload(), la cual función igual que la anterior

using Genie, Genie.Router, Genie.Requests

route("/hola", method = POST) do
	name = postpayload(:nombre, "Analytics Lane")
	
	"¡Hola $name!"
end

Genie, un método para crear aplicaciones con Julia

Hemos visto la base de Genie, un framework que podría dar lugar a una serie como esta. Ya que ofrece múltiples posibilidades para publicar aplicaciones web creadas con Julia. Permitiendo publicar nuestro trabajo de una forma que sea fácilmente accesible.


Publicidad