package se.cambio.openehr.controller.terminology; import org.openehr.rm.datatypes.text.CodePhrase; import org.openehr.rm.datatypes.text.DvCodedText; import se.cambio.cm.model.facade.terminology.vo.TerminologyNodeVO; import se.cambio.openehr.util.exceptions.InvalidCodeException; import se.cambio.openehr.util.exceptions.UnknownPropertyException; import se.cambio.openehr.util.exceptions.UnsupportedLanguageException; import se.cambio.openehr.util.exceptions.UnsupportedTerminologyException; import java.util.Collection; import java.util.List; import java.util.Set; /** * This class defines a minimal interface of a terminology service * that is required to support runtime and authoring of CDSS. * * @author rong.chen * */ public interface TerminologyService { /** * Checks if codePhrase a is subclass of b with regards to * subsumption relationship * * @param a * @param b * @return true if a is subclass of b */ public boolean isSubclassOf(CodePhrase a, CodePhrase b) throws UnsupportedTerminologyException, InvalidCodeException; /** * Checks if the given code is subclass of any member of * specified set of codes * * @param code * @param codes * @return true if a is subclass of b */ public boolean isSubclassOf(CodePhrase code, Set<CodePhrase> codes) throws UnsupportedTerminologyException, InvalidCodeException; /** * Retrieves all subclasses of given concept with specified language * * @param concept * @return returns a tree representation of subclasses */ public TerminologyNodeVO retrieveAllSubclasses(CodePhrase concept, CodePhrase language) throws UnsupportedTerminologyException, UnsupportedLanguageException, InvalidCodeException; public List<TerminologyNodeVO> retrieve(String expression, CodePhrase language) throws UnsupportedTerminologyException, UnsupportedLanguageException; public List<TerminologyNodeVO> retrieveAll(String terminologyId, CodePhrase language) throws UnsupportedTerminologyException, UnsupportedLanguageException; /** * Checks if given concept has a named attribute of given value * * @param concept * @param property * @param value * @return true if the property has value */ public boolean hasPropertyOfValue(CodePhrase concept, CodePhrase property, CodePhrase value) throws UnsupportedTerminologyException, UnknownPropertyException; /** * Retrieves the term of a given concept in given language * * @param concept * @param language * @return the term * @throws UnsupportedTerminologyException * @throws UnsupportedLanguageException */ public String retrieveTerm(CodePhrase concept, CodePhrase language) throws UnsupportedTerminologyException, UnsupportedLanguageException; /** * Retrieves all possible values of given attribute with labels in specified language * * @param property * @param language * @return a list of coded texts */ public List<DvCodedText> retrieveAllPossibleValues(CodePhrase property, CodePhrase language) throws UnsupportedTerminologyException, UnknownPropertyException, UnsupportedLanguageException; public boolean isTerminologySupported(String terminologyId); public boolean isValidCodePhrase(CodePhrase codePhrase); public Collection<String> getSupportedTerminologies(); } /* * ***** BEGIN LICENSE BLOCK ***** * Version: MPL 2.0/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla Public License Version * 2.0 (the 'License'); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an 'AS IS' basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * * The Initial Developers of the Original Code are Iago Corbal and Rong Chen. * Portions created by the Initial Developer are Copyright (C) 2012-2013 * the Initial Developer. All Rights Reserved. * * Contributor(s): * * Software distributed under the License is distributed on an 'AS IS' basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * ***** END LICENSE BLOCK ***** */