mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	117474 bhorje: CM-690 virtualization git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.1.N/root@117559 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			104 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| 
 | |
| package org.alfresco.repo.virtual.ref;
 | |
| 
 | |
| import java.util.List;
 | |
| 
 | |
| import org.alfresco.util.Pair;
 | |
| /**
 | |
|  * Custom stringifier for hash encoded strings of {@link Reference}s having the
 | |
|  * protocol set to {@link VirtualProtocol}.
 | |
|  */
 | |
| public class VirtualHashStringifier extends ProtocolHashStringifier
 | |
| {
 | |
|     private static final long serialVersionUID = -252596166306653635L;
 | |
| 
 | |
|     private NumericPathHasher numericPathHasher = new NumericPathHasher();
 | |
| 
 | |
|     public VirtualHashStringifier(HashStore classpathHashStore, Stringifier referenceDispatcher)
 | |
|     {
 | |
|         super(classpathHashStore,
 | |
|               referenceDispatcher);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 
 | |
|      */
 | |
| 
 | |
|     @Override
 | |
|     public String stringify(Reference reference) throws ReferenceEncodingException
 | |
|     {
 | |
|         final Protocol protocol = reference.getProtocol();
 | |
|         if (!Protocols.VIRTUAL.protocol.equals(protocol))
 | |
|         {
 | |
|             throw new ReferenceEncodingException("Unsupported protocol " + protocol + "."
 | |
|                         + Protocols.VIRTUAL.protocol.name + " exoected ");
 | |
|         }
 | |
| 
 | |
|         return VIRTUAL_PROTOCOL_CODE + "-" + stringifyVirtualReference(reference);
 | |
|     }
 | |
| 
 | |
|     protected String stringifyVirtualReference(Reference reference)
 | |
|     {
 | |
|         Resource resource = reference.getResource();
 | |
|         String resourceString = resource.stringify(this);
 | |
| 
 | |
|         List<Parameter> parameters = reference.getParameters();
 | |
| 
 | |
|         ResourceParameter actualNodeParameter = (ResourceParameter) parameters
 | |
|                     .get(VirtualProtocol.ACTUAL_NODE_LOCATION_PARAM_INDEX);
 | |
|         Resource actualNodeResource = actualNodeParameter.getValue();
 | |
|         String actualNodeResourceString = actualNodeResource.stringify(this);
 | |
| 
 | |
|         StringParameter templatePathParameter;
 | |
|         templatePathParameter = (StringParameter) parameters.get(VirtualProtocol.TEMPLATE_PATH_PARAM_INDEX);
 | |
|         String pathString = templatePathParameter.getValue();
 | |
| 
 | |
|         Pair<String, String> pathHash = numericPathHasher.hash(pathString);
 | |
| 
 | |
|         StringBuilder stringifiedPath = new StringBuilder();
 | |
|         String hashed = pathHash.getFirst();
 | |
|         String nonHashed = pathHash.getSecond();
 | |
| 
 | |
|         if (nonHashed == null)
 | |
|         {
 | |
|             stringifiedPath.append(HASHED_NUMERIC_PATH_CODE);
 | |
|             stringifiedPath.append(hashed);
 | |
|         }
 | |
|         else if (hashed == null)
 | |
|         {
 | |
|             if (nonHashed.isEmpty())
 | |
|             {
 | |
|                 stringifiedPath.append(NUMERIC_ROOT_PATH_CODE);
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 stringifiedPath.append(NUMERIC_PATH_CODE);
 | |
|                 stringifiedPath.append(nonHashed);
 | |
|             }
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             stringifiedPath.append(MIXED_NUMERIC_PATH_CODE);
 | |
|             stringifiedPath.append(hashed);
 | |
|             stringifiedPath.append("-");
 | |
|             stringifiedPath.append(nonHashed);
 | |
|         }
 | |
| 
 | |
| //        String delimitedPathString;
 | |
| //        if ("/".equals(pathString.trim()))
 | |
| //        {
 | |
| //            delimitedPathString = "";
 | |
| //        }
 | |
| //        else
 | |
| //        {
 | |
| //            delimitedPathString = pathString.replace('/',
 | |
| //                                                     '-');
 | |
| //        }
 | |
| 
 | |
|         String parametersString = actualNodeResourceString +"-"+ stringifiedPath.toString();
 | |
| 
 | |
|         return resourceString + "-" + parametersString;
 | |
|     }
 | |
| 
 | |
| }
 |