001/* 002 * Copyright 2010 Anyware Services 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016package org.ametys.plugins.repository.metadata; 017 018import org.ametys.plugins.repository.AmetysRepositoryException; 019 020 021/** 022 * A resource with additional data.<br> 023 * A RichText is typically an XML or HTML stream with attached pictures. 024 */ 025public interface RichText extends Resource 026{ 027 028 /** 029 * Returns the Folder holding additional data.<br> 030 * Its internal organization is application dependant. 031 * @return the Folder holding additional data 032 */ 033 public Folder getAdditionalDataFolder(); 034 035 /** 036 * Get the content annotation names. 037 * @return the annotation names. 038 * @throws AmetysRepositoryException if an error occurs. 039 */ 040 public String[] getAnnotationNames() throws AmetysRepositoryException; 041 042 /** 043 * Get the values of a given annotation. 044 * @param name The name of the annotation. 045 * @return The annotation values. 046 * @throws AmetysRepositoryException if an error occurs. 047 */ 048 public String[] getAnnotationValues(String name) throws AmetysRepositoryException; 049 050}