move check email params in validator

This commit is contained in:
Tanguy PATTE 2015-08-21 11:37:13 +02:00
parent d557cee249
commit 88b663a514
7 changed files with 81 additions and 50 deletions

View file

@ -17,7 +17,13 @@ class DescriptionController < ApplicationController
def create
@dossier = Dossier.find(params[:dossier_id])
@dossier.update_attributes(create_params)
unless @dossier.update_attributes(create_params)
@dossier = @dossier.decorate
@formulaire = @dossier.formulaire
flash.now.alert = @dossier.errors.full_messages.join('<br />').html_safe
return render 'show'
end
unless params[:cerfa_pdf].nil?
cerfa = @dossier.cerfa
cerfa.content = params[:cerfa_pdf]
@ -31,15 +37,15 @@ class DescriptionController < ApplicationController
end
end
if check_missing_attributes(params) || check_format_email(@dossier.mail_contact).nil?
if check_missing_attributes(params)
redirect_to url_for(controller: :description, action: :error)
else
if params[:back_url] == 'recapitulatif'
@commentaire = Commentaire.create
@commentaire.email = 'Modification détails'
@commentaire.body = 'Les informations détaillées de la demande ont été modifiées. Merci de le prendre en compte.'
@commentaire.dossier = @dossier
@commentaire.save
commentaire = Commentaire.create
commentaire.email = 'Modification détails'
commentaire.body = 'Les informations détaillées de la demande ont été modifiées. Merci de le prendre en compte.'
commentaire.dossier = @dossier
commentaire.save
end
redirect_to url_for(controller: :recapitulatif, action: :show, dossier_id: @dossier.id)
@ -56,9 +62,4 @@ class DescriptionController < ApplicationController
def check_missing_attributes(params)
params[:nom_projet].strip == '' || params[:description].strip == '' || params[:montant_projet].strip == '' || params[:montant_aide_demande].strip == '' || params[:date_previsionnelle].strip == '' || params[:mail_contact].strip == ''
end
# TODO dans un validateur, dans le model
def check_format_email(email)
/\A[\w+\-.]+@[a-z\d\-]+(\.[a-z]+)*\.[a-z]+\z/.match(email)
end
end

View file

@ -12,6 +12,8 @@ class Dossier < ActiveRecord::Base
before_create :build_default_cerfa
validates :mail_contact, format: { with: /\A[\w+\-.]+@[a-z\d\-]+(\.[a-z]+)*\.[a-z]+\z/ }, unless: 'mail_contact.nil?'
def retrieve_piece_jointe_by_type(type)
pieces_jointes.where(type_piece_jointe_id: type).last
end