mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	26059: ALF-5900 - IMAP creates winmail.dat in attachment folder (Add support for Microsoft Transport Neutral Encapsulation Format.)
          - added attachment extraction for TNEF documents - goodbye winmail.dat !
   26063: javadoc for imap.
   26088: ALF-7408 - addition of commons-net for ftp client library.
          First test of end to end ftp.   Just a simple test of connection now, will be followed by more detailed tests.
   26176: ALF-7408 - FTP tests + disabled failing test case for ALF-7618
   26180: ALF-7618 - correction of unit test error.
   26188: ALF-7618 - added a test of paths
   26229: Added back simple '\~.*' pattern
   26288: ALF-7676 - Test to stress different user rights.
          - FTPServerTest.testTwoUserUpdate added for the FTP server.
   26304: Corrected spelling name in private class.
   26408: addming minimal package infos.
   26416: ALF-5082 / ALF-2183 / ALF-4448 - When guessing the mimetype for a file, add the option to supply a ContentReader to enhance the accuracy.
          Enable this for a few key places that do mimetype guessing,
          which should avoid issues for files with the wrong extension (either renamed accidently, or for .TMP)
   26433: Re-order the mimetype guess step to ensure that the Content Reader is always valid
   26440: Added another test for word 2003 save as.
   26441: Test resource for ContentDiskDriver
   26446: ALF-5082 - Back out a FileFolderService change to mimetype guessing, which had broken things, pending a better way to do it with ContentWriter
   26490: Small change for ContentDiskDriverTes.fileExists.  Leaky transaction causing problems in automated build.
   26497: ContentDiskDriver - commented out two of the problematic leaky transaction tests.
   26503: Add new interface methods + documentation for asking a ContentWriter to guess the mimetype and encoding for you.
          (Code will be migrated from places that currently do this themselves later)
   26504: Add an extension interface in the DataModel project for some of the extra ContentReader methods that FileContentReader provides
   26505: When ContentWriter.putContent(String) is called with no encoding specified, record what the system default encoding was that was used.
          (Prevents issues if the system default is ever changed)
   26509: When calling Tika to do file detection, if we have a file based reader then give Tika the File rather than an InputStream
   26522: More debug logging while debugging ALF-5260
   26546: Have one copy of the Tika Config in spring, rather than several places fetching their own copy of the default one (either explicitly or implicitly).
   26522: More debug logging while diagnosing ALF-5260
   26548: Add another mimetype check - ensures that truncated/corrup container files which can't be fully processed can still get the container type without failure
   26549: Implement the mimetype and encoding guessers on ContentWriter (either immediately or as a listener, as required), and update FileFolderServer to make use of this (+test this)
   26553: Replace explicit mimetype and encoding guess calls with ContentWriter requests to have the work done
   26554: Replace explicit mimetype and encoding guess calls with ContentWriter requests to have the work done
   26579: Switch the transformer to use Tika
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@28224 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
	
		
			
				
	
	
		
			100 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2010 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.repo.jscript;
 | |
| 
 | |
| import org.alfresco.model.ContentModel;
 | |
| import org.alfresco.service.ServiceRegistry;
 | |
| import org.alfresco.service.cmr.dictionary.DataTypeDefinition;
 | |
| import org.alfresco.service.cmr.dictionary.PropertyDefinition;
 | |
| import org.alfresco.service.cmr.repository.ContentData;
 | |
| import org.alfresco.service.namespace.NamespacePrefixResolver;
 | |
| import org.alfresco.service.namespace.NamespacePrefixResolverProvider;
 | |
| import org.alfresco.service.namespace.QName;
 | |
| 
 | |
| /**
 | |
|  * Specialised map class for supporting the initialisation of 'cm:content' properties for JavaScript API
 | |
|  * objects. The JavaScript needs supporting objects to be initialised for certain data-types. If the
 | |
|  * 'cm:content' property is not already initialised then it must be created on demand or it will not be
 | |
|  * available to the users of the API. See AR-1673.
 | |
|  * 
 | |
|  * @author Kevin Roast
 | |
|  */
 | |
| public class ContentAwareScriptableQNameMap<K,V> extends ScriptableQNameMap<K,V>
 | |
| {
 | |
|     private ServiceRegistry services;
 | |
|     private ScriptNode factory;
 | |
|     
 | |
|     
 | |
|     /**
 | |
|      * Constructor
 | |
|      * 
 | |
|      * @param factory       Factory to provide further ScriptNode objects
 | |
|      * @param services      ServiceRegistry
 | |
|      */
 | |
|     public ContentAwareScriptableQNameMap(final ScriptNode factory, final ServiceRegistry services)
 | |
|     {
 | |
|         super(new NamespacePrefixResolverProvider(){
 | |
|             public NamespacePrefixResolver getNamespacePrefixResolver()
 | |
|             {
 | |
|                 return services.getNamespaceService();
 | |
|             }
 | |
|         });
 | |
|         this.services = services;
 | |
|         this.factory = factory;
 | |
|     }
 | |
| 
 | |
|     /* (non-Javadoc)
 | |
|      * @see org.alfresco.service.namespace.QNameMap#get(java.lang.Object)
 | |
|      */
 | |
|     @Override
 | |
|     public Object get(Object name)
 | |
|     {
 | |
|         Object value = super.get(name);
 | |
|         
 | |
|         if (value == null)
 | |
|         {
 | |
|            // convert the key to a qname and look up the data-type for the property
 | |
|            QName qname = QName.resolveToQName(getResolver(), name.toString());
 | |
|            PropertyDefinition propDef = this.services.getDictionaryService().getProperty(qname);
 | |
|            if (propDef != null && DataTypeDefinition.CONTENT.equals(propDef.getDataType().getName()))
 | |
|            {
 | |
|                // found a valid cm:content property that is not initialised
 | |
|                String mimetype = null;
 | |
|                if (qname.equals(ContentModel.PROP_CONTENT)) 
 | |
|                {
 | |
|                    String fileName = (String)get("cm:name");
 | |
|                    if (fileName != null)
 | |
|                    {
 | |
|                        // We don't have any content, so just use the filename when
 | |
|                        //  trying to guess the mimetype for this
 | |
|                        mimetype = this.services.getMimetypeService().guessMimetype(fileName);
 | |
|                    }
 | |
|                }
 | |
|                ContentData cdata = new ContentData(null, mimetype, 0L, "UTF-8");
 | |
|                // create the JavaScript API object we need
 | |
|                value = factory.new ScriptContentData(cdata, qname);
 | |
|                // and store it so it is available to the API user
 | |
|                put(name, value);
 | |
|            }
 | |
|         }
 | |
|         
 | |
|         return value;
 | |
|     }
 | |
| }
 |