wip(validates): prefill and validate_champ_value? on all other missing validation checks
This commit is contained in:
parent
284a10e235
commit
e08aa7d28b
16 changed files with 16 additions and 0 deletions
|
@ -5,6 +5,7 @@ class Champs::BooleanChamp < Champ
|
||||||
before_validation :set_value_to_nil, if: -> { value.blank? }
|
before_validation :set_value_to_nil, if: -> { value.blank? }
|
||||||
before_validation :set_value_to_false, unless: -> { ([nil, TRUE_VALUE, FALSE_VALUE]).include?(value) }
|
before_validation :set_value_to_false, unless: -> { ([nil, TRUE_VALUE, FALSE_VALUE]).include?(value) }
|
||||||
|
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates :value, inclusion: [TRUE_VALUE, FALSE_VALUE],
|
validates :value, inclusion: [TRUE_VALUE, FALSE_VALUE],
|
||||||
allow_nil: true,
|
allow_nil: true,
|
||||||
allow_blank: false,
|
allow_blank: false,
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
class Champs::CnafChamp < Champs::TextChamp
|
class Champs::CnafChamp < Champs::TextChamp
|
||||||
# see https://github.com/betagouv/api-particulier/blob/master/src/presentation/middlewares/cnaf-input-validation.middleware.ts
|
# see https://github.com/betagouv/api-particulier/blob/master/src/presentation/middlewares/cnaf-input-validation.middleware.ts
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates :numero_allocataire, format: { with: /\A\d{1,7}\z/ }, if: -> { code_postal.present? && validate_champ_value? }
|
validates :numero_allocataire, format: { with: /\A\d{1,7}\z/ }, if: -> { code_postal.present? && validate_champ_value? }
|
||||||
validates :code_postal, format: { with: /\A\w{5}\z/ }, if: -> { numero_allocataire.present? && validate_champ_value? }
|
validates :code_postal, format: { with: /\A\w{5}\z/ }, if: -> { numero_allocataire.present? && validate_champ_value? }
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
class Champs::DepartementChamp < Champs::TextChamp
|
class Champs::DepartementChamp < Champs::TextChamp
|
||||||
store_accessor :value_json, :code_region
|
store_accessor :value_json, :code_region
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validate :value_in_departement_names, unless: -> { value.nil? }
|
validate :value_in_departement_names, unless: -> { value.nil? }
|
||||||
validate :external_id_in_departement_codes, unless: -> { external_id.nil? }
|
validate :external_id_in_departement_codes, unless: -> { external_id.nil? }
|
||||||
before_save :store_code_region
|
before_save :store_code_region
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
class Champs::DgfipChamp < Champs::TextChamp
|
class Champs::DgfipChamp < Champs::TextChamp
|
||||||
# see https://github.com/betagouv/api-particulier/blob/master/src/presentation/middlewares/dgfip-input-validation.middleware.ts
|
# see https://github.com/betagouv/api-particulier/blob/master/src/presentation/middlewares/dgfip-input-validation.middleware.ts
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates :numero_fiscal, format: { with: /\A\w{13,14}\z/ }, if: -> { reference_avis.present? && validate_champ_value? }
|
validates :numero_fiscal, format: { with: /\A\w{13,14}\z/ }, if: -> { reference_avis.present? && validate_champ_value? }
|
||||||
validates :reference_avis, format: { with: /\A\w{13,14}\z/ }, if: -> { numero_fiscal.present? && validate_champ_value? }
|
validates :reference_avis, format: { with: /\A\w{13,14}\z/ }, if: -> { numero_fiscal.present? && validate_champ_value? }
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
class Champs::DossierLinkChamp < Champ
|
class Champs::DossierLinkChamp < Champ
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validate :value_integerable, if: -> { value.present? }, on: :prefill
|
validate :value_integerable, if: -> { value.present? }, on: :prefill
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
|
@ -5,6 +5,7 @@ class Champs::DropDownListChamp < Champ
|
||||||
OTHER = '__other__'
|
OTHER = '__other__'
|
||||||
delegate :options_without_empty_value_when_mandatory, to: :type_de_champ
|
delegate :options_without_empty_value_when_mandatory, to: :type_de_champ
|
||||||
|
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validate :value_is_in_options, unless: -> { value.blank? || drop_down_other? }
|
validate :value_is_in_options, unless: -> { value.blank? || drop_down_other? }
|
||||||
|
|
||||||
def render_as_radios?
|
def render_as_radios?
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
class Champs::EmailChamp < Champs::TextChamp
|
class Champs::EmailChamp < Champs::TextChamp
|
||||||
include EmailSanitizableConcern
|
include EmailSanitizableConcern
|
||||||
before_validation -> { sanitize_email(:value) }
|
before_validation -> { sanitize_email(:value) }
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates :value, allow_blank: true, format: { with: StrictEmailValidator::REGEXP }, if: :validate_champ_value?
|
validates :value, allow_blank: true, format: { with: StrictEmailValidator::REGEXP }, if: :validate_champ_value?
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
class Champs::EngagementJuridiqueChamp < Champ
|
class Champs::EngagementJuridiqueChamp < Champ
|
||||||
# cf: https://communaute.chorus-pro.gouv.fr/documentation/creer-un-engagement/#1522314752186-a34f3662-0644b5d1-16c22add-8ea097de-3a0a
|
# cf: https://communaute.chorus-pro.gouv.fr/documentation/creer-un-engagement/#1522314752186-a34f3662-0644b5d1-16c22add-8ea097de-3a0a
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates_with ExpressionReguliereValidator,
|
validates_with ExpressionReguliereValidator,
|
||||||
expression_reguliere: /([A-Z]|[0-9]|\-|\_|\+|\/)+/,
|
expression_reguliere: /([A-Z]|[0-9]|\-|\_|\+|\/)+/,
|
||||||
expression_reguliere_error_message: "Le numéro d'EJ ne peut contenir que des caractères alphanumérique et les caractères spéciaux suivant : “-“ ; “_“ ; “+“ ; “/“",
|
expression_reguliere_error_message: "Le numéro d'EJ ne peut contenir que des caractères alphanumérique et les caractères spéciaux suivant : “-“ ; “_“ ; “+“ ; “/“",
|
||||||
|
|
|
@ -3,6 +3,7 @@ class Champs::EpciChamp < Champs::TextChamp
|
||||||
before_validation :on_departement_change
|
before_validation :on_departement_change
|
||||||
before_validation :on_epci_name_changes
|
before_validation :on_epci_name_changes
|
||||||
|
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validate :code_departement_in_departement_codes, unless: -> { code_departement.nil? }
|
validate :code_departement_in_departement_codes, unless: -> { code_departement.nil? }
|
||||||
validate :external_id_in_departement_epci_codes, unless: -> { code_departement.nil? || external_id.nil? }
|
validate :external_id_in_departement_epci_codes, unless: -> { code_departement.nil? || external_id.nil? }
|
||||||
validate :value_in_departement_epci_names, unless: -> { code_departement.nil? || external_id.nil? || value.nil? }
|
validate :value_in_departement_epci_names, unless: -> { code_departement.nil? || external_id.nil? || value.nil? }
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
class Champs::ExpressionReguliereChamp < Champ
|
class Champs::ExpressionReguliereChamp < Champ
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates_with ExpressionReguliereValidator, if: :validate_champ_value?
|
validates_with ExpressionReguliereValidator, if: :validate_champ_value?
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
class Champs::IbanChamp < Champ
|
class Champs::IbanChamp < Champ
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates_with IbanValidator, if: :validate_champ_value?
|
validates_with IbanValidator, if: :validate_champ_value?
|
||||||
after_validation :format_iban
|
after_validation :format_iban
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
class Champs::MultipleDropDownListChamp < Champ
|
class Champs::MultipleDropDownListChamp < Champ
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validate :values_are_in_options, if: -> { value.present? }
|
validate :values_are_in_options, if: -> { value.present? }
|
||||||
|
|
||||||
def options?
|
def options?
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
class Champs::PieceJustificativeChamp < Champ
|
class Champs::PieceJustificativeChamp < Champ
|
||||||
FILE_MAX_SIZE = 200.megabytes
|
FILE_MAX_SIZE = 200.megabytes
|
||||||
|
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates :piece_justificative_file,
|
validates :piece_justificative_file,
|
||||||
size: { less_than: FILE_MAX_SIZE },
|
size: { less_than: FILE_MAX_SIZE },
|
||||||
if: -> { !type_de_champ.skip_pj_validation }
|
if: -> { !type_de_champ.skip_pj_validation }
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
class Champs::RegionChamp < Champs::TextChamp
|
class Champs::RegionChamp < Champs::TextChamp
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validate :value_in_region_names, unless: -> { value.nil? }
|
validate :value_in_region_names, unless: -> { value.nil? }
|
||||||
validate :external_id_in_region_codes, unless: -> { external_id.nil? }
|
validate :external_id_in_region_codes, unless: -> { external_id.nil? }
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
class Champs::RNAChamp < Champ
|
class Champs::RNAChamp < Champ
|
||||||
include RNAChampAssociationFetchableConcern
|
include RNAChampAssociationFetchableConcern
|
||||||
|
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates :value, allow_blank: true, format: {
|
validates :value, allow_blank: true, format: {
|
||||||
with: /\AW[0-9A-Z]{9}\z/, message: I18n.t(:not_a_rna, scope: 'activerecord.errors.messages')
|
with: /\AW[0-9A-Z]{9}\z/, message: I18n.t(:not_a_rna, scope: 'activerecord.errors.messages')
|
||||||
}, if: :validate_champ_value?
|
}, if: :validate_champ_value?
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
class Champs::TitreIdentiteChamp < Champ
|
class Champs::TitreIdentiteChamp < Champ
|
||||||
FILE_MAX_SIZE = 20.megabytes
|
FILE_MAX_SIZE = 20.megabytes
|
||||||
ACCEPTED_FORMATS = ['image/png', 'image/jpeg']
|
ACCEPTED_FORMATS = ['image/png', 'image/jpeg']
|
||||||
|
# TODO: if: -> { validate_champ_value? || validation_context == :prefill }
|
||||||
validates :piece_justificative_file, content_type: ACCEPTED_FORMATS, size: { less_than: FILE_MAX_SIZE }
|
validates :piece_justificative_file, content_type: ACCEPTED_FORMATS, size: { less_than: FILE_MAX_SIZE }
|
||||||
|
|
||||||
def main_value_name
|
def main_value_name
|
||||||
|
|
Loading…
Reference in a new issue