forked from samvera/hydra-head
-
Notifications
You must be signed in to change notification settings - Fork 0
Model Examples
ndushay edited this page May 14, 2012
·
1 revision
This model conforms to Hydra commonMetadata cModel and has basic MODS metadata
(this used to be included in the code itself as app/models/common_metadata_asset.rb)
class CommonMetadataAsset < ActiveFedora::Base # declares a rightsMetadata datastream with type Hydra::Datastream::RightsMetadata # basically, it is another expression of has_metadata :name => "rightsMetadata", :type => Hydra::Datastream::RightsMetadata include Hydra::ModelMixins::CommonMetadata # adds helpful methods for basic hydra objects include Hydra::ModelMethods end
(this used to be included in the code itself as app/models/hydra/datastream/mods_dataset.rb)
module Hydra module Datastream class ModsDataset < ActiveFedora::NokogiriDatastream include Hydra::Datastream::CommonModsIndexMethods set_terminology do |t| t.root(:path=>"mods", :xmlns=>"http://www.loc.gov/mods/v3", :schema=>"http://www.loc.gov/standards/mods/v3/mods-3-2.xsd") # Common MODS info -- might eventually be put into its own shared terminology. t.title_info(:path=>"titleInfo") { t.main_title(:path=>"title", :label=>"title") t.language(:path=>{:attribute=>"lang"}) } t.title(:proxy=>[:title_info, :main_title]) t.abstract t.subject { t.topic(:index_as=>[:facetable]) } t.topic_tag(:path=>"subject", :default_content_path=>"topic") t.identifier { t.type_(:path=>{:attribute=>"type"}) } # This is a mods:name. The underscore is purely to avoid namespace conflicts. t.name_ { t.namePart(:index_as=>[:searchable, :displayable, :facetable, :sortable], :required=>:true, :type=>:string, :label=>"generic name") t.affiliation t.institution(:path=>"affiliation") t.displayForm t.role(:ref=>[:role]) t.description t.date(:path=>"namePart", :attributes=>{:type=>"date"}) t.last_name(:path=>"namePart", :attributes=>{:type=>"family"}) t.first_name(:path=>"namePart", :attributes=>{:type=>"given"}, :label=>"first name") t.terms_of_address(:path=>"namePart", :attributes=>{:type=>"termsOfAddress"}) } # lookup :person, :first_name t.person(:ref=>:name, :attributes=>{:type=>"personal"}) t.organization(:ref=>:name, :attributes=>{:type=>"institutional"}) t.conference(:ref=>:name, :attributes=>{:type=>"conference"}) t.role { t.text(:path=>"roleTerm",:attributes=>{:type=>"text"}) t.code(:path=>"roleTerm",:attributes=>{:type=>"code"}) } # Dataset-specific Terms # In datasets, we're calling the abstract "methodology" t.methodology(:path=>"abstract") # Most of these are forcing non-bibliographic information into mods by using the note field pretty freely t.note t.gps(:index_as=>[:facetable],:path=>"note",:attributes=>{:type=>"location"}) t.timespan_start(:path=>"note",:attributes=>{:type=>"timespan-start"}) t.timespan_end(:path=>"note",:attributes=>{:type=>"timespan-end"}) t.region(:index_as=>[:facetable],:path=>"note",:attributes=>{:type=>"region"}) t.site(:index_as=>[:facetable],:path=>"note",:attributes=>{:type=>"site"}) t.ecosystem(:index_as=>[:facetable],:path=>"note",:attributes=>{:type=>"ecosystem"}) end # It would be nice if we could declare properties with refined info like this # accessor :grant_agency, :relative_xpath=>'oxns:mods/oxns:name[contains(oxns:role/oxns:roleTerm, "Funder")]' # Generates an empty Mods Article (used when you call ModsArticle.new without passing in existing xml) def self.xml_template builder = Nokogiri::XML::Builder.new do |xml| xml.mods(:version=>"3.3", "xmlns:xlink"=>"http://www.w3.org/1999/xlink", "xmlns:xsi"=>"http://www.w3.org/2001/XMLSchema-instance", "xmlns"=>"http://www.loc.gov/mods/v3", "xsi:schemaLocation"=>"http://www.loc.gov/mods/v3 http://www.loc.gov/standards/mods/v3/mods-3-3.xsd") { xml.titleInfo(:lang=>"") { xml.title } xml.name(:type=>"personal") { xml.namePart(:type=>"given") xml.namePart(:type=>"family") xml.affiliation xml.role { xml.roleTerm(:authority=>"marcrelator", :type=>"text") } } xml.name(:type=>"corporate") { xml.namePart xml.affiliation xml.role { xml.roleTerm("Funder", :authority=>"marcrelator", :type=>"text") } } xml.typeOfResource "software, multimedia" xml.genre("dataset", :authority=>"dct") xml.language { xml.languageTerm("eng", :authority=>"iso639-2b", :type=>"code") } xml.abstract xml.subject { xml.topic } xml.note(:type=>"completeness") xml.note(:type=>"interval") xml.note(:type=>"datatype") xml.note(:type=>"timespan-start") xml.note(:type=>"timespan-end") xml.note(:type=>"location") xml.note(:type=>"grant") xml.note(:type=>"data quality") xml.note(:type=>"contact-name") xml.note(:type=>"contact-email") } end return builder.doc end def self.person_relator_terms {"anl" => "Analyst", "aut" => "Author", "clb" => "Collaborator", "com" => "Compiler", "cre" => "Creator", "ctb" => "Contributor", "dpt" => "Depositor", "dtc" => "Data contributor ", "dtm" => "Data manager ", "edt" => "Editor", "lbr" => "Laboratory ", "ldr" => "Laboratory director ", "pdr" => "Project director", "prg" => "Programmer", "res" => "Researcher", "rth" => "Research team head", "rtm" => "Research team member" } end def self.completed_choices ["Time Series", "Snapshot / Sample" ] end def self.interval_choices ["Monthly", "Quarterly", "Semi-annually", "Annually", "Irregular" ] end def self.data_type_choices ["transect","observation","data logging","remote sensing"] end def self.valid_child_types ["data", "supporting file", "profile", "lorem ipsum", "dolor"] end def to_solr(solr_doc=Hash.new) super(solr_doc) solr_doc.merge!(extract_person_full_names) solr_doc.merge!(extract_person_organizations) solr_doc.merge!(:object_type_facet => "Dataset") solr_doc end end end end