mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-10-08 14:51:49 +00:00
CM-690 virtualization
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@117474 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -0,0 +1,103 @@
|
||||
|
||||
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;
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user