Hoy tenemos el placer de informar el lanzamiento de la versión 3 de estos componentes de desarrollo mas elegante, dentro de las vistas estamos hablando de haml que para esta versión tiene como gran mejora la de poder hacer uso de multilineas dentro de la sintaxis por ejemplo:
Bueno como les había mostrado en mi anterior post les mostraría en un futuro post como usar devise, devise es una gema para realizar la auntenticación que tiene similitudes con clearance, como dicen es un full stack authentication system, esto quiere decir que no solo permite la autenticación de los usuarios sino que tambien se encarga de permitir cambiar la contrseña en caso de que se hayan olvidado y además de realizar la activación de la cuenta mediante email. Disponer de toda esta funcionalidad sin tener que programarla y testearla es algo muy positivo ya que casí la mayoría de los proyectos necesitan algún tipo de autenticación, activación y recuperación de cuentas. Comencemos creando un proyecto con rails 3 beta.
Recientemente salio el artículo en este y muchos otros blogs acerca de rails 3 beta, es realmente emocionante poder usar esta versión de este Framework pero un gran problema es no poder usar las gemas que estamos acostumbrados, por ejemplo para hacer tests yo uso rspec, támbien he estado usando mongo_mapper que por suerte funciona con rails 3 aunque no he solucionado el problema de generar scaffolds, bueno aqui les doy algunos tips para que puedan usar rails3 y tal ves no extrañar algunas gemas. Antes de que intenten este tutor asegurense de que actualizar sus gemas.
Después de un largo tiempo de espera, un año y mes desde el anuncio oficial, se ha lanzado la beta publica de la versión de Rails 3, pueden ver el anuncio oficial aqui.
Comentarles que esta versión del framework rails, corre bajo ruby 1.8.7 y preferentemente 1.9.X, ya que la velocidad de ejecución de código es mas alta que en las versiones de ruby 1.8.x.
Para probar las nuevas características de rails 3.0 solo escriban en la consola:
No se ustedes pero manejar multiples versiones de Ruby se vuelve una confusión y algo complejo cuando tienes varias versiones, afortunadamente existe rvm, una excelente gema que permite mantener multiples versiones de Ruby de forma sencilla.
Saludos a todos quisiera invitarlos al primer curso de Ruby on Rails que se realizara en la Universidad Pública de El Alto los días 9, 16, 23 y 30 de Enero de 2010 de 9:00 a 13:00 los días sábados. Más detalles en el afiche
Si estan usando el datepicker de jquery-ui se puede hacer que los campos date_select o datetime_select de rails puedan ser reemplazados con el siguiente javascript que hice. En caso de que esten usando formtastic pueden usar este snipet http://snipt.net/boriscy/formtastic-datetime/,
lo guardan como lib/custom_form_builder.rb
En el config/environment.rb al final escriben include ‘custom_form_builder’
Aumenten al final del archivoconfig/initializers/formtastic.rb Formtastic::SemanticFormHelper.builder = MyCustomFormBuilder
$(document).ready(function() {
// Define the dateFormat for the datepicker
$.datepicker._defaults.dateFormat = 'dd M yy';
/**
* Sets the date for each select with the date selected with datepicker
*/
$('input.ui-date-text').live("change", function() {
var sels = $(this).siblings("select:lt(3)");
var d = $.datepicker.parseDate($.datepicker._defaults.dateFormat, $(this).val() );
$(sels[0]).val(d.getFullYear());
$(sels[1]).val(d.getMonth() + 1);
$(sels[2]).val(d.getDate());
});
/**
* Replaces the date or datetime field with jquey-ui datepicker
*/
$(’.date, .datetime’).each(function(i, el) {
var input = document.createElement(’input’);
$(input).attr({’type’: ‘text’, ‘class’: ‘ui-date-text’});
// Insert the input:text before the first select
$(el).find(”select:first”).before(input);
$(el).find(”select:lt(3)”).hide();
// Set the input with the value of the selects
var values = [];
$(input).siblings(”select:lt(3)”).each(function(i, el) {
var val = $(el).val();
if(val != ”)
values.push(val);
});
if( values.length > 1) {
d = new Date(values[0], parseInt(values[1]) - 1, values[2]);
$(input).val( $.datepicker.formatDate($.datepicker._defaults.dateFormat, d) );
}
$(input).datepicker();
});
});
Aunque hay un problema con el Internet Explorer (solo probe con IE7), cuando uno cambia la fecha sin usar el datepicker sino escribiendola esta no es guardada correctamente, haber si lo resulven y lo testean con varios browsers.
Ultimamente estoy realizando una aplicación que requiere subir archivos Excel, fue un poco difícil encontrar la forma de que pasaran mis tests con Paperclip, pero hay que reconocer que esta gema hace magia con los uploads, el problema que tenía era con los uploads y el content_type, mi modelo realiza la validación del tipo de contenido usando las validaciones que provee paperclip, el modelo luce de esta forma:
Saludos a todos, he estado usando Authlogic y busque una traducción al español pero no la encontre, entonces ahi les va para que se la copien y peguenlo en su archivo “config/ocales/es.yml”
authlogic:
error_messages:
login_blank: "no debe estar en blanco"
login_not_found: "no es válido"
login_invalid: "solo debe ingresar letras, números y -_@ sin espacios"
consecutive_failed_logins_limit_exceeded: "Se sobrepaso el número consecutivo de logins, la cuenta fue desactivada"
email_invalid: "debe ser un email válido."
password_blank: "no debe estar en blanco"
password_invalid: "no es válido"
not_active: "Su cuenta no esta activa"
not_confirmed: "Su cuenta no ha sido confirmada"
not_approved: "Su cuenta no fue aprovada"
no_authentication_details: "Usted no proveio ningún detalle para la autentu¡icación."
models:
user_session: "UsuarioSession (o lo que este usando)"
attributes:
user_session: # "(or whatever name you are using)"
login: "login"
email: "email"
password: "contraseña"
remember_me: "recuerdame"
recuerden mantenre los dos espacios de tabulación debido que debe estar dentro de “es”. Tambien estaba probando y haciendo algunas modificaciones a mi modelo para que authlogic funcione como yo queria entonces hice lo siguiente:
class Usuario < ActiveRecord::Base
acts_as_authentic do |config|
config.login_field = :login
config.merge_validates_format_of_login_field_options(:with => /\A^[a-z-_0-9@]+$\Z/i)
config.merge_validates_length_of_login_field_options(:within => 4..20)
end
end
Lo cual nos permite definir otras validaciones en Authlogic.
Testeo de Authlogic
En caso de que deseen testear su código en Rspec o Cucumber con authlogic solo deben adicionar lo siguiente para Rspec en spec/spec_helper.rb o para Cucumber en features/support/env.rb
require "authlogic/test_case"
include Authlogic::TestCase
Entonces ahora esto permite realizar los test, pero no debemos olvidar crear la sesión en Authlogic de la siguiente forma:
# Agreguen los campos necesarios para su usuario
@usuario = Usuario.create(:login => 'usuario', :password => 'demo123', :password_confirmation => 'demo123')
UsuarioSession.create(@usuario)