mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-29 15:21:53 +00:00 
			
		
		
		
	99981: Merged 5.0.N (5.0.2) to HEAD-BUG-FIX (5.1/Cloud) (PARTIAL MERGE)
      99482: Merged DEV to 5.0.N (5.0.1)
         99198 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc typo in project alfresco-jlan
         99413 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project alfresco-jlan
         99205 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project core
         99415 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project data-model
         99227 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project file-transfer-receiver
         99416 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project legacy-lucene
         99417 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project qa-share
         99418 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project remote-api
         99427 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc in project Repository, letters S..Z
         99433 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc in project Repository, letters A..R
         99421 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project share-po
         99247 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc typo in project slingshot
         99248 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project slingshot
         99424 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project solr
         99426 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project solr4
         99253 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project solr-client
         99259 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project web-client
         99260 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code
            - Changed Javadoc parameters inconsistence in project web-framework-commons
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@100501 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
	
		
			
				
	
	
		
			200 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			200 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2011 Alfresco Software Limited.
 | |
|  *
 | |
|  * This file is part of Alfresco
 | |
|  *
 | |
|  * Alfresco is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Lesser General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * Alfresco is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public License
 | |
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| package org.alfresco.service.cmr.ml;
 | |
| 
 | |
| import java.util.List;
 | |
| import java.util.Locale;
 | |
| import java.util.Map;
 | |
| import java.util.Set;
 | |
| 
 | |
| import org.alfresco.service.Auditable;
 | |
| import org.alfresco.service.cmr.model.FileExistsException;
 | |
| import org.alfresco.service.cmr.model.FileNotFoundException;
 | |
| import org.alfresco.service.cmr.repository.NodeRef;
 | |
| 
 | |
| /**
 | |
|  * The API to manage multilingual content and related structures.
 | |
|  *
 | |
|  * @author Derek Hulley
 | |
|  * @author Philippe Dubois
 | |
|  */
 | |
| public interface MultilingualContentService
 | |
| {
 | |
|     /**
 | |
|      * Checks whether an existing document is part of a translation group.
 | |
|      *
 | |
|      * @param contentNodeRef            An existing <b>cm:content</b>
 | |
|      * @return                          Returns <tt>true</tt> if the document has a <b>cm:mlContainer</b> parent
 | |
|      */
 | |
|     @Auditable(parameters = {"contentNodeRef"})
 | |
|     boolean isTranslation(NodeRef contentNodeRef);
 | |
| 
 | |
|     /**
 | |
|      * Make an existing document into a translation by adding the <b>cm:mlDocument</b> aspect and
 | |
|      * creating a <b>cm:mlContainer</b> parent.  If it is already a translation, then nothing is done.
 | |
|      *
 | |
|      * @param contentNodeRef            An existing <b>cm:content</b>
 | |
|      *
 | |
|      * @see org.alfresco.model.ContentModel#ASPECT_MULTILINGUAL_DOCUMENT
 | |
|      */
 | |
|     @Auditable(parameters = {"contentNodeRef", "locale"})
 | |
|     void makeTranslation(NodeRef contentNodeRef, Locale locale);
 | |
| 
 | |
|     /**
 | |
|      * Removes the node from any associated translations.  If the translation is the
 | |
|      * pivot translation, then the entire set of translations will be unhooked.
 | |
|      *
 | |
|      * @param translationNodeRef        an existing <b>cm:mlDocument</b>
 | |
|      */
 | |
|     @Auditable(parameters = {"translationNodeRef"})
 | |
|     void unmakeTranslation(NodeRef translationNodeRef);
 | |
| 
 | |
|     /**
 | |
|      * Make a translation out of an existing document.  The necessary translation structures will be created
 | |
|      * as necessary.
 | |
|      *
 | |
|      * @param newTranslationNodeRef     An existing <b>cm:content</b>
 | |
|      * @param translationOfNodeRef      An existing <b>cm:mlDocument</b>
 | |
|      */
 | |
|     @Auditable(parameters = {"newTranslationNodeRef", "translationOfNodeRef", "locale"})
 | |
|     void addTranslation(NodeRef newTranslationNodeRef, NodeRef translationOfNodeRef, Locale locale);
 | |
| 
 | |
|     /**
 | |
|      * Convenience method for super user.
 | |
|      *
 | |
|      * @param translationNodeRef        An existing <b>cm:mlDocument</b>
 | |
|      * @return                          Returns the <b>cm:mlContainer</b> translation parent
 | |
|      */
 | |
|     @Auditable(parameters = {"translationNodeRef"})
 | |
|     NodeRef getTranslationContainer(NodeRef translationNodeRef);
 | |
| 
 | |
|     /**
 | |
|      * Gets the set of sibling translations associated with the given <b>cm:mlDocument</b> or
 | |
|      * <b>cm:mlContainer</b>.
 | |
|      *
 | |
|      * @param translationOfNodeRef      An existing <b>cm:mlDocument</b> or <b>cm:mlContainer</b>
 | |
|      * @return                          Returns a map of translation nodes keyed by locale
 | |
|      */
 | |
|     @Auditable(parameters = {"translationOfNodeRef"})
 | |
|     Map<Locale, NodeRef> getTranslations(NodeRef translationOfNodeRef);
 | |
| 
 | |
|     /**
 | |
|      * Given a <b>cm:mlDocument</b>, this method attempts to find the best translation for the given
 | |
|      * locale.  If there is not even a
 | |
|      * {@link org.springframework.extensions.surf.util.I18NUtil#getNearestLocale(Locale, Set) partial match}, then the
 | |
|      * {@link #getPivotTranslation(NodeRef) pivot translation} is used.  If that also gives no results
 | |
|      * then the translation itself is returned.
 | |
|      *
 | |
|      * @param translationNodeRef        the <b>cm:mlDocument</b>
 | |
|      * @param locale                    the target locale
 | |
|      * @return                          Returns the best match for the locale (never <tt>null</tt>)
 | |
|      *
 | |
|      * @see #getTranslations(NodeRef)
 | |
|      * @see org.springframework.extensions.surf.util.I18NUtil#getNearestLocale(Locale, Set)
 | |
|      */
 | |
|     @Auditable(parameters = {"translationNodeRef", "locale"})
 | |
|     NodeRef getTranslationForLocale(NodeRef translationNodeRef, Locale locale);
 | |
| 
 | |
| 
 | |
|     /**
 | |
|      * Given a <b>cm:mlDocument</b> or <b>cm:mlContainer</b> this node returns each locale for
 | |
|      * which there isn't a translation.
 | |
|      *
 | |
|      * @param localizedNodeRef          the <b>cm:mlDocument</b> or <b>cm:mlContainer</b>
 | |
|      * @param addThisNodeLocale         if true, add the locale of the given <b>cm:mlDocument</b> in the list.
 | |
|      * @return                          Returns a list of missng locales
 | |
|      */
 | |
|     @Auditable(parameters = {"localizedNodeRef", "addThisNodeLocale"})
 | |
|     List<Locale> getMissingTranslations(NodeRef localizedNodeRef, boolean addThisNodeLocale);
 | |
| 
 | |
|     /**
 | |
|      * Given any node, this returns the pivot translation.  All multilingual documents belong to
 | |
|      * a group linked by a hidden parent node of type <b>cm:mlContainer</b>.  The pivot language
 | |
|      * for the translations is stored on the parent, and the child that has the same locale is the
 | |
|      * pivot translation.
 | |
|      *
 | |
|      * @param nodeRef       a <b>cm:mlDocument</b> translation or <b>cm:mlContainer</b> translation
 | |
|      *                      container
 | |
|      * @return              Returns a corresponding <b>cm:mlDocument</b> that matches the locale of
 | |
|      *                      of the <b>cm:mlContainer</b>.  <tt>null</tt> is returned if there is no
 | |
|      *                      pivot translation.
 | |
|      */
 | |
|     @Auditable(parameters = {"nodeRef"})
 | |
|     NodeRef getPivotTranslation(NodeRef nodeRef);
 | |
| 
 | |
|     /**
 | |
|      * Make a empty translation out of an existing pivot translation.  The given translation or
 | |
|      * container will be used to find the pivot translation.  Failing this, the given translation
 | |
|      * will be used directly.  If no name is provided or if the name is the same as the original's
 | |
|      * then the locale will be added to the main portion of the filename, i.e.
 | |
|      * <pre>
 | |
|      *    Document.txt --> Document_fr.txt
 | |
|      * </pre>
 | |
|      * <p/>
 | |
|      * The necessary translation structures will be created as necessary.
 | |
|      *
 | |
|      * @param translationOfNodeRef      An existing <b>cm:mlDocument</b>
 | |
|      * @param name                      The name of the file to create, or <tt>null</tt> to use
 | |
|      *                                  the default naming convention.
 | |
|      * @return Returns                  the new created <b>cm:mlEmptyTranslation</b>
 | |
|      */
 | |
|     @Auditable(parameters = {"translationOfNodeRef", "name", "locale"})
 | |
|     NodeRef addEmptyTranslation(NodeRef translationOfNodeRef, String name, Locale locale);
 | |
| 
 | |
|     /**
 | |
|      * Copies the given <b>cm:mlContainer</b>.
 | |
|      * <p>
 | |
|      * This involves the copy of the <b>cm:mlContainer</b> node and the copy of its <b>cm:mlDocument</b>.
 | |
|      * <p>
 | |
|      *
 | |
|      * @param mlContainerNodeRef            The nodeRef to copy
 | |
|      * @param newParentRef                  The new parent of the copied <b>cm:mlDocument</b>
 | |
|      * @param prefixName                    The prefix of the name of the copied translations. Can be null.
 | |
|      * @return                              The copied <b>cm:mlContainer</b>
 | |
|      * @throws FileNotFoundException
 | |
|      * @throws FileExistsException
 | |
|      * @throws Exception
 | |
|      */
 | |
|     @Auditable(parameters = {"mlContainerNodeRef", "newParentRef"})
 | |
|     NodeRef copyTranslationContainer(NodeRef mlContainerNodeRef, NodeRef newParentRef, String prefixName) throws FileExistsException, FileNotFoundException, Exception;
 | |
| 
 | |
|     /**
 | |
|      * Moves the location of the given <b>cm:mlContainer</b>.
 | |
|      * <p>
 | |
|      * This not involves changing the <b>cm:mlContainer</b> node but moves its <b>cm:mlDocument</b>.
 | |
|      * <p>
 | |
|      *
 | |
|      * @param mlContainerNodeRef            The nodeRef> to move
 | |
|      * @param newParentRef                  The new parent of the moved <b>cm:mlDocument</b>
 | |
|      * @throws FileExistsException
 | |
|      * @throws FileNotFoundException
 | |
|      */
 | |
|     @Auditable(parameters = {"mlContainerNodeRef", "newParentRef"})
 | |
|     void moveTranslationContainer(NodeRef mlContainerNodeRef, NodeRef newParentRef) throws FileExistsException, FileNotFoundException;
 | |
| 
 | |
|     /**
 | |
|      * Delete the given mlContainer and its translations. The translations will lost their <b>cm:mlDocument</b> aspect and
 | |
|      * will be archved. The empty translations will be permanently deleted.
 | |
|      *
 | |
|      * @param mlContainerNodeRef        The <b>cm:mlContainer</b> to remove
 | |
|      */
 | |
|     @Auditable(parameters = {"mlContainerNodeRef"})
 | |
|     void deleteTranslationContainer(NodeRef mlContainerNodeRef);
 | |
| }
 |