/** * Copyright or © or Copr. Ministère Français chargé de la Culture * et de la Communication (2013) * <p/> * contact.gincoculture_at_gouv.fr * <p/> * This software is a computer program whose purpose is to provide a thesaurus * management solution. * <p/> * This software is governed by the CeCILL license under French law and * abiding by the rules of distribution of free software. You can use, * modify and/ or redistribute the software under the terms of the CeCILL * license as circulated by CEA, CNRS and INRIA at the following URL * "http://www.cecill.info". * <p/> * As a counterpart to the access to the source code and rights to copy, * modify and redistribute granted by the license, users are provided only * with a limited warranty and the software's author, the holder of the * economic rights, and the successive licensors have only limited liability. * <p/> * In this respect, the user's attention is drawn to the risks associated * with loading, using, modifying and/or developing or reproducing the * software by the user in light of its specific status of free software, * that may mean that it is complicated to manipulate, and that also * therefore means that it is reserved for developers and experienced * professionals having in-depth computer knowledge. Users are therefore * encouraged to load and test the software's suitability as regards their * requirements in conditions enabling the security of their systemsand/or * data to be ensured and, more generally, to use and operate it in the * same conditions as regards security. * <p/> * The fact that you are presently reading this means that you have had * knowledge of the CeCILL license and that you accept its terms. */ package fr.mcc.ginco.imports; import com.hp.hpl.jena.rdf.model.RDFNode; import com.hp.hpl.jena.rdf.model.Resource; import com.hp.hpl.jena.rdf.model.Statement; import com.hp.hpl.jena.rdf.model.StmtIterator; import fr.mcc.ginco.ark.IIDGeneratorService; import fr.mcc.ginco.beans.Language; import fr.mcc.ginco.beans.Note; import fr.mcc.ginco.beans.NoteType; import fr.mcc.ginco.beans.Thesaurus; import fr.mcc.ginco.beans.ThesaurusConcept; import fr.mcc.ginco.beans.ThesaurusTerm; import fr.mcc.ginco.dao.ILanguageDAO; import fr.mcc.ginco.exceptions.BusinessException; import fr.mcc.ginco.services.INoteTypeService; import fr.mcc.ginco.skos.namespaces.SKOS; import org.apache.commons.lang3.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import javax.inject.Inject; import javax.inject.Named; import java.util.ArrayList; import java.util.List; /** * Builder in charge of buidlding concept notes */ @Service("skosConceptNoteBuilder") public class ConceptNoteBuilder extends AbstractBuilder { private static Logger logger = LoggerFactory.getLogger(ConceptNoteBuilder.class); @Inject @Named("noteTypeService") private INoteTypeService noteTypeService; @Inject @Named("generatorService") private IIDGeneratorService generatorService; @Inject private ILanguageDAO languagesDAO; @Value("${ginco.default.language}") private String defaultLang; public ConceptNoteBuilder() { super(); } private Language getNoteLanguage(String skosLang) { Language lang; if (StringUtils.isEmpty(skosLang)) { lang = languagesDAO .getById(defaultLang); return lang; } else { lang = languagesDAO.getByPart1(skosLang); if (lang == null) { lang = languagesDAO.getById(skosLang); } if (lang != null) { return lang; } else { throw new BusinessException("Note " + skosLang + " is missing it's language", "import-note-with-no-lang" ); } } } /** * Returns the list of notes for the given concept * * @param skosConcept * @param concept * @param thesaurus * @return */ public List<Note> buildConceptNotes(Resource skosConcept, ThesaurusConcept concept, ThesaurusTerm preferredTerm, Thesaurus thesaurus) { logger.debug("Building notes for concept " + skosConcept.getURI()); List<Note> allConceptNotes = new ArrayList<Note>(); List<NoteType> conceptNoteTypes = noteTypeService .getConceptNoteTypeList(); for (NoteType noteType : conceptNoteTypes) { String skosNoteType = noteType.getCode(); if (SKOS.SKOS_NOTES.keySet().contains(skosNoteType)) { StmtIterator stmtNotesItr = skosConcept .listProperties(SKOS.SKOS_NOTES.get(skosNoteType)); while (stmtNotesItr.hasNext()) { Statement stmt = stmtNotesItr.next(); Note newNote = new Note(); newNote.setCreated(thesaurus.getCreated()); newNote.setIdentifier(generatorService.generate(Note.class)); newNote.setLexicalValue(stmt.getString()); RDFNode prefLabel = stmt.getObject(); newNote.setLanguage(getNoteLanguage(prefLabel.asLiteral().getLanguage())); newNote.setModified(thesaurus.getDate()); newNote.setNoteType(noteType); newNote.setConcept(concept); allConceptNotes.add(newNote); } } } // Add definition notes to the prefered term... StmtIterator stmtNotesItr = skosConcept .listProperties(SKOS.SKOS_NOTES.get("definition")); while (stmtNotesItr.hasNext()) { Statement stmt = stmtNotesItr.next(); Note newNote = new Note(); newNote.setCreated(thesaurus.getCreated()); newNote.setIdentifier(generatorService.generate(Note.class)); newNote.setLexicalValue(stmt.getString()); newNote.setModified(thesaurus.getDate()); RDFNode prefLabel = stmt.getObject(); newNote.setLanguage(getNoteLanguage(prefLabel.asLiteral().getLanguage())); newNote.setNoteType(noteTypeService.getNoteTypeById("definition")); newNote.setTerm(preferredTerm); allConceptNotes.add(newNote); } return allConceptNotes; } }