Module: Concept::Validations

Extended by:
ActiveSupport::Concern
Included in:
Base
Defined in:
app/models/concept/validations.rb

Instance Method Summary collapse

Instance Method Details

#exclusive_top_termObject

top term and broader relations are mutually exclusive



17
18
19
20
21
22
23
# File 'app/models/concept/validations.rb', line 17

def exclusive_top_term
  if validatable_for_publishing?
    if top_term && broader_relations.any?
      errors.add :base, I18n.t('txt.models.concept.top_term_exclusive_error')
    end
  end
end

#pref_label_in_primary_thesaurus_languageObject



36
37
38
39
40
41
42
43
44
45
# File 'app/models/concept/validations.rb', line 36

def pref_label_in_primary_thesaurus_language
  if validatable_for_publishing?
    labels = pref_labels.select{ |l| l.published? }
    if labels.none?
      errors.add :base, I18n.t('txt.models.concept.no_pref_label_error')
    elsif not labels.map(&:language).map(&:to_s).include?(Iqvoc::Concept.pref_labeling_languages.first.to_s)
      errors.add :base, I18n.t('txt.models.concept.main_pref_label_language_missing_error')
    end
  end
end

#rooted_top_termsObject

top terms must never be used as descendants (narrower relation targets) NB: for top terms themselves, this is covered by ‘ensure_exclusive_top_term`



27
28
29
30
31
32
33
34
# File 'app/models/concept/validations.rb', line 27

def rooted_top_terms
  if validatable_for_publishing?
    if narrower_relations.includes(:target). # XXX: inefficient?
        select { |rel| rel.target && rel.target.top_term? }.any?
      errors.add :base, I18n.t('txt.models.concept.top_term_rooted_error')
    end
  end
end

#unique_pref_labelObject



63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
# File 'app/models/concept/validations.rb', line 63

def unique_pref_label
  if validatable_for_publishing?
    # checks if there are any existing pref labels with the same
    # language and value
    conflicting_pref_labels = pref_labels.select do |l|
      Labeling::SKOS::PrefLabel.
        joins(:owner, :target).
        where(labels: { value: l.value, language: l.language }).
        where('labelings.owner_id != ?', id).
        where('concepts.origin != ?', origin).
        any?
    end

    if conflicting_pref_labels.any?
      if conflicting_pref_labels.one?
        errors.add :base,
          I18n.t('txt.models.concept.pref_label_not_unique',
            label: conflicting_pref_labels.last.value)
      else
        errors.add :base,
          I18n.t('txt.models.concept.pref_labels_not_unique',
            label: conflicting_pref_labels.map(&:value).join(', '))
      end
    end
  end
end

#unique_pref_label_languageObject



47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# File 'app/models/concept/validations.rb', line 47

def unique_pref_label_language
  # We have many sources a prefLabel can be defined in
  pls = pref_labelings.map(&:target) +
    send(Iqvoc::Concept.pref_labeling_class_name.to_relation_name).map(&:target) +
    labelings.select{ |l| l.is_a?(Iqvoc::Concept.pref_labeling_class) }.map(&:target)
  languages = {}
  pls.compact.each do |pref_label|
    lang = pref_label.language.to_s
    origin = (pref_label.origin || pref_label.id || pref_label.value).to_s
    if (languages.keys.include?(lang) && languages[lang] != origin)
      errors.add :pref_labelings, I18n.t('txt.models.concept.pref_labels_with_same_languages_error')
    end
    languages[lang] = origin
  end
end

#valid_rank_for_ranked_relationsObject



90
91
92
93
94
95
96
97
98
99
100
# File 'app/models/concept/validations.rb', line 90

def valid_rank_for_ranked_relations
  if validatable_for_publishing?
    relations.each do |relation|
      if relation.class.rankable? && !(0..100).include?(relation.rank)
        errors.add :base, I18n.t('txt.models.concept.invalid_rank_for_ranked_relations',
          relation: relation.class.model_name.human.downcase,
          relation_target_label: relation.target.pref_label.to_s)
      end
    end
  end
end