I am trying to convert my Rails 2.3.5 app to 2.3.8 and then to Rails 3.0
Currently, I am upgrading to Rails 2.3.8. The default escaping behavior
is causing all kinds of problems.
I have installed the rails_xss plugin from the following url:
And am trying to follow the directions in readme.
I have a form builder which has the following method:
def field_label(field_name, *args)
options = args.extract_options!
options.reverse_merge!(:required => field_required?(field_name))
options[:label_class] = “required” if options[:required]
t_label = options.delete(:label)
t_label = (t_label.nil? ? field_name.to_s.humanize.titleize :
t_label)
if object.errors.invalid? field_name
temp_label = t_label + ": " +
@template.content_tag(:span,
([object.errors.on(field_name)].flatten.first.sub(/^^/, ‘’)), :class =>
‘error_message’)
else
temp_label = t_label
end
label(field_name, temp_label.html_safe, :class =>
options[:label_class])
end
I cannot seem to get the method above not escape the error text when I
intentionally try to submit a required field with an empty value. I get
an output as shown below:
Client Name: can’t be blank
See if the string in the element is not being interpreted? How
can this be done? Is there a method to this madness?
Thanks for your time.
Bharat