mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
Merged V3.2 to HEAD
16971: Merged V3.1 to V3.2 14282: (RECORD ONLY) Updated version to 3.1.1 14565: (RECORD ONLY) Updated version to include revision number (x.y.z) 14848: (RECORD ONLY) Updated version number 15029: (RECORD ONLY) ETHREEOH-441 and ETHREEOH-1862 Exceptions in server when certain PDFs are uploaded. - Probably done already without merge info - Renamed source zip to help tracking 15985: ETHREEOH-2292: Deployment failure in case of IPv6 on Win 2k8 16164: Fixed ETHREEOH-2690: JGroups TCP doesn't bind to specified address 16240: (RECORD ONLY) Fix typos in installer 16726: Fix ETHREEOH-2677 - user usages (when taking ownership) 16745: Fix ETHREEOH-2991 - Deployment exception, unable to deploy - when deploying a manual snapshot with a stale file 16771: (RECORD ONLY) Fix to ETHREEOH-441 - Probably merged without merge info 16822: Merged DEV/BELARUS/V3.1 to V3.1 16753: ETHREEOH-1951: when versionable aspect is active, using the Microsoft Word option ... 16825: Fixed ETHREEOH-803: Incorrect mimetype is displayed for .pps and .pot files 16862: Fix for ETHREEOH-801 Fail to extract some kind of PDF file metadata - Resolved merge by prefering merged-in fix 16880: Merged V2.2 to V3.1 13966: (record only) Updated to use ALF-BINARIES version of installjammer 14340: (record only) Fix so deployment installers build 14719: (record only) Tweaks to AMP 15153: (record only) Fix ETWOTWO-1264 - PHP integration 15287: Fixed ETWOTWO-989: MS Sql server upgrade from 2.1.6 failed 15351: ETWOTWO-1345 (script not matching patch ID) 16928: Fixed shutdown: Task threads are now daemon threads 16986: Merged V3.1 to V3.2 16932: Moved Lucene ResultSet prefetch code to use NodeBulkLoader (backed by common code in Node DAO) 16945: (RECORD ONLY) Merged V3.2 to V3.1 16931: Fixed build unit test path for recent Chiba lib change 16957: Removed Hibernate event listener after 3.2.3 CGLib fixes 16959: Applied fix for ETHREEOH-2121: ContentUtils.getContentAsString does not pass JSESSIONID into the request 16961: (RECORD ONLY) Updated db settings in configs 16964: (RECORD ONLY) Merged V3.2 to V3.1 16308: ETHREEOH-2833: The Content rule with 'Items with specific text value in property' condition can't be created. 16968: Fixed ETHREEOH-2120: Recently Modified Documents Dashlet failed to load after a big upload 16983: Build fix: avoid queries for parent assocs if no nodes were found during child node in caching 16991: Merge V3.1 to V3.2 15136: (RECORD ONLY) : changes have already been merged. MERGE 2.2 to 3.1 14985 - ETWOTWO-1174 - Preview of protected PDFs results in an error 14305 - ETWOTWO-951 - contribution 14601 - ETWOTWO-1236 - Make FSR deployment case sensitive. 17022: MT - fix fallout from r16924 - add inbound collection support to MT node service interceptor (caught by MultiTDemoTest.testCreateGroups) 17023: Fixed parentAssocCache bug when adding assocs against an empty cache git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@17025 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -122,31 +122,7 @@ public class MultiTNodeServiceInterceptor extends DelegatingIntroductionIntercep
|
||||
for (int i = 0; i < args.length; i++)
|
||||
{
|
||||
Object arg = args[i];
|
||||
Object newArg = arg;
|
||||
if (arg == null)
|
||||
{
|
||||
// No conversion possible
|
||||
}
|
||||
if (arg instanceof StoreRef)
|
||||
{
|
||||
StoreRef ref = (StoreRef) arg;
|
||||
newArg = tenantService.getName(ref);
|
||||
}
|
||||
else if (arg instanceof NodeRef)
|
||||
{
|
||||
NodeRef ref = (NodeRef) arg;
|
||||
newArg = tenantService.getName(ref);
|
||||
}
|
||||
else if (arg instanceof ChildAssociationRef)
|
||||
{
|
||||
ChildAssociationRef ref = (ChildAssociationRef) arg;
|
||||
newArg = tenantService.getName(ref);
|
||||
}
|
||||
else if (arg instanceof AssociationRef)
|
||||
{
|
||||
AssociationRef ref = (AssociationRef) arg;
|
||||
newArg = tenantService.getName(ref);
|
||||
}
|
||||
Object newArg = convertInboundValue(arg);
|
||||
|
||||
if (logger.isDebugEnabled())
|
||||
{
|
||||
@@ -258,8 +234,9 @@ public class MultiTNodeServiceInterceptor extends DelegatingIntroductionIntercep
|
||||
}
|
||||
|
||||
/**
|
||||
* Convert outbound collection to spoofed (no tenant prefix) values.
|
||||
* Convert outbound collection to spoofed (ie. without tenant prefix) values.
|
||||
*/
|
||||
@SuppressWarnings("unchecked")
|
||||
private Collection<Object> convertOutboundValues(Collection<Object> rawValues)
|
||||
{
|
||||
/*
|
||||
@@ -289,7 +266,7 @@ public class MultiTNodeServiceInterceptor extends DelegatingIntroductionIntercep
|
||||
}
|
||||
|
||||
/**
|
||||
* Convert outbound single value to spoofed (no tenant prefix) value.
|
||||
* Convert outbound single value to spoofed (ie. without tenant prefix) value.
|
||||
*/
|
||||
@SuppressWarnings("unchecked")
|
||||
private Object convertOutboundValue(Object rawValue)
|
||||
@@ -299,10 +276,10 @@ public class MultiTNodeServiceInterceptor extends DelegatingIntroductionIntercep
|
||||
return null;
|
||||
}
|
||||
|
||||
// Deal with collections
|
||||
Object value = rawValue;
|
||||
if (rawValue instanceof Collection)
|
||||
{
|
||||
// Deal with collections
|
||||
value = convertOutboundValues((Collection<Object>)rawValue);
|
||||
}
|
||||
else if (rawValue instanceof StoreRef)
|
||||
@@ -344,4 +321,93 @@ public class MultiTNodeServiceInterceptor extends DelegatingIntroductionIntercep
|
||||
// Done
|
||||
return value;
|
||||
}
|
||||
|
||||
/**
|
||||
* Convert inbound collection to non-spoofed (ie. with tenant prefix) values.
|
||||
*/
|
||||
@SuppressWarnings("unchecked")
|
||||
private Collection<Object> convertInboundValues(Collection<Object> rawValues)
|
||||
{
|
||||
/*
|
||||
* Return types can be Lists or Sets, so cater for both.
|
||||
*/
|
||||
final Collection<Object> convertedValues;
|
||||
if (rawValues instanceof List)
|
||||
{
|
||||
convertedValues = new ArrayList<Object>(rawValues.size());
|
||||
}
|
||||
else if (rawValues instanceof Set)
|
||||
{
|
||||
convertedValues = new HashSet<Object>(rawValues.size(), 1.0F);
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new IllegalArgumentException("Interceptor can only handle List and Set return types.");
|
||||
}
|
||||
|
||||
for (Object rawValue : rawValues)
|
||||
{
|
||||
Object convertedValue = convertInboundValue(rawValue);
|
||||
convertedValues.add(convertedValue);
|
||||
}
|
||||
// Done
|
||||
return convertedValues;
|
||||
}
|
||||
|
||||
/**
|
||||
* Convert outbound single value to non-spoofed (ie. with tenant prefix) value.
|
||||
*/
|
||||
@SuppressWarnings("unchecked")
|
||||
private Object convertInboundValue(Object rawValue)
|
||||
{
|
||||
if (rawValue == null)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
Object value = rawValue;
|
||||
if (rawValue instanceof StoreRef)
|
||||
{
|
||||
StoreRef ref = (StoreRef) rawValue;
|
||||
value = tenantService.getName(ref);
|
||||
}
|
||||
else if (rawValue instanceof NodeRef)
|
||||
{
|
||||
NodeRef ref = (NodeRef) rawValue;
|
||||
value = tenantService.getName(ref);
|
||||
}
|
||||
else if (rawValue instanceof ChildAssociationRef)
|
||||
{
|
||||
ChildAssociationRef ref = (ChildAssociationRef) rawValue;
|
||||
value = tenantService.getName(ref);
|
||||
}
|
||||
else if (rawValue instanceof AssociationRef)
|
||||
{
|
||||
AssociationRef ref = (AssociationRef) rawValue;
|
||||
value = tenantService.getName(ref);
|
||||
}
|
||||
else if (rawValue instanceof Collection)
|
||||
{
|
||||
// Deal with collections
|
||||
value = convertInboundValues((Collection<Object>)rawValue);
|
||||
}
|
||||
else if (rawValue instanceof Path)
|
||||
{
|
||||
Path ref = (Path)rawValue;
|
||||
Path inboundPath = new Path();
|
||||
Iterator<Path.Element> itr = ref.iterator();
|
||||
while (itr.hasNext())
|
||||
{
|
||||
Path.Element pathElement = itr.next();
|
||||
if (pathElement instanceof Path.ChildAssocElement)
|
||||
{
|
||||
pathElement = new Path.ChildAssocElement(tenantService.getName(((Path.ChildAssocElement)pathElement).getRef()));
|
||||
}
|
||||
inboundPath.append(pathElement);
|
||||
}
|
||||
value = inboundPath;
|
||||
}
|
||||
// Done
|
||||
return value;
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user