ontology.rb revision aa6a6b29584351c27210c27d29151fccbba61212
# Ontohub Library Includes
# Ontology Model Includes
# Multiple Class Features
:logic_id,
:acronym,
:projects,
:present,
:task_ids,
allow_blank: true,
delegate :permission?, to: :repository
strip_attributes :only => [:name, :iri]
condition = <<-CONDITION
("ontology_versions"."file_extension" = :extname)
OR (("ontology_versions"."file_extension" IS NULL)
AND ("ontologies"."file_extension" = :extname))
CONDITION
with_basepath(File.basepath(path)).
where(condition, extname: File.extname(path)).
readonly(false)
end
scope :with_basepath, ->(path) do
join = <<-JOIN
LEFT JOIN "ontology_versions"
ON "ontologies"."ontology_version_id" = "ontology_versions"."id"
JOIN
condition = <<-CONDITION
("ontology_versions"."basepath" = :path)
OR (("ontology_versions"."basepath" IS NULL)
AND ("ontologies"."basepath" = :path))
CONDITION
joins(join).where(condition, path: path).readonly(false)
end
scope :parents_first,
order('(CASE WHEN ontologies.parent_id IS NULL THEN 1 ELSE 0 END) DESC,'\
' ontologies.parent_id asc')
def generate_name(name)
match = name.match(%r{
\A
.+?
:// # A uri has a separation between schema and hierarchy
.+
(?:/|\#)
(?<filename>[^/]+) # Match filename after a slash/hash
\z
}x)
if match
filename = match[:filename].sub(/\.[\w\d]+\z/, '')
capitalized_name = filename.split(/[_ ]/).map(&:capitalize).join(' ')
else
name
end
end
def iri_for_child(child_name)
child_name = child_name[1..-2] if child_name[0] == '<'
child_name.include?("://") ? child_name : "#{iri}?#{child_name}"
end
def locid_for_child(child_name)
child_name = child_name[1..-2] if child_name[0] == '<'
child_name.include?('://') ? child_name : "#{locid}//#{child_name}"
end
def is?(logic_name)
self.logic ? (self.logic.name == logic_name) : false
end
def owl?
self.is?('OWL') || self.is?('OWL2')
end
def to_s
name? ? name : iri
end
# Title for mappings
def title
name? ? iri : nil
end
def self.find_with_locid(locid, iri = nil)
ontology = where(locid: locid).first
if ontology.nil? && iri
ontology = AlternativeIri.where('iri LIKE ?', '%' << iri).
first.try(:ontology)
end
ontology
end
def self.find_with_iri(iri)
ontology = where('iri LIKE ?', '%' << iri).first
if ontology.nil?
ontology = AlternativeIri.where('iri LIKE ?', '%' << iri).
first.try(:ontology)
end
ontology
end
def is_imported?
import_mappings.present?
end
def is_imported_from_other_repository?
import_mappings_from_other_repositories.present?
end
def imported_by
import_mappings.map(&:source)
end
def destroy_with_parent(user)
if parent
repository.delete_file(parent.path, user,
"Delete #{Settings.OMS} #{parent}") do
parent.destroy
end
else
repository.delete_file(path, user,
"Delete #{Settings.OMS} #{self}") do
destroy
end
end
end
def destroy
# if repository destroying, then check if imported externally
if is_imported? &&
(!repository.is_destroying? || is_imported_from_other_repository?)
raise Ontology::DeleteError
end
super
end
def imported_ontologies
fetch_mappings_by_kind(self, 'import')
end
def contains_logic_translations?
query, args = contains_logic_translations_query(self)
pluck_select([query, *args], :logically_translated).size > 1
end
def direct_imported_ontologies
ontology_ids = Mapping.where(target_id: self, kind: 'import').
pluck(:source_id)
Ontology.where(id: ontology_ids)
end
def combined_sentences
affected_ontology_ids = [self.id] + imported_ontologies.pluck(:id)
Sentence.where(ontology_id: affected_ontology_ids)
end
# list all sentences defined on this ontology,
# those who are self defined and those which
# are imported (ImpAxioms)
def all_sentences
Sentence.unscoped.
where(ontology_id: self).
where('imported = ? OR imported = ?', true, false)
end
def imported_sentences
Sentence.unscoped.
where(ontology_id: self).
where('imported = ?', true)
end
def current_version
self.versions.current
end
def basepath
has_versions? ? current_version.basepath : read_attribute(:basepath)
end
def file_extension
has_versions? ? current_version.file_extension : read_attribute(:file_extension)
end
def path
"#{basepath}#{file_extension}"
end
def has_versions?
current_version.present?
end
def file_in_repository
repository.get_file(path)
end
# Uses where in order to force a Relation as a result
def formality_levels
FormalityLevel.joins(:ontologies).
where(ontologies: {id: self})
end
protected
def import_mappings
Mapping.where(source_id: id, kind: 'import')
end
def import_mappings_from_other_repositories
import_mappings.select { |l| l.target.repository != repository }
end
end