Si quieres suscribirte al feed RSS del blog, este es el canal por defecto: http://www.nohaycuchara.com/feed/
Worst viewed with Internet Explorer

Tag "Ruby On Rails":

DetectiveEn el tiempo que llevo trabajando en este sector he conocido muchos tipos de clientes. Desde los más normales e incluso comprensivos, hasta el que se cree que tienes un botón en el teclado que pone “hacer web”, el que te pide colores “frescos pero serios” o el clásico “no sé qué ha pasado, yo no he tocado nada”. Este último será el que reciba hoy nuestra atención.

Prueba a hacer un CMS con opciones críticas, de esas que sirven para borrar algo importante o modificar un campo que utilizan muchos servicios relacionados. Pon un texto informativo al lado en rojo chillón y una confirmación con JS seguida de otra de lado del servidor. Da igual. Al final, algo se romperá y un agujero negro engullirá los pocos indicios que podían ayudarte a deshacer el entuerto.

Cuando la información es tan sensible que perderla significa perder dinero e incluso puestos de trabajo, saber qué ha pasado es fundamental. Por ello, y a falta de un buen sistema de backup, conviene dejar constancia en el log de todo lo ocurrido.

Para conseguirlo, y ya que mi framework de trabajo es RoR, he preparado un initializer que cumple con esto que os comento. Haciendo uso de varios callbacks, informa de los cambios que ha sufrido un objeto o de los atributos que tenía antes de ser borrado. Todo ello suponiendo que el modelo herede de AR e indicando la fecha y hora del suceso.

Como no son muchas líneas, lo pego directamente. Espero que os sea de utilidad :) : Leer más…

CucumberVa, os dejo unos segundos para que os riáis a gusto… ¿ya? No, ¿que si me instalo el pepino dónde? xD :D
En serio, dejémonos de coñas (ahora viene el contenido de verdad):

Algunas -acertadísimas- decisiones estratégicas del departamento en el que curro me han llevado a dar un paso más en mis desarrollos con Rails: empezar con el BDD. Para ello, me he puesto manos a la obra con Cucumber, mejorando la experiencia al combinarlo con Mundo Pepino. Pero claro, no todo iba a ser de color de rosa, y es que es imposible instalar la gema si trabajamos bajo una distro basada en Debian (como Ubuntu, el cual es mi caso).

La solución a esto es hacernos con un par de paquetes de los que depende, así que ejecutamos el siguiente comando como superusuario:

  1. apt-get install libxslt1-dev libxml2-dev

Y ya está, con esta tontería nos acabamos de librar del error que escupe justo después de “Building native extensions“.

Se da el caso en que a veces, cuando utilizamos Paperclip, necesitamos que el path de un mismo adjunto sea diferente según su origen. Esto viene bien para guardar su información relacionada en el mismo campo (MIME type, tamaño y nombre), pero flexibilizando al máximo su ubicación. Para ello, esta popular gema de Rails pone a nuestra disposición una característica muy útil: las interpolaciones.

Con ellas podemos mandar un parámetro extra (mediante un campo oculto, por ejemplo) al modelo para setear cualquier dato que necesitemos utilizar después.

PaperlipsPrimero, creamos un “initializer” con el siguiente contenido:

  1. Paperclip::Interpolations[:folder] = proc do |attachment,style|
  2.   attachment.instance.folder
  3. end

De esta manera estamos habilitando el uso de la palabra reservada “:folder” en la instrucción “has_attached_file“, así:

  1. has_attached_file :att, :path => ":folder/:id.:extension"

Hace unos meses tenía entre manos una aplicación que consumía Web Services de una API que servía la información en varios formatos (XML, YAML, texto plano y PHP serializado -entre otros-). Para ello se ideó un proceso que con el tiempo se vio que era bastante chapucero, pues se basaba en varias peticiones HTTP y la escritura de su resultado en archivos temporales. Debido a ello, en ocasiones el rendimiento caía en picado, cosa que pasaba hasta que descubrí la forma correcta de manejar este flujo de datos:

Web Services

  1. def get_data(data_url)
  2.   begin
  3.     url = URI.parse(data_url)
  4.     res = Net::HTTP.get_response(url)
  5.     YAML.load(res.body)
  6.   rescue Exception => e
  7.     Rails.logger.error "ERROR: #{e}"
  8.     false
  9.   end
  10. end

Nueve sencillas líneas de código es lo único que necesitamos para lograr este objetivo. Primero, lo encapsulamos todo en un bloque que pueda capturar una posible excepción (“begin [...] rescue“). En la primera parte del mismo obtenemos el contenido y lo parseamos con la herramienta correspondiente al formato de salida que elijamos (YAML en este caso). En la segunda, guardamos en el log el nombre del problema ocurrido y devolvemos “false“.

Phusion PassengerParece ser que una de las últimas versiones de Passenger (“mod_rails” para los amigos), la 2.2.4, tiene un bug bastante conocido pero sin solución aparente: la carpeta temporal se crea sin permisos de escritura.
Como en todos los lenguajes de servidor, a la hora de subir un archivo se copia el mismo a un directorio donde permanece hasta que la transferencia ha llegado al 100%; pero en este caso es antes cuando sucede el error, ya que dicha transferencia no llega ni a comenzar.

Como hemos dicho antes, se trata de un tema de permisos. Podríamos pensar en dárselos sin más, pero esto sería sólo una solución temporal, pues este path se renueva cada vez que reiniciamos el server. Para arreglar esto de forma definitiva, deberemos abrir el archivo “Utils.cpp” y buscar la siguiente línea:

  1. makeDirTree(tmpDir + "/webserver_private", "u=wxs,g=,o=", workerUid, workerGid);

Una vez la hayamos encontrado, la sustituimos por esta y reiniciamos el proceso:

  1. makeDirTree(tmpDir + "/webserver_private", "u=wxs,g=wx,o=wx", workerUid, workerGid);

Fuente: Fermín, mi compañero de Jet. :D Yo estaba a su lado, pero en realidad el cerebrito de todo esto es él, ¡gracias tío! ;)

PostgreSQLRoR tiene muy buena integración con todos los tipos de BBDD existentes, aunque a veces su compatibilidad con algunas características deja mucho que desear. Este es el caso de los “schemas” de PostgreSQL, que para ser usados en la sentencia “set_table_name” de un modelo necesitan que pongamos el siguiente código en el fichero “environment.rb“:

  1. ActiveRecord::ConnectionAdapters::PostgreSQLAdapter.class_eval do
  2.   def quote_table_name(name)
  3.     name
  4.   end
  5. end

RubyGemsEste bonito mensaje nos aparecerá si acabamos de instalar Ruby y al intentar meter Rails nos damos cuenta de que necesitamos actualizar nuestro ya anticuado RubyGems (< 0.8.5, 1.1 o 1.2). A pesar de ser lo contrario, dichas versiones se empeñan en pensar que son las más modernas, lo que nos obligará a sacarlas como sea del sistema. Esto lo podemos hacer manualmente o ejecutando estos dos sencillos comandos:

  • gem install rubygems-update
  • update_rubygems

Ruby 1.9Me he pasado toda la puta mañana intentando probar el “nuevo” Ruby 1.9.1 y el resultado ha sido nefasto. Al ir a la página oficial me he encontrado con que la única versión estable es la de Linux, por lo que me he tenido que conformar con un “Preview binary” de mierda (desgraciadamente trabajo sobre Windows).

Al principio pensaba que con eso bastaría, que la primera release no-windoze llevaba mucho tiempo en circulación y les habría dado tiempo a madurarla lo suficiente… Pero no, me equivocaba. Si dicen que no es la definitiva y que no se recomienda para entornos de producción, por algo es.
Si queremos meterle Rails, el primer escollo que debemos salvar los usuarios del SO de M$ es un error con varias DLLs que faltan, para lo cual tenemos que copiar el contenido del siguiente archivo en la carpeta “\ruby\bin“:

Ruby 1.9.1 Missing DLLs (RAR – 1,52MB) -fuente-.

Desconozco cual es el motivo que les ha llevado a los desarrolladores a prescindir de ellas, si alguien me lo dijese se lo agradecería. ;)

Una vez hecho esto y después de leer el Changelog, podemos ver que la lista de cambios es enorme y bastante significativa. La mayoría de ellos contribuyen a mejorar el lenguaje (haciendo hincapié en la rapidez del mismo), por lo que la migración no puede ser más que positiva. No obstante, hay un gran punto que me ha llevado a volver a la 1.8.6: la incompatibilidad de gemas.
Si tenéis paquetes críticos que desconocéis si siguen estando soportados, os recomiendo la siguiente web: Is It Ruby 1.9?. En ella cuentan con una gran BBDD llena de experiencias de usuarios en este aspecto. ;)

El Mostro de las cookiesSi a pesar de trabajar con un framework como RoR te empeñas en salirte de las convenciones prefijadas, ya sea por gusto, desconocimiento o circunstancias del proyecto, eres de los míos. Mi caso se acerca más al último punto (con un pequeño toque del segundo :P ), por lo que he tenido algunos problemas derivados de esta situación.

Llegó un punto en el que tuve que almacenar una gran cantidad de texto en “flash“. Todos éramos felices, el Sol salía cada mañana y los pajarillos canturreaban… hasta que dicha información superó los 4 Kb ≈bad≈ . No había caído en que se estaba haciendo uso de las cookies para almacenar el ID de sesión, por lo que a veces aparecía una bonita excepción con el nombre que titula este post.

Pero Rails siempre tiene una alternativa, y esta vez consistía en guardarlo todo directamente en la BBDD, mejorando de rebote la seguridad del sistema (no así su rendimiento, aunque la diferencia es mínima). Para ello, sólo tenemos que seguir los siguientes pasos:

  • Descomentar el “protect_from_forgery :secret” en el archivo “controllers/application.rb“.
  • Descomentar también la línea que tiene lo siguiente en el “environment“: “config.action_controller.session_store = :active_record_store“.
  • Ejecutar estas dos tareas “rake”: “db:sessions:create” (que nos creará el archivo con la estructura de la tabla) y “rake db:migrate” (que ejecutará la migración de acuerdo al paso anterior).

Si todo ha ido bien, en el próximo reinicio del servidor deberíamos ver el tinglado este funcionando. :)

HTTPLlevo sin escribir dos meses justos, lo sé, y lo peor no es eso, sino las pocas ganas que tengo de solucionarlo…

La verdad es que está siendo una de las etapas de mi vida con más ajetreo que recuerdo, y no es que esté haciendo muchas cosas, sino que las pocas que hago absorben todo mi tiempo. Por todo esto y la vaguería que me caracteriza para según qué asuntos, he acabado con una pedazo de lista de links sobre temas que quería tocar en el blog, pero como al final veo que me va a ser imposible abordarlos todos sin que caduquen, he preferido hacer una breve reseña de cada uno en este post.

No os guiéis por el orden, pues los soltaré según me vengan, de la misma manera que me los encontré por Internet.

Y cuidado… que vienen curvas. :D Leer más…

Página 1 de 212