Module: DelegateValidation

Defined in:
app/models/delegate_validation.rb

Overview

Delegate validation is all about enabling one class to validate the information within an instance of another class. The case driving this is the ability for a Submission to validate that the request options provided by the user are valid for the RequestType instances that the submission is going to use. In that case the RequestType#delegate_validator returns a class that can then be used to validate the request options. Because RequestType isn't subclassed it actually delegates to the Request class that it'll instantiate, so you can find examples of the delegator stuff in SequencingRequest and LibraryCreationRequest

Defined Under Namespace

Classes: AlwaysValidValidator, CompositeValidator, Validator

Instance Method Summary collapse

Instance Method Details

#delegate_validation(*args) ⇒ Object

rubocop:todo Metrics/MethodLength



10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# File 'app/models/delegate_validation.rb', line 10

 do
  # NOTE: The following attribute is not required for Microarray Genotyping.
  # I think this might be broken and suggests that there should be separate classes for project: one for
  # next-gen sequencing that includes this attribute in it's metadata, and one for microarray genotyping
  # that doesn't.
  include ProjectManager::Associations
  include BudgetDivision::Associations

  custom_attribute(:project_cost_code, required: true)
  custom_attribute(:funding_comments)
  custom_attribute(:collaborators)
  custom_attribute(:external_funding_source)
  custom_attribute(:sequencing_budget_cost_centre)
  custom_attribute(:project_funding_model, in: PROJECT_FUNDING_MODELS)
  custom_attribute(:gt_committee_tracking_id)

  before_validation do |record|
    record.project_cost_code = nil if record.project_cost_code.blank?
    record.project_funding_model = nil if record.project_funding_model.blank?
  end
end