mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	Compare commits
	
		
			55 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | e779057f23 | ||
|  | 49ee9f8f29 | ||
|  | 213886cedd | ||
|  | eceb7c0eb3 | ||
|  | 8cd46d4585 | ||
|  | 11d71e1941 | ||
|  | 353d50a35c | ||
|  | 2daafc711d | ||
|  | dfa94fbe21 | ||
|  | 4a93aec66b | ||
|  | 3f0bbc9844 | ||
|  | cb9ad42101 | ||
|  | ca385b3bbc | ||
|  | 19c1582f1e | ||
|  | 06a918b082 | ||
|  | f543de9959 | ||
|  | 8124279e6a | ||
|  | 4281fd5b2d | ||
|  | d10d88306b | ||
|  | 1d7a37cd8c | ||
|  | 4bcb795452 | ||
|  | 393b064918 | ||
|  | f741f2ca45 | ||
|  | ef676f11e4 | ||
|  | 478c81fee3 | ||
|  | cf9cc8042d | ||
|  | 8d790ed1cb | ||
|  | 87c7bd2877 | ||
|  | 9125f889b0 | ||
|  | 2fb74d2691 | ||
|  | d671162dae | ||
|  | bfaa629da7 | ||
|  | 719d73a558 | ||
|  | a2aa867f3f | ||
|  | 8d745c536a | ||
|  | b0f4c21ae3 | ||
|  | 72494e34fa | ||
|  | 792b7024ea | ||
|  | 40a1371f0d | ||
|  | c22c47e63f | ||
|  | 232299d42d | ||
|  | aca7969849 | ||
|  | 4ab2bbd3d6 | ||
|  | f68f02372d | ||
|  | 9b0eedc8c1 | ||
|  | f164dedcee | ||
|  | 9cdaa0a265 | ||
|  | ef034e596b | ||
|  | 1251081a69 | ||
|  | 2d16eb6f42 | ||
|  | e577134875 | ||
|  | 510eadd565 | ||
|  | 187646895c | ||
|  | f9515e336f | ||
|  | 828dd20576 | 
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-community-repo-amps</artifactId> | ||||
|       <version>23.6.0.20</version> | ||||
|       <version>23.7.0.3</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-community-parent</artifactId> | ||||
|       <version>23.6.0.20</version> | ||||
|       <version>23.7.0.3</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-automation-community-repo</artifactId> | ||||
|       <version>23.6.0.20</version> | ||||
|       <version>23.7.0.3</version> | ||||
|    </parent> | ||||
|  | ||||
|    <build> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-community-parent</artifactId> | ||||
|       <version>23.6.0.20</version> | ||||
|       <version>23.7.0.3</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -1,3 +1,3 @@ | ||||
| SOLR6_TAG=2.0.13 | ||||
| SOLR6_TAG=2.0.17 | ||||
| POSTGRES_TAG=15.4 | ||||
| ACTIVEMQ_TAG=5.18.3-jre17-rockylinux8 | ||||
|   | ||||
| @@ -15,6 +15,13 @@ | ||||
|       <parameter property="end" jdbcType="BIGINT" javaType="java.lang.Long"/> | ||||
|    </parameterMap> | ||||
|  | ||||
|    <parameterMap id="parameter_NodeIdsWhichReferenceContentUrl" type="map"> | ||||
|       <parameter property="contentUrlShort" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|       <parameter property="contentUrlCrc" jdbcType="BIGINT" javaType="java.lang.Long"/> | ||||
|       <parameter property="localName" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|       <parameter property="uri" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|    </parameterMap> | ||||
|  | ||||
|    <resultMap id="result_NodeRefEntity" type="org.alfresco.module.org_alfresco_module_rm.query.NodeRefEntity"> | ||||
|       <result property="row" column="row" jdbcType="BIGINT" javaType="java.lang.Long"/> | ||||
|       <result property="protocol" column="protocol" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
| @@ -55,18 +62,21 @@ | ||||
|  | ||||
|    <!-- Get list of node ids which reference given content url --> | ||||
|    <select id="select_NodeIdsWhichReferenceContentUrl" | ||||
|            parameterType="ContentUrl" | ||||
|            parameterMap="parameter_NodeIdsWhichReferenceContentUrl" | ||||
|            resultMap="result_NodeIds"> | ||||
|       select | ||||
|          p.node_id | ||||
|       from | ||||
|          alf_content_url cu | ||||
|       LEFT OUTER JOIN alf_content_data cd ON (cd.content_url_id = cu.id) | ||||
|       LEFT OUTER JOIN alf_node_properties p ON (p.long_value = cd.id) | ||||
|       WHERE | ||||
|          content_url_short = #{contentUrlShort} and | ||||
|          content_url_crc = #{contentUrlCrc} | ||||
|  | ||||
|          left outer join alf_content_data cd ON (cd.content_url_id = cu.id) | ||||
|          left outer join alf_node_properties p ON (p.long_value = cd.id) | ||||
|          left outer join alf_qname q ON (q.id = p.qname_id) | ||||
|          left outer join alf_namespace n ON (n.id = q.ns_id) | ||||
|       where | ||||
|          cu.content_url_short = ? and | ||||
|          cu.content_url_crc = ? and | ||||
|          q.local_name = ? and | ||||
|          n.uri = ? | ||||
|    </select> | ||||
|  | ||||
|    <select id="select_RecordFoldersWithSchedules" | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-community-repo-parent</artifactId> | ||||
|       <version>23.6.0.20</version> | ||||
|       <version>23.7.0.3</version> | ||||
|    </parent> | ||||
|  | ||||
|    <properties> | ||||
|   | ||||
| @@ -27,7 +27,6 @@ | ||||
|  | ||||
| package org.alfresco.module.org_alfresco_module_rm.query; | ||||
|  | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.Collections; | ||||
| import java.util.HashMap; | ||||
| @@ -36,6 +35,11 @@ import java.util.List; | ||||
| import java.util.Map; | ||||
| import java.util.Set; | ||||
|  | ||||
| import org.apache.commons.logging.Log; | ||||
| import org.apache.commons.logging.LogFactory; | ||||
| import org.mybatis.spring.SqlSessionTemplate; | ||||
|  | ||||
| import org.alfresco.model.ContentModel; | ||||
| import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel; | ||||
| import org.alfresco.repo.domain.contentdata.ContentUrlEntity; | ||||
| import org.alfresco.repo.domain.node.NodeDAO; | ||||
| @@ -47,9 +51,6 @@ import org.alfresco.service.cmr.repository.InvalidNodeRefException; | ||||
| import org.alfresco.service.cmr.repository.NodeRef; | ||||
| import org.alfresco.service.namespace.QName; | ||||
| import org.alfresco.util.Pair; | ||||
| import org.apache.commons.logging.Log; | ||||
| import org.apache.commons.logging.LogFactory; | ||||
| import org.mybatis.spring.SqlSessionTemplate; | ||||
|  | ||||
| /** | ||||
|  * Records management query DAO implementation | ||||
| @@ -89,7 +90,8 @@ public class RecordsManagementQueryDAOImpl implements RecordsManagementQueryDAO, | ||||
|     protected TenantService tenantService; | ||||
|  | ||||
|     /** | ||||
|      * @param sqlSessionTemplate SQL session template | ||||
|      * @param sqlSessionTemplate | ||||
|      *            SQL session template | ||||
|      */ | ||||
|     public final void setSqlSessionTemplate(SqlSessionTemplate sqlSessionTemplate) | ||||
|     { | ||||
| @@ -97,7 +99,8 @@ public class RecordsManagementQueryDAOImpl implements RecordsManagementQueryDAO, | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param qnameDAO qname DAO | ||||
|      * @param qnameDAO | ||||
|      *            qname DAO | ||||
|      */ | ||||
|     public final void setQnameDAO(QNameDAO qnameDAO) | ||||
|     { | ||||
| @@ -173,8 +176,9 @@ public class RecordsManagementQueryDAOImpl implements RecordsManagementQueryDAO, | ||||
|     /** | ||||
|      * Get a set of node reference which reference the provided content URL | ||||
|      * | ||||
|      * @param String contentUrl	content URL | ||||
|      * @return Set<NodeRef>	set of nodes that reference the provided content URL | ||||
|      * @param String | ||||
|      *            contentUrl content URL | ||||
|      * @return Set<NodeRef> set of nodes that reference the provided content URL | ||||
|      */ | ||||
|     @Override | ||||
|     public Set<NodeRef> getNodeRefsWhichReferenceContentUrl(String contentUrl) | ||||
| @@ -188,13 +192,19 @@ public class RecordsManagementQueryDAOImpl implements RecordsManagementQueryDAO, | ||||
|         ContentUrlEntity contentUrlEntity = new ContentUrlEntity(); | ||||
|         contentUrlEntity.setContentUrl(contentUrl.toLowerCase()); | ||||
|  | ||||
|         Map<String, Object> params = new HashMap<>(4); | ||||
|         params.put("contentUrlShort", contentUrlEntity.getContentUrlShort()); | ||||
|         params.put("contentUrlCrc", contentUrlEntity.getContentUrlCrc()); | ||||
|         params.put("localName", ContentModel.PROP_CONTENT.getLocalName()); | ||||
|         params.put("uri", ContentModel.PROP_CONTENT.getNamespaceURI()); | ||||
|  | ||||
|         if (logger.isDebugEnabled()) | ||||
|         { | ||||
|             logger.debug("Executing query " + SELECT_NODE_IDS_WHICH_REFERENCE_CONTENT_URL); | ||||
|         } | ||||
|  | ||||
|         // Get all the node ids which reference the given content url | ||||
|         List<Long> nodeIds = template.selectList(SELECT_NODE_IDS_WHICH_REFERENCE_CONTENT_URL, contentUrlEntity); | ||||
|         List<Long> nodeIds = template.selectList(SELECT_NODE_IDS_WHICH_REFERENCE_CONTENT_URL, params); | ||||
|  | ||||
|         if (logger.isDebugEnabled()) | ||||
|         { | ||||
| @@ -224,7 +234,7 @@ public class RecordsManagementQueryDAOImpl implements RecordsManagementQueryDAO, | ||||
|                     if (logger.isDebugEnabled()) | ||||
|                     { | ||||
|                         logMessage.append(nodeRefToAdd) | ||||
|                             .append(" (from version)"); | ||||
|                                 .append(" (from version)"); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
| @@ -232,7 +242,7 @@ public class RecordsManagementQueryDAOImpl implements RecordsManagementQueryDAO, | ||||
|                 else | ||||
|                 { | ||||
|                     nodeRefToAdd = nodeDAO.getNodeIdStatus(nodeId) | ||||
|                         .getNodeRef(); | ||||
|                             .getNodeRef(); | ||||
|                     if (logger.isDebugEnabled()) | ||||
|                     { | ||||
|                         logMessage.append(nodeRefToAdd); | ||||
| @@ -266,9 +276,9 @@ public class RecordsManagementQueryDAOImpl implements RecordsManagementQueryDAO, | ||||
|     { | ||||
|         Map<String, Object> params = new HashMap<>(2); | ||||
|         params.put("processed", qnameDAO.getQName(ASPECT_DISPOSITION_PROCESSED) | ||||
|             .getFirst()); | ||||
|                 .getFirst()); | ||||
|         params.put("folderQnameId", qnameDAO.getQName(TYPE_RECORD_FOLDER) | ||||
|             .getFirst()); | ||||
|                 .getFirst()); | ||||
|         params.put("start", start); | ||||
|         params.put("end", end); | ||||
|  | ||||
| @@ -280,7 +290,7 @@ public class RecordsManagementQueryDAOImpl implements RecordsManagementQueryDAO, | ||||
|         for (NodeRefEntity nodeRefEntity : entities) | ||||
|         { | ||||
|             results.add( | ||||
|                 new NodeRef(nodeRefEntity.getProtocol(), nodeRefEntity.getIdentifier(), nodeRefEntity.getUuid())); | ||||
|                     new NodeRef(nodeRefEntity.getProtocol(), nodeRefEntity.getIdentifier(), nodeRefEntity.getUuid())); | ||||
|         } | ||||
|  | ||||
|         return results; | ||||
| @@ -289,7 +299,8 @@ public class RecordsManagementQueryDAOImpl implements RecordsManagementQueryDAO, | ||||
|     /** | ||||
|      * @see org.alfresco.module.org_alfresco_module_rm.query.RecordsManagementQueryDAO#getPropertyStringValueEntity(String stringValue) | ||||
|      */ | ||||
|     public PropertyStringValueEntity getPropertyStringValueEntity(String stringValue){ | ||||
|     public PropertyStringValueEntity getPropertyStringValueEntity(String stringValue) | ||||
|     { | ||||
|  | ||||
|         PropertyStringValueEntity propertyStringValueEntity = new PropertyStringValueEntity(); | ||||
|         propertyStringValueEntity.setValue(stringValue); | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|  | ||||
| # Version label | ||||
| version.major=23 | ||||
| version.minor=6 | ||||
| version.minor=7 | ||||
| version.revision=0 | ||||
| version.label= | ||||
|  | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-governance-services-community-repo-parent</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <build> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <modules> | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-amps</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-community-repo</artifactId> | ||||
|       <version>23.6.0.20</version> | ||||
|       <version>23.7.0.3</version> | ||||
|    </parent> | ||||
|  | ||||
|    <dependencies> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <dependencies> | ||||
|   | ||||
| @@ -9,6 +9,6 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-packaging</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
| </project> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-packaging</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <modules> | ||||
|   | ||||
| @@ -1,3 +1,3 @@ | ||||
| SOLR6_TAG=2.0.13 | ||||
| SOLR6_TAG=2.0.17 | ||||
| POSTGRES_TAG=15.4 | ||||
| ACTIVEMQ_TAG=5.18.3-jre17-rockylinux8 | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-packaging</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <organization> | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <developers> | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <developers> | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <developers> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-packaging</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|   | ||||
							
								
								
									
										32
									
								
								pom.xml
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								pom.xml
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ | ||||
| <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
|     <artifactId>alfresco-community-repo</artifactId> | ||||
|     <version>23.6.0.20</version> | ||||
|     <version>23.7.0.3</version> | ||||
|     <packaging>pom</packaging> | ||||
|     <name>Alfresco Community Repo Parent</name> | ||||
|  | ||||
| @@ -24,7 +24,7 @@ | ||||
|  | ||||
|     <properties> | ||||
|         <acs.version.major>23</acs.version.major> | ||||
|         <acs.version.minor>6</acs.version.minor> | ||||
|         <acs.version.minor>7</acs.version.minor> | ||||
|         <acs.version.revision>0</acs.version.revision> | ||||
|         <acs.version.label /> | ||||
|         <amp.min.version>${acs.version.major}.0.0</amp.min.version> | ||||
| @@ -51,14 +51,14 @@ | ||||
|         <dependency.alfresco-server-root.version>7.0.1</dependency.alfresco-server-root.version> | ||||
|         <dependency.activiti-engine.version>5.23.0</dependency.activiti-engine.version> | ||||
|         <dependency.activiti.version>5.23.0</dependency.activiti.version> | ||||
|         <dependency.alfresco-transform-core.version>5.2.2-A.1</dependency.alfresco-transform-core.version> | ||||
|         <dependency.alfresco-transform-service.version>4.2.2-A.1</dependency.alfresco-transform-service.version> | ||||
|         <dependency.alfresco-transform-core.version>5.2.2</dependency.alfresco-transform-core.version> | ||||
|         <dependency.alfresco-transform-service.version>4.2.2</dependency.alfresco-transform-service.version> | ||||
|         <dependency.alfresco-greenmail.version>7.0</dependency.alfresco-greenmail.version> | ||||
|         <dependency.acs-event-model.version>0.0.33</dependency.acs-event-model.version> | ||||
|  | ||||
|         <dependency.aspectj.version>1.9.22.1</dependency.aspectj.version> | ||||
|         <dependency.spring.version>6.2.8</dependency.spring.version> | ||||
|         <dependency.spring-security.version>6.3.9</dependency.spring-security.version> | ||||
|         <dependency.spring.version>6.2.11</dependency.spring.version> | ||||
|         <dependency.spring-security.version>6.4.11</dependency.spring-security.version> | ||||
|         <dependency.antlr.version>3.5.3</dependency.antlr.version> | ||||
|         <dependency.jackson.version>2.17.2</dependency.jackson.version> | ||||
|         <dependency.cxf.version>4.1.2</dependency.cxf.version> | ||||
| @@ -81,7 +81,7 @@ | ||||
|         <dependency.slf4j.version>2.0.16</dependency.slf4j.version> | ||||
|         <dependency.log4j.version>2.23.1</dependency.log4j.version> | ||||
|         <dependency.groovy.version>3.0.22</dependency.groovy.version> | ||||
|         <dependency.tika.version>2.9.2</dependency.tika.version> | ||||
|         <dependency.tika.version>3.2.3</dependency.tika.version> | ||||
|         <dependency.truezip.version>7.7.10</dependency.truezip.version> | ||||
|         <dependency.poi.version>5.4.1</dependency.poi.version> | ||||
|         <dependency.jboss.logging.version>3.5.0.Final</dependency.jboss.logging.version> | ||||
| @@ -113,7 +113,7 @@ | ||||
|         <dependency.jakarta-json-path.version>2.9.0</dependency.jakarta-json-path.version> | ||||
|         <dependency.json-smart.version>2.5.2</dependency.json-smart.version> | ||||
|         <alfresco.googledrive.version>4.1.0</alfresco.googledrive.version> | ||||
|         <alfresco.aos-module.version>3.3.0</alfresco.aos-module.version> | ||||
|         <alfresco.aos-module.version>3.4.0</alfresco.aos-module.version> | ||||
|         <alfresco.api-explorer.version>23.4.0</alfresco.api-explorer.version> <!-- Also in alfresco-enterprise-share --> | ||||
|  | ||||
|         <alfresco.maven-plugin.version>2.2.0</alfresco.maven-plugin.version> | ||||
| @@ -154,7 +154,7 @@ | ||||
|         <connection>scm:git:https://github.com/Alfresco/alfresco-community-repo.git</connection> | ||||
|         <developerConnection>scm:git:https://github.com/Alfresco/alfresco-community-repo.git</developerConnection> | ||||
|         <url>https://github.com/Alfresco/alfresco-community-repo</url> | ||||
|         <tag>23.6.0.20</tag> | ||||
|         <tag>23.7.0.3</tag> | ||||
|     </scm> | ||||
|  | ||||
|     <distributionManagement> | ||||
| @@ -170,6 +170,12 @@ | ||||
|  | ||||
|     <dependencyManagement> | ||||
|         <dependencies> | ||||
|             <!-- v1.10 has 0BSD license it must be consulted with Legal --> | ||||
|             <dependency> | ||||
|                 <groupId>org.tukaani</groupId> | ||||
|                 <artifactId>xz</artifactId> | ||||
|                 <version>1.9</version> | ||||
|             </dependency> | ||||
|             <!-- Jakarta... --> | ||||
|             <dependency> | ||||
|                 <groupId>jakarta.xml.bind</groupId> | ||||
| @@ -1132,16 +1138,10 @@ | ||||
|                                             <exclude>jakarta.xml.soap:jakarta.xml.soap-api:(, 2.0.1)</exclude> | ||||
|                                             <exclude>jakarta.jws:jakarta.jws-api:(, 3.0.0)</exclude> | ||||
| <!--                                            Enforce ban bouncycastle dependencies other than specified under <includes> section--> | ||||
|                                             <exclude>org.bouncycastle</exclude> | ||||
|                                             <exclude>org.bouncycastle:(,1.81)</exclude> | ||||
| <!--                                            Enforce one version of Jaxb--> | ||||
|                                             <exclude>com.sun.xml.bind</exclude> | ||||
|                                         </excludes> | ||||
|                                         <includes> | ||||
|                                             <include>org.bouncycastle:bcprov-jdk18on:[1.78.1,)</include> | ||||
|                                             <include>org.bouncycastle:bcmail-jdk18on:[1.78.1,)</include> | ||||
|                                             <include>org.bouncycastle:bcpkix-jdk18on:[1.78.1,)</include> | ||||
|                                             <include>org.bouncycastle:bcutil-jdk18on:[1.78.1,)</include> | ||||
|                                         </includes> | ||||
|                                     </bannedDependencies> | ||||
|                                 </rules> | ||||
|                                 <fail>true</fail> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <dependencies> | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|  * #%L | ||||
|  * Alfresco Remote API | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2016 Alfresco Software Limited | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software.  | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of  | ||||
| @@ -31,6 +31,14 @@ import java.util.HashMap; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
|  | ||||
| import org.apache.commons.lang3.StringUtils; | ||||
| import org.json.simple.JSONObject; | ||||
| import org.owasp.html.PolicyFactory; | ||||
| import org.owasp.html.Sanitizers; | ||||
| import org.springframework.extensions.webscripts.Cache; | ||||
| import org.springframework.extensions.webscripts.Status; | ||||
| import org.springframework.extensions.webscripts.WebScriptRequest; | ||||
|  | ||||
| import org.alfresco.model.ContentModel; | ||||
| import org.alfresco.model.ForumModel; | ||||
| import org.alfresco.repo.content.MimetypeMap; | ||||
| @@ -44,10 +52,6 @@ import org.alfresco.service.cmr.security.PermissionService; | ||||
| import org.alfresco.service.namespace.NamespaceService; | ||||
| import org.alfresco.service.namespace.QName; | ||||
| import org.alfresco.service.namespace.RegexQNamePattern; | ||||
| import org.json.simple.JSONObject; | ||||
| import org.springframework.extensions.webscripts.Cache; | ||||
| import org.springframework.extensions.webscripts.Status; | ||||
| import org.springframework.extensions.webscripts.WebScriptRequest; | ||||
|  | ||||
| /** | ||||
|  * This class is the controller for the comments.post web script. | ||||
| @@ -58,7 +62,7 @@ import org.springframework.extensions.webscripts.WebScriptRequest; | ||||
| public class CommentsPost extends AbstractCommentsWebScript | ||||
| { | ||||
|     /** | ||||
|      *  Overrides AbstractCommentsWebScript to add comment | ||||
|      * Overrides AbstractCommentsWebScript to add comment | ||||
|      */ | ||||
|     @Override | ||||
|     protected Map<String, Object> executeImpl(NodeRef nodeRef, WebScriptRequest req, Status status, Cache cache) | ||||
| @@ -66,6 +70,19 @@ public class CommentsPost extends AbstractCommentsWebScript | ||||
|         // get json object from request | ||||
|         JSONObject json = parseJSON(req); | ||||
|  | ||||
|         // Validating and Sanitizing comment content to prevent XSS | ||||
|         String commentContent = getOrNull(json, "content"); | ||||
|         if (StringUtils.isBlank(commentContent)) | ||||
|         { | ||||
|             throw new IllegalArgumentException("Comment content must not be empty"); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             PolicyFactory policy = Sanitizers.FORMATTING.and(Sanitizers.LINKS); | ||||
|             String safeContent = policy.sanitize(commentContent); | ||||
|             json.replace("content", safeContent); | ||||
|         } | ||||
|  | ||||
|         /* MNT-10231, MNT-9771 fix */ | ||||
|         this.behaviourFilter.disableBehaviour(nodeRef, ContentModel.ASPECT_AUDITABLE); | ||||
|  | ||||
| @@ -135,7 +152,7 @@ public class CommentsPost extends AbstractCommentsWebScript | ||||
|     { | ||||
|         Map<String, Object> result = new HashMap<String, Object>(4, 1.0f); | ||||
|  | ||||
|         String creator = (String)this.nodeService.getProperty(commentNodeRef, ContentModel.PROP_CREATOR); | ||||
|         String creator = (String) this.nodeService.getProperty(commentNodeRef, ContentModel.PROP_CREATOR); | ||||
|  | ||||
|         Serializable created = this.nodeService.getProperty(commentNodeRef, ContentModel.PROP_CREATED); | ||||
|         Serializable modified = this.nodeService.getProperty(commentNodeRef, ContentModel.PROP_MODIFIED); | ||||
| @@ -143,7 +160,7 @@ public class CommentsPost extends AbstractCommentsWebScript | ||||
|         boolean isUpdated = false; | ||||
|         if (created instanceof Date && modified instanceof Date) | ||||
|         { | ||||
|            isUpdated = ((Date)modified).getTime() - ((Date)created).getTime() > 5000; | ||||
|             isUpdated = ((Date) modified).getTime() - ((Date) created).getTime() > 5000; | ||||
|         } | ||||
|  | ||||
|         // TODO refactor v0 Comments API to use CommentService (see ACE-5437) | ||||
| @@ -229,8 +246,7 @@ public class CommentsPost extends AbstractCommentsWebScript | ||||
|      */ | ||||
|     private NodeRef createCommentsFolder(final NodeRef nodeRef) | ||||
|     { | ||||
|         NodeRef commentsFolder = AuthenticationUtil.runAs(new AuthenticationUtil.RunAsWork<NodeRef>() | ||||
|         { | ||||
|         NodeRef commentsFolder = AuthenticationUtil.runAs(new AuthenticationUtil.RunAsWork<NodeRef>() { | ||||
|             public NodeRef doWork() throws Exception | ||||
|             { | ||||
|                 NodeRef commentsFolder = null; | ||||
|   | ||||
| @@ -40,7 +40,6 @@ | ||||
| 		"items": | ||||
| 		[ | ||||
| 		<#list results as row> | ||||
| 			<#if row.item.hasPermission("Read")> | ||||
| 			{ | ||||
| 				"type": "${row.item.typeShort}", | ||||
| 				"parentType": "${row.item.parentTypeShort!""}", | ||||
| @@ -76,7 +75,6 @@ | ||||
| 				"nodeRef": "${row.item.nodeRef}"<#if row.selectable?exists>, | ||||
| 				"selectable" : ${row.selectable?string}</#if> | ||||
| 			}<#if row_has_next>,</#if> | ||||
| 			</#if> | ||||
| 		</#list> | ||||
| 		] | ||||
| 	} | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>23.6.0.20</version> | ||||
|         <version>23.7.0.3</version> | ||||
|     </parent> | ||||
|  | ||||
|     <dependencies> | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -2,7 +2,7 @@ | ||||
|  * #%L | ||||
|  * Alfresco Repository | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2016 Alfresco Software Limited | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software.  | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of  | ||||
| @@ -36,8 +36,7 @@ import org.alfresco.service.cmr.repository.datatype.DefaultTypeConverter; | ||||
| import org.alfresco.service.namespace.QName; | ||||
|  | ||||
| /** | ||||
|  * Class holding properties associated with the <b>sys:referenceable</b> aspect. | ||||
|  * This aspect is common enough to warrant direct inclusion on the <b>Node</b> entity. | ||||
|  * Class holding properties associated with the <b>sys:referenceable</b> aspect. This aspect is common enough to warrant direct inclusion on the <b>Node</b> entity. | ||||
|  *  | ||||
|  * @author Derek Hulley | ||||
|  * @since 3.4 | ||||
| @@ -55,7 +54,7 @@ public class ReferenceablePropertiesEntity | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return          Returns <tt>true</tt> if the property belongs to the <b>sys:referenceable</b> aspect | ||||
|      * @return Returns <tt>true</tt> if the property belongs to the <b>sys:referenceable</b> aspect | ||||
|      */ | ||||
|     public static boolean isReferenceableProperty(QName qname) | ||||
|     { | ||||
| @@ -87,10 +86,8 @@ public class ReferenceablePropertiesEntity | ||||
|     /** | ||||
|      * Adds all {@link ContentModel#ASPECT_REFERENCEABLE referencable} properties. | ||||
|      */ | ||||
|     public static void addReferenceableProperties(Node node, Map<QName, Serializable> properties) | ||||
|     public static void addReferenceableProperties(Long nodeId, NodeRef nodeRef, Map<QName, Serializable> properties) | ||||
|     { | ||||
|         Long nodeId = node.getId(); | ||||
|         NodeRef nodeRef = node.getNodeRef(); | ||||
|         properties.put(ContentModel.PROP_STORE_PROTOCOL, nodeRef.getStoreRef().getProtocol()); | ||||
|         properties.put(ContentModel.PROP_STORE_IDENTIFIER, nodeRef.getStoreRef().getIdentifier()); | ||||
|         properties.put(ContentModel.PROP_NODE_UUID, nodeRef.getId()); | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|  * #%L | ||||
|  * Alfresco Repository | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2023 Alfresco Software Limited | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
| @@ -39,8 +39,10 @@ import org.alfresco.service.namespace.QName; | ||||
| /** | ||||
|  * Encapsulates events occurred in a single transaction. | ||||
|  * | ||||
|  * @param <REF> entity (e.g. node, child association, peer association) reference type | ||||
|  * @param <RES> entity resource type | ||||
|  * @param <REF> | ||||
|  *            entity (e.g. node, child association, peer association) reference type | ||||
|  * @param <RES> | ||||
|  *            entity resource type | ||||
|  */ | ||||
| public abstract class EventConsolidator<REF extends EntityRef, RES extends Resource> | ||||
| { | ||||
| @@ -90,23 +92,31 @@ public abstract class EventConsolidator<REF extends EntityRef, RES extends Resou | ||||
|     /** | ||||
|      * Builds and returns the {@link RepoEvent} instance. | ||||
|      * | ||||
|      * @param eventInfo the object holding the event information | ||||
|      * @param eventInfo | ||||
|      *            the object holding the event information | ||||
|      * @return the {@link RepoEvent} instance | ||||
|      */ | ||||
|     public RepoEvent<DataAttributes<RES>> getRepoEvent(EventInfo eventInfo) | ||||
|     { | ||||
|         final RepoEvent.Builder<DataAttributes<RES>> builder = RepoEvent.builder(); | ||||
|  | ||||
|         configureRepoEventBuilder(builder, eventInfo); | ||||
|  | ||||
|         return builder.build(); | ||||
|     } | ||||
|  | ||||
|     protected void configureRepoEventBuilder(RepoEvent.Builder<DataAttributes<RES>> builder, EventInfo eventInfo) | ||||
|     { | ||||
|         EventType eventType = getDerivedEvent(); | ||||
|  | ||||
|         DataAttributes<RES> eventData = buildEventData(eventInfo, resource, eventType); | ||||
|  | ||||
|         return RepoEvent.<DataAttributes<RES>>builder() | ||||
|             .setId(eventInfo.getId()) | ||||
|             .setSource(eventInfo.getSource()) | ||||
|             .setTime(eventInfo.getTimestamp()) | ||||
|             .setType(eventType.getType()) | ||||
|             .setData(eventData) | ||||
|             .setDataschema(EventJSONSchema.getSchemaV1(eventType)) | ||||
|             .build(); | ||||
|         builder.setId(eventInfo.getId()) | ||||
|                 .setSource(eventInfo.getSource()) | ||||
|                 .setTime(eventInfo.getTimestamp()) | ||||
|                 .setType(eventType.getType()) | ||||
|                 .setData(eventData) | ||||
|                 .setDataschema(EventJSONSchema.getSchemaV1(eventType)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -114,9 +124,9 @@ public abstract class EventConsolidator<REF extends EntityRef, RES extends Resou | ||||
|      */ | ||||
|     protected DataAttributes<RES> buildEventData(EventInfo eventInfo, RES resource, EventType eventType) | ||||
|     { | ||||
|         return EventData.<RES>builder() | ||||
|             .setEventGroupId(eventInfo.getTxnId()) | ||||
|             .setResource(resource) | ||||
|             .build(); | ||||
|         return EventData.<RES> builder() | ||||
|                 .setEventGroupId(eventInfo.getTxnId()) | ||||
|                 .setResource(resource) | ||||
|                 .build(); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|  * #%L | ||||
|  * Alfresco Repository | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2016 Alfresco Software Limited | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software.  | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of  | ||||
| @@ -28,8 +28,10 @@ package org.alfresco.repo.node.getchildren; | ||||
| import java.util.List; | ||||
| import java.util.Set; | ||||
|  | ||||
| import org.alfresco.repo.domain.node.NodeEntity; | ||||
| import org.alfresco.repo.domain.node.AuditablePropertiesEntity; | ||||
| import org.alfresco.repo.domain.node.NodePropertyEntity; | ||||
| import org.alfresco.service.cmr.repository.NodeRef; | ||||
| import org.alfresco.service.cmr.repository.StoreRef; | ||||
|  | ||||
| /** | ||||
|  * Filterable/Sortable Node Entity | ||||
| @@ -42,12 +44,17 @@ import org.alfresco.repo.domain.node.NodePropertyEntity; | ||||
| public class FilterSortNodeEntity | ||||
| { | ||||
|     private Long id; // node id | ||||
|     private String nodeUuid; | ||||
|     private Long typeQNameId; | ||||
|  | ||||
|     private NodeEntity node; | ||||
|     private AuditablePropertiesEntity auditablePropertiesEntity; | ||||
|     private NodePropertyEntity prop1; | ||||
|     private NodePropertyEntity prop2; | ||||
|     private NodePropertyEntity prop3; | ||||
|  | ||||
|     private String storeProtocol; | ||||
|     private String storeIdentifier; | ||||
|  | ||||
|     // Supplemental query-related parameters | ||||
|     private Long parentNodeId; | ||||
|     private Long prop1qnameId; | ||||
| @@ -80,6 +87,26 @@ public class FilterSortNodeEntity | ||||
|         this.id = id; | ||||
|     } | ||||
|  | ||||
|     public String getNodeUuid() | ||||
|     { | ||||
|         return nodeUuid; | ||||
|     } | ||||
|  | ||||
|     public void setNodeUuid(String nodeUuid) | ||||
|     { | ||||
|         this.nodeUuid = nodeUuid; | ||||
|     } | ||||
|  | ||||
|     public Long getTypeQNameId() | ||||
|     { | ||||
|         return typeQNameId; | ||||
|     } | ||||
|  | ||||
|     public void setTypeQNameId(Long typeQNameId) | ||||
|     { | ||||
|         this.typeQNameId = typeQNameId; | ||||
|     } | ||||
|  | ||||
|     public String getPattern() | ||||
|     { | ||||
|         return pattern; | ||||
| @@ -93,22 +120,21 @@ public class FilterSortNodeEntity | ||||
|         do | ||||
|         { | ||||
|             idx = s.indexOf(escapeChar, offset); | ||||
|             if(idx != -1) | ||||
|             if (idx != -1) | ||||
|             { | ||||
|                 sb.append(s.substring(offset, idx)); | ||||
|                 sb.append("\\"); | ||||
|                 sb.append(escapeChar); | ||||
|                 offset = idx + 1; | ||||
|             } | ||||
|         } | ||||
|         while(idx != -1); | ||||
|         } while (idx != -1); | ||||
|         sb.append(s.substring(offset)); | ||||
|         return sb.toString(); | ||||
|     } | ||||
|  | ||||
|     public void setPattern(String pattern) | ||||
|     { | ||||
|         if(pattern != null) | ||||
|         if (pattern != null) | ||||
|         { | ||||
|             // escape the '%' character with '\' (standard SQL escape character) | ||||
|             pattern = escape(pattern, '%'); | ||||
| @@ -137,6 +163,16 @@ public class FilterSortNodeEntity | ||||
|         this.namePropertyQNameId = namePropertyQNameId; | ||||
|     } | ||||
|  | ||||
|     public AuditablePropertiesEntity getAuditablePropertiesEntity() | ||||
|     { | ||||
|         return auditablePropertiesEntity; | ||||
|     } | ||||
|  | ||||
|     public void setAuditablePropertiesEntity(AuditablePropertiesEntity auditablePropertiesEntity) | ||||
|     { | ||||
|         this.auditablePropertiesEntity = auditablePropertiesEntity; | ||||
|     } | ||||
|  | ||||
|     public NodePropertyEntity getProp1() | ||||
|     { | ||||
|         return prop1; | ||||
| @@ -167,14 +203,24 @@ public class FilterSortNodeEntity | ||||
|         this.prop3 = prop3; | ||||
|     } | ||||
|  | ||||
|     public NodeEntity getNode() | ||||
|     public String getStoreProtocol() | ||||
|     { | ||||
|         return node; | ||||
|         return storeProtocol; | ||||
|     } | ||||
|  | ||||
|     public void setNode(NodeEntity childNode) | ||||
|     public void setStoreProtocol(String storeProtocol) | ||||
|     { | ||||
|         this.node = childNode; | ||||
|         this.storeProtocol = storeProtocol; | ||||
|     } | ||||
|  | ||||
|     public String getStoreIdentifier() | ||||
|     { | ||||
|         return storeIdentifier; | ||||
|     } | ||||
|  | ||||
|     public void setStoreIdentifier(String storeIdentifier) | ||||
|     { | ||||
|         this.storeIdentifier = storeIdentifier; | ||||
|     } | ||||
|  | ||||
|     // Supplemental query-related parameters | ||||
| @@ -258,4 +304,9 @@ public class FilterSortNodeEntity | ||||
|     { | ||||
|         this.isPrimary = isPrimary; | ||||
|     } | ||||
|  | ||||
|     public NodeRef createNodeRef() | ||||
|     { | ||||
|         return new NodeRef(new StoreRef(storeProtocol, storeIdentifier), nodeUuid); | ||||
|     } | ||||
| } | ||||
| @@ -2,7 +2,7 @@ | ||||
|  * #%L | ||||
|  * Alfresco Repository | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2016 Alfresco Software Limited | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software.  | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of  | ||||
| @@ -38,13 +38,16 @@ import java.util.List; | ||||
| import java.util.Map; | ||||
| import java.util.Set; | ||||
|  | ||||
| import org.apache.commons.logging.Log; | ||||
| import org.apache.commons.logging.LogFactory; | ||||
| import org.springframework.extensions.surf.util.I18NUtil; | ||||
|  | ||||
| import org.alfresco.error.AlfrescoRuntimeException; | ||||
| import org.alfresco.model.ContentModel; | ||||
| import org.alfresco.query.CannedQueryParameters; | ||||
| import org.alfresco.query.CannedQuerySortDetails; | ||||
| import org.alfresco.query.CannedQuerySortDetails.SortOrder; | ||||
| import org.alfresco.repo.domain.node.AuditablePropertiesEntity; | ||||
| import org.alfresco.repo.domain.node.Node; | ||||
| import org.alfresco.repo.domain.node.NodeDAO; | ||||
| import org.alfresco.repo.domain.node.NodeEntity; | ||||
| import org.alfresco.repo.domain.node.NodePropertyEntity; | ||||
| @@ -69,15 +72,11 @@ import org.alfresco.service.namespace.QName; | ||||
| import org.alfresco.util.AlfrescoCollator; | ||||
| import org.alfresco.util.Pair; | ||||
| import org.alfresco.util.ParameterCheck; | ||||
| import org.apache.commons.logging.Log; | ||||
| import org.apache.commons.logging.LogFactory; | ||||
| import org.springframework.extensions.surf.util.I18NUtil; | ||||
|  | ||||
| /** | ||||
|  * GetChildren canned query | ||||
|  *  | ||||
|  * To get paged list of children of a parent node filtered by child type. | ||||
|  * Also optionally filtered and/or sorted by one or more properties (up to three). | ||||
|  * To get paged list of children of a parent node filtered by child type. Also optionally filtered and/or sorted by one or more properties (up to three). | ||||
|  * | ||||
|  * @author janv | ||||
|  * @since 4.0 | ||||
| @@ -100,7 +99,6 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|  | ||||
|     public static final QName FILTER_QNAME_NODE_IS_PRIMARY = QName.createQName("", "IS_PRIMARY"); | ||||
|  | ||||
|      | ||||
|     private NodeDAO nodeDAO; | ||||
|     private QNameDAO qnameDAO; | ||||
|     private CannedQueryDAO cannedQueryDAO; | ||||
| @@ -135,8 +133,8 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|         } | ||||
|  | ||||
|         // TODO refactor (only apply post query if sorted - as above) | ||||
|         GetChildrenCannedQueryParams paramBean = (GetChildrenCannedQueryParams)params.getParameterBean(); | ||||
|         if ((paramBean.getFilterProps()!= null) && (paramBean.getFilterProps().size() > 0)) | ||||
|         GetChildrenCannedQueryParams paramBean = (GetChildrenCannedQueryParams) params.getParameterBean(); | ||||
|         if ((paramBean.getFilterProps() != null) && (paramBean.getFilterProps().size() > 0)) | ||||
|         { | ||||
|             applyPostQueryPermissions = true; | ||||
|         } | ||||
| @@ -163,7 +161,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|         Long start = (logger.isDebugEnabled() ? System.currentTimeMillis() : null); | ||||
|  | ||||
|         // Get parameters | ||||
|         GetChildrenCannedQueryParams paramBean = (GetChildrenCannedQueryParams)parameters.getParameterBean(); | ||||
|         GetChildrenCannedQueryParams paramBean = (GetChildrenCannedQueryParams) parameters.getParameterBean(); | ||||
|  | ||||
|         // Get parent node | ||||
|         NodeRef parentRef = paramBean.getParentRef(); | ||||
| @@ -192,8 +190,8 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|  | ||||
|         // Get sort details | ||||
|         CannedQuerySortDetails sortDetails = parameters.getSortDetails(); | ||||
|         @SuppressWarnings({ "unchecked", "rawtypes" }) | ||||
|         final List<Pair<QName, SortOrder>> sortPairs = (List)sortDetails.getSortPairs(); | ||||
|         @SuppressWarnings({"unchecked", "rawtypes"}) | ||||
|         final List<Pair<QName, SortOrder>> sortPairs = (List) sortDetails.getSortPairs(); | ||||
|  | ||||
|         if (filterProps.size() > 0) | ||||
|         { | ||||
| @@ -203,9 +201,9 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|             for (FilterProp filter : filterProps) | ||||
|             { | ||||
|                 if ((filter instanceof FilterPropBoolean) && | ||||
|                     ((FilterPropBoolean)filter).getPropName().equals(FILTER_QNAME_NODE_IS_PRIMARY)) | ||||
|                         ((FilterPropBoolean) filter).getPropName().equals(FILTER_QNAME_NODE_IS_PRIMARY)) | ||||
|                 { | ||||
|                     isPrimary = ((FilterPropBoolean)filter).getPropVal(); | ||||
|                     isPrimary = ((FilterPropBoolean) filter).getPropVal(); | ||||
|                     break; | ||||
|                 } | ||||
|                 idx++; | ||||
| @@ -223,17 +221,17 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|         for (Pair<QName, SortOrder> sort : sortPairs) | ||||
|         { | ||||
|             QName sortQName = sort.getFirst(); | ||||
|             if(! sortFilterProps.contains(sortQName)) | ||||
|             if (!sortFilterProps.contains(sortQName)) | ||||
|             { | ||||
|                sortFilterProps.add(sortQName); | ||||
|                 sortFilterProps.add(sortQName); | ||||
|             } | ||||
|         } | ||||
|         for (FilterProp filter : filterProps) | ||||
|         { | ||||
|             QName filterQName = filter.getPropName(); | ||||
|             if(! sortFilterProps.contains(filterQName)) | ||||
|             if (!sortFilterProps.contains(filterQName)) | ||||
|             { | ||||
|                sortFilterProps.add(filterQName); | ||||
|                 sortFilterProps.add(filterQName); | ||||
|             } | ||||
|         } | ||||
|  | ||||
| @@ -241,109 +239,108 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|  | ||||
|         if (filterSortPropCnt > MAX_FILTER_SORT_PROPS) | ||||
|         { | ||||
|             throw new AlfrescoRuntimeException("GetChildren: exceeded maximum number filter/sort properties: (max="+MAX_FILTER_SORT_PROPS+", actual="+filterSortPropCnt); | ||||
|             throw new AlfrescoRuntimeException("GetChildren: exceeded maximum number filter/sort properties: (max=" + MAX_FILTER_SORT_PROPS + ", actual=" + filterSortPropCnt); | ||||
|         } | ||||
|  | ||||
|         filterSortPropCnt = setFilterSortParams(sortFilterProps, params); | ||||
|  | ||||
|          | ||||
|         List<NodeRef> result = new ArrayList<>(0); | ||||
|  | ||||
|         try | ||||
|         { | ||||
| 	        if ((childNodeTypeQNames != null) && (childNodeTypeQNames.size() > 0)) | ||||
| 	        { | ||||
| 	            // Set child node type qnames (additional filter - performed by DB query) | ||||
| 	            Set<Long> childNodeTypeQNameIds = qnameDAO.convertQNamesToIds(childNodeTypeQNames, false); | ||||
| 	            if (childNodeTypeQNameIds.size() > 0) | ||||
| 	            { | ||||
| 	                params.setChildNodeTypeQNameIds(new ArrayList<Long>(childNodeTypeQNameIds)); | ||||
| 	            } | ||||
| 	            else | ||||
| 	            { | ||||
| 	                // short-circuit - return no results - given node type qname(s) do not exist | ||||
| 	                return result; | ||||
| 	            } | ||||
| 	        } | ||||
|             if ((childNodeTypeQNames != null) && (childNodeTypeQNames.size() > 0)) | ||||
|             { | ||||
|                 // Set child node type qnames (additional filter - performed by DB query) | ||||
|                 Set<Long> childNodeTypeQNameIds = qnameDAO.convertQNamesToIds(childNodeTypeQNames, false); | ||||
|                 if (childNodeTypeQNameIds.size() > 0) | ||||
|                 { | ||||
|                     params.setChildNodeTypeQNameIds(new ArrayList<Long>(childNodeTypeQNameIds)); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     // short-circuit - return no results - given node type qname(s) do not exist | ||||
|                     return result; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
| 	        if ((assocTypeQNames != null)  && (assocTypeQNames.size() > 0)) | ||||
| 	        { | ||||
| 	            // Set assoc type qnames (additional filter - performed by DB query) | ||||
| 	            Set<Long> assocTypeQNameIds = qnameDAO.convertQNamesToIds(assocTypeQNames, false); | ||||
| 	            if (assocTypeQNameIds.size() > 0) | ||||
| 	            { | ||||
| 	                params.setAssocTypeQNameIds(assocTypeQNameIds); | ||||
| 	            } | ||||
| 	            else | ||||
| 	            { | ||||
| 	                // short-circuit - return no results - given assoc type qname(s) do not exist | ||||
| 	                return result; | ||||
| 	            } | ||||
| 	        } | ||||
|             if ((assocTypeQNames != null) && (assocTypeQNames.size() > 0)) | ||||
|             { | ||||
|                 // Set assoc type qnames (additional filter - performed by DB query) | ||||
|                 Set<Long> assocTypeQNameIds = qnameDAO.convertQNamesToIds(assocTypeQNames, false); | ||||
|                 if (assocTypeQNameIds.size() > 0) | ||||
|                 { | ||||
|                     params.setAssocTypeQNameIds(assocTypeQNameIds); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     // short-circuit - return no results - given assoc type qname(s) do not exist | ||||
|                     return result; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
| 	        if (pattern != null) | ||||
| 	        { | ||||
| 	            // TODO, check that we should be tied to the content model in this way. Perhaps a configurable property | ||||
| 	            // name against which compare the pattern? | ||||
| 	            Pair<Long, QName> nameQName = qnameDAO.getQName(ContentModel.PROP_NAME); | ||||
| 	            if(nameQName == null) | ||||
| 	            { | ||||
| 	                throw new AlfrescoRuntimeException("Unable to determine qname id of name property"); | ||||
| 	            } | ||||
| 	            params.setNamePropertyQNameId(nameQName.getFirst()); | ||||
| 	            params.setPattern(pattern); | ||||
| 	        } | ||||
|             if (pattern != null) | ||||
|             { | ||||
|                 // TODO, check that we should be tied to the content model in this way. Perhaps a configurable property | ||||
|                 // name against which compare the pattern? | ||||
|                 Pair<Long, QName> nameQName = qnameDAO.getQName(ContentModel.PROP_NAME); | ||||
|                 if (nameQName == null) | ||||
|                 { | ||||
|                     throw new AlfrescoRuntimeException("Unable to determine qname id of name property"); | ||||
|                 } | ||||
|                 params.setNamePropertyQNameId(nameQName.getFirst()); | ||||
|                 params.setPattern(pattern); | ||||
|             } | ||||
|  | ||||
| 	        if (filterSortPropCnt > 0) | ||||
| 	        { | ||||
| 	            // filtered and/or sorted - note: permissions will be applied post query | ||||
| 	            final List<FilterSortNode> children = new ArrayList<FilterSortNode>(100); | ||||
| 	            final FilterSortChildQueryCallback c = getFilterSortChildQuery(children, filterProps, paramBean); | ||||
| 	            FilterSortResultHandler resultHandler = new FilterSortResultHandler(c); | ||||
| 	            cannedQueryDAO.executeQuery(QUERY_NAMESPACE, QUERY_SELECT_GET_CHILDREN_WITH_PROPS, params, 0, Integer.MAX_VALUE, resultHandler); | ||||
| 	            resultHandler.done(); | ||||
|             if (filterSortPropCnt > 0) | ||||
|             { | ||||
|                 // filtered and/or sorted - note: permissions will be applied post query | ||||
|                 final List<FilterSortNode> children = new ArrayList<FilterSortNode>(100); | ||||
|                 final FilterSortChildQueryCallback c = getFilterSortChildQuery(children, filterProps, paramBean); | ||||
|                 FilterSortResultHandler resultHandler = new FilterSortResultHandler(c); | ||||
|                 cannedQueryDAO.executeQuery(QUERY_NAMESPACE, QUERY_SELECT_GET_CHILDREN_WITH_PROPS, params, 0, Integer.MAX_VALUE, resultHandler); | ||||
|                 resultHandler.done(); | ||||
|  | ||||
| 	            if (sortPairs.size() > 0) | ||||
| 	            { | ||||
| 	            	Long startSort = (logger.isDebugEnabled() ? System.currentTimeMillis() : null); | ||||
|                 if (sortPairs.size() > 0) | ||||
|                 { | ||||
|                     Long startSort = (logger.isDebugEnabled() ? System.currentTimeMillis() : null); | ||||
|  | ||||
| 	                // sort | ||||
| 	                Collections.sort(children, new PropComparatorAsc(sortPairs)); | ||||
|                     // sort | ||||
|                     Collections.sort(children, new PropComparatorAsc(sortPairs)); | ||||
|  | ||||
| 	                if (startSort != null) | ||||
| 	                { | ||||
| 	                    logger.debug("Post-query sort: "+children.size()+" in "+(System.currentTimeMillis()-startSort)+" msecs"); | ||||
| 	                } | ||||
| 	            } | ||||
|                     if (startSort != null) | ||||
|                     { | ||||
|                         logger.debug("Post-query sort: " + children.size() + " in " + (System.currentTimeMillis() - startSort) + " msecs"); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
| 	            result = new ArrayList<NodeRef>(children.size()); | ||||
| 	            for (FilterSortNode child : children) | ||||
| 	            { | ||||
| 	                result.add(tenantService.getBaseName(child.getNodeRef())); | ||||
| 	            } | ||||
| 	        } | ||||
| 	        else | ||||
| 	        { | ||||
| 	            // unsorted (apart from any implicit order) - note: permissions are applied during result handling to allow early cutoff | ||||
|                 result = new ArrayList<NodeRef>(children.size()); | ||||
|                 for (FilterSortNode child : children) | ||||
|                 { | ||||
|                     result.add(tenantService.getBaseName(child.getNodeRef())); | ||||
|                 } | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 // unsorted (apart from any implicit order) - note: permissions are applied during result handling to allow early cutoff | ||||
|  | ||||
| 	            final int requestedCount = parameters.getResultsRequired(); | ||||
|                 final int requestedCount = parameters.getResultsRequired(); | ||||
|  | ||||
| 	            final List<NodeRef> rawResult = new ArrayList<NodeRef>(Math.min(1000, requestedCount)); | ||||
| 	            UnsortedChildQueryCallback callback = getUnsortedChildQueryCallback(rawResult, requestedCount, paramBean); | ||||
| 	            UnsortedResultHandler resultHandler = new UnsortedResultHandler(callback); | ||||
| 	            cannedQueryDAO.executeQuery(QUERY_NAMESPACE, QUERY_SELECT_GET_CHILDREN_WITHOUT_PROPS, params, 0, Integer.MAX_VALUE, resultHandler); | ||||
| 	            resultHandler.done(); | ||||
|                 final List<NodeRef> rawResult = new ArrayList<NodeRef>(Math.min(1000, requestedCount)); | ||||
|                 UnsortedChildQueryCallback callback = getUnsortedChildQueryCallback(rawResult, requestedCount, paramBean); | ||||
|                 UnsortedResultHandler resultHandler = new UnsortedResultHandler(callback); | ||||
|                 cannedQueryDAO.executeQuery(QUERY_NAMESPACE, QUERY_SELECT_GET_CHILDREN_WITHOUT_PROPS, params, 0, Integer.MAX_VALUE, resultHandler); | ||||
|                 resultHandler.done(); | ||||
|  | ||||
| 	            // permissions have been applied | ||||
| 	            result = PermissionCheckedValueMixin.create(rawResult); | ||||
| 	        } | ||||
|                 // permissions have been applied | ||||
|                 result = PermissionCheckedValueMixin.create(rawResult); | ||||
|             } | ||||
|         } | ||||
|         finally | ||||
|         { | ||||
| 	        if (start != null) | ||||
| 	        { | ||||
| 	            logger.debug("Base query "+(filterSortPropCnt > 0 ? "(sort=y, perms=n)" : "(sort=n, perms=y)")+": "+result.size()+" in "+(System.currentTimeMillis()-start)+" msecs"); | ||||
| 	        } | ||||
|             if (start != null) | ||||
|             { | ||||
|                 logger.debug("Base query " + (filterSortPropCnt > 0 ? "(sort=y, perms=n)" : "(sort=n, perms=y)") + ": " + result.size() + " in " + (System.currentTimeMillis() - start) + " msecs"); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return result; | ||||
| @@ -385,14 +382,14 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|                     else | ||||
|                     { | ||||
|                         // belts and braces | ||||
|                         throw new AlfrescoRuntimeException("GetChildren: unexpected - cannot set sort parameter: "+cnt); | ||||
|                         throw new AlfrescoRuntimeException("GetChildren: unexpected - cannot set sort parameter: " + cnt); | ||||
|                     } | ||||
|  | ||||
|                     propCnt++; | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     logger.warn("Skipping filter/sort param - cannot find: "+filterSortProp); | ||||
|                     logger.warn("Skipping filter/sort param - cannot find: " + filterSortProp); | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
| @@ -443,7 +440,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|             Object pv1 = null; | ||||
|             Object pv2 = null; | ||||
|  | ||||
|             QName sortPropQName = (QName)sortProps.get(0).getFirst(); | ||||
|             QName sortPropQName = (QName) sortProps.get(0).getFirst(); | ||||
|             boolean sortAscending = (sortProps.get(0).getSecond() == SortOrder.ASCENDING); | ||||
|  | ||||
|             FilterSortNode node1 = node1In; | ||||
| @@ -462,7 +459,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|  | ||||
|             if (pv1 == null) | ||||
|             { | ||||
|                 if(pv2 == null && sortProps.size() > 1) | ||||
|                 if (pv2 == null && sortProps.size() > 1) | ||||
|                 { | ||||
|                     return compareImpl(node1In, node2In, sortProps.subList(1, sortProps.size())); | ||||
|                 } | ||||
| @@ -478,32 +475,32 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|  | ||||
|             if (pv1 instanceof String) | ||||
|             { | ||||
|                 result = collator.compare((String)pv1, (String)pv2); // TODO use collation keys (re: performance) | ||||
|                 result = collator.compare((String) pv1, (String) pv2); // TODO use collation keys (re: performance) | ||||
|             } | ||||
|             else if (pv1 instanceof Date) | ||||
|             { | ||||
|                 result = (((Date)pv1).compareTo((Date)pv2)); | ||||
|                 result = (((Date) pv1).compareTo((Date) pv2)); | ||||
|             } | ||||
|             else if (pv1 instanceof Long) | ||||
|             { | ||||
|                 result = (((Long)pv1).compareTo((Long)pv2)); | ||||
|                 result = (((Long) pv1).compareTo((Long) pv2)); | ||||
|             } | ||||
|             else if (pv1 instanceof Integer) | ||||
|             { | ||||
|                 result = (((Integer)pv1).compareTo((Integer)pv2)); | ||||
|                 result = (((Integer) pv1).compareTo((Integer) pv2)); | ||||
|             } | ||||
|             else if (pv1 instanceof QName) | ||||
|             { | ||||
|                 result = (((QName)pv1).compareTo((QName)pv2)); | ||||
|                 result = (((QName) pv1).compareTo((QName) pv2)); | ||||
|             } | ||||
|             else if (pv1 instanceof Boolean) | ||||
|             { | ||||
|                 result = (((Boolean)pv1).compareTo((Boolean)pv2)); | ||||
|                 result = (((Boolean) pv1).compareTo((Boolean) pv2)); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 // TODO other comparisons | ||||
|                 throw new RuntimeException("Unsupported sort type: "+pv1.getClass().getName()); | ||||
|                 throw new RuntimeException("Unsupported sort type: " + pv1.getClass().getName()); | ||||
|             } | ||||
|  | ||||
|             if ((result == 0) && (sortProps.size() > 1)) | ||||
| @@ -555,68 +552,68 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|             { | ||||
|                 if ((filterProp instanceof FilterPropString) && (propVal instanceof String)) | ||||
|                 { | ||||
|                     String val = (String)propVal; | ||||
|                     String filter = (String)filterProp.getPropVal(); | ||||
|                     String val = (String) propVal; | ||||
|                     String filter = (String) filterProp.getPropVal(); | ||||
|  | ||||
|                     switch ((FilterTypeString)filterProp.getFilterType()) | ||||
|                     switch ((FilterTypeString) filterProp.getFilterType()) | ||||
|                     { | ||||
|                         case STARTSWITH: | ||||
|                             if (val.startsWith(filter)) | ||||
|                             { | ||||
|                                 return true; | ||||
|                             } | ||||
|                     case STARTSWITH: | ||||
|                         if (val.startsWith(filter)) | ||||
|                         { | ||||
|                             return true; | ||||
|                         } | ||||
|                         break; | ||||
|                         case STARTSWITH_IGNORECASE: | ||||
|                             if (val.toLowerCase().startsWith(filter.toLowerCase())) | ||||
|                             { | ||||
|                                 return true; | ||||
|                             } | ||||
|                             break; | ||||
|                         case EQUALS: | ||||
|                             if (val.equals(filter)) | ||||
|                             { | ||||
|                                 return true; | ||||
|                             } | ||||
|                     case STARTSWITH_IGNORECASE: | ||||
|                         if (val.toLowerCase().startsWith(filter.toLowerCase())) | ||||
|                         { | ||||
|                             return true; | ||||
|                         } | ||||
|                         break; | ||||
|                         case EQUALS_IGNORECASE: | ||||
|                             if (val.equalsIgnoreCase(filter)) | ||||
|                             { | ||||
|                                 return true; | ||||
|                             } | ||||
|                             break; | ||||
|                         case ENDSWITH: | ||||
|                             if (val.endsWith(filter)) | ||||
|                             { | ||||
|                                 return true; | ||||
|                             } | ||||
|                             break; | ||||
|                         case ENDSWITH_IGNORECASE: | ||||
|                             if (val.toLowerCase().endsWith(filter.toLowerCase())) | ||||
|                             { | ||||
|                                 return true; | ||||
|                             } | ||||
|                             break; | ||||
|                         case MATCHES: | ||||
|                             if (val.matches(filter)) | ||||
|                             { | ||||
|                                 return true; | ||||
|                             } | ||||
|                             break; | ||||
|                         case MATCHES_IGNORECASE: | ||||
|                             if (val.toLowerCase().matches(filter.toLowerCase())) | ||||
|                             { | ||||
|                                 return true; | ||||
|                             } | ||||
|                             break; | ||||
|                         default: | ||||
|                     case EQUALS: | ||||
|                         if (val.equals(filter)) | ||||
|                         { | ||||
|                             return true; | ||||
|                         } | ||||
|                         break; | ||||
|                     case EQUALS_IGNORECASE: | ||||
|                         if (val.equalsIgnoreCase(filter)) | ||||
|                         { | ||||
|                             return true; | ||||
|                         } | ||||
|                         break; | ||||
|                     case ENDSWITH: | ||||
|                         if (val.endsWith(filter)) | ||||
|                         { | ||||
|                             return true; | ||||
|                         } | ||||
|                         break; | ||||
|                     case ENDSWITH_IGNORECASE: | ||||
|                         if (val.toLowerCase().endsWith(filter.toLowerCase())) | ||||
|                         { | ||||
|                             return true; | ||||
|                         } | ||||
|                         break; | ||||
|                     case MATCHES: | ||||
|                         if (val.matches(filter)) | ||||
|                         { | ||||
|                             return true; | ||||
|                         } | ||||
|                         break; | ||||
|                     case MATCHES_IGNORECASE: | ||||
|                         if (val.toLowerCase().matches(filter.toLowerCase())) | ||||
|                         { | ||||
|                             return true; | ||||
|                         } | ||||
|                         break; | ||||
|                     default: | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             if ((filterProp instanceof FilterPropBoolean) && (propVal instanceof Boolean)) | ||||
|             { | ||||
|                 Boolean val = (Boolean)propVal; | ||||
|                 Boolean filter = (Boolean)filterProp.getPropVal(); | ||||
|                 Boolean val = (Boolean) propVal; | ||||
|                 Boolean filter = (Boolean) filterProp.getPropVal(); | ||||
|  | ||||
|                 return (val == filter); | ||||
|             } | ||||
| @@ -649,7 +646,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|  | ||||
|         if (start != null) | ||||
|         { | ||||
|             logger.debug("Post-query perms: "+ret.size()+" in "+(System.currentTimeMillis()-start)+" msecs"); | ||||
|             logger.debug("Post-query perms: " + ret.size() + " in " + (System.currentTimeMillis() - start) + " msecs"); | ||||
|         } | ||||
|  | ||||
|         return ret; | ||||
| @@ -663,7 +660,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|  | ||||
|         if (start != null) | ||||
|         { | ||||
|             logger.trace("Pre-load: "+nodeRefs.size()+" in "+(System.currentTimeMillis()-start)+" msecs"); | ||||
|             logger.trace("Pre-load: " + nodeRefs.size() + " in " + (System.currentTimeMillis() - start) + " msecs"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -697,7 +694,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|         @Override | ||||
|         public boolean handle(FilterSortNode node) | ||||
|         { | ||||
|             if(include(node)) | ||||
|             if (include(node)) | ||||
|             { | ||||
|                 children.add(node); | ||||
|             } | ||||
| @@ -709,7 +706,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|         protected boolean include(FilterSortNode node) | ||||
|         { | ||||
|             // filter, if needed | ||||
|             return(!applyFilter || includeFilter(node.getPropVals(), filterProps)) && includeAspects(node.getNodeRef(), inclusiveAspects, exclusiveAspects); | ||||
|             return (!applyFilter || includeFilter(node.getPropVals(), filterProps)) && includeAspects(node.getNodeRef(), inclusiveAspects, exclusiveAspects); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -731,7 +728,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|         @Override | ||||
|         public boolean handle(NodeRef nodeRef) | ||||
|         { | ||||
|             if(include(nodeRef)) | ||||
|             if (include(nodeRef)) | ||||
|             { | ||||
|                 rawResult.add(tenantService.getBaseName(nodeRef)); | ||||
|             } | ||||
| @@ -777,7 +774,8 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|             if (results.size() >= BATCH_SIZE) | ||||
|             { | ||||
|                 // batch | ||||
|                 preloadFilterSort(); | ||||
|                 preloadNodes(); | ||||
|                 filterSort(); | ||||
|             } | ||||
|  | ||||
|             results.add(result); | ||||
| @@ -790,24 +788,27 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|             if (results.size() >= 0) | ||||
|             { | ||||
|                 // finish batch | ||||
|                 preloadFilterSort(); | ||||
|                 preloadNodes(); | ||||
|                 filterSort(); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         private void preloadFilterSort() | ||||
|         private void preloadNodes() | ||||
|         { | ||||
|         	List<NodeRef> nodeRefs = new ArrayList<>(results.size()); | ||||
|             List<NodeRef> nodeRefs = new ArrayList<>(results.size()); | ||||
|             for (FilterSortNodeEntity result : results) | ||||
|             { | ||||
|             	nodeRefs.add(result.getNode().getNodeRef()); | ||||
|                 nodeRefs.add(result.createNodeRef()); | ||||
|             } | ||||
|  | ||||
|             preload(nodeRefs); | ||||
|         } | ||||
|  | ||||
|         private void filterSort() | ||||
|         { | ||||
|             for (FilterSortNodeEntity result : results) | ||||
|             { | ||||
|                 Node node = result.getNode(); | ||||
|                 NodeRef nodeRef = node.getNodeRef(); | ||||
|                 NodeRef nodeRef = result.createNodeRef(); | ||||
|  | ||||
|                 Map<NodePropertyKey, NodePropertyValue> propertyValues = new HashMap<NodePropertyKey, NodePropertyValue>(3); | ||||
|  | ||||
| @@ -832,7 +833,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|                 Map<QName, Serializable> propVals = nodePropertyHelper.convertToPublicProperties(propertyValues); | ||||
|  | ||||
|                 // Add referenceable / spoofed properties (including spoofed name if null) | ||||
|                 ReferenceablePropertiesEntity.addReferenceableProperties(node, propVals); | ||||
|                 ReferenceablePropertiesEntity.addReferenceableProperties(result.getId(), nodeRef, propVals); | ||||
|  | ||||
|                 // special cases | ||||
|  | ||||
| @@ -841,12 +842,12 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|                 { | ||||
|                     if (entry.getValue() instanceof MLText) | ||||
|                     { | ||||
|                         propVals.put(entry.getKey(), DefaultTypeConverter.INSTANCE.convert(String.class, (MLText)entry.getValue())); | ||||
|                         propVals.put(entry.getKey(), DefaultTypeConverter.INSTANCE.convert(String.class, (MLText) entry.getValue())); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 // ContentData (eg. cm:content.size, cm:content.mimetype) | ||||
|                 ContentData contentData = (ContentData)propVals.get(ContentModel.PROP_CONTENT); | ||||
|                 ContentData contentData = (ContentData) propVals.get(ContentModel.PROP_CONTENT); | ||||
|                 if (contentData != null) | ||||
|                 { | ||||
|                     propVals.put(SORT_QNAME_CONTENT_SIZE, contentData.getSize()); | ||||
| @@ -854,7 +855,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|                 } | ||||
|  | ||||
|                 // Auditable props (eg. cm:creator, cm:created, cm:modifier, cm:modified, ...) | ||||
|                 AuditablePropertiesEntity auditableProps = node.getAuditableProperties(); | ||||
|                 AuditablePropertiesEntity auditableProps = result.getAuditablePropertiesEntity(); | ||||
|                 if (auditableProps != null) | ||||
|                 { | ||||
|                     for (Map.Entry<QName, Serializable> entry : auditableProps.getAuditableProperties().entrySet()) | ||||
| @@ -864,7 +865,7 @@ public class GetChildrenCannedQuery extends AbstractCannedQueryPermissions<NodeR | ||||
|                 } | ||||
|  | ||||
|                 // Node type | ||||
|                 Long nodeTypeQNameId = node.getTypeQNameId(); | ||||
|                 Long nodeTypeQNameId = result.getTypeQNameId(); | ||||
|                 if (nodeTypeQNameId != null) | ||||
|                 { | ||||
|                     Pair<Long, QName> pair = qnameDAO.getQName(nodeTypeQNameId); | ||||
|   | ||||
| @@ -133,6 +133,14 @@ | ||||
|     <resultMap id="result_FilterSortNode" type="FilterSortNode"> | ||||
|          | ||||
|         <id property="id" column="id" jdbcType="BIGINT" javaType="java.lang.Long"/> | ||||
|         <result property="nodeUuid" column="uuid" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|         <result property="typeQNameId" column="type_qname_id" jdbcType="BIGINT" javaType="java.lang.Long"/> | ||||
|  | ||||
|         <result property="auditablePropertiesEntity.auditCreator" column="audit_creator" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|         <result property="auditablePropertiesEntity.auditCreated" column="audit_created" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|         <result property="auditablePropertiesEntity.auditModifier" column="audit_modifier" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|         <result property="auditablePropertiesEntity.auditModified" column="audit_modified" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|         <result property="auditablePropertiesEntity.auditAccessed" column="audit_accessed" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|  | ||||
|         <result property="prop1.nodeId" column="prop1_node_id" jdbcType="BIGINT" javaType="java.lang.Long"/> | ||||
|         <result property="prop1.key.qnameId" column="prop1_qname_id" jdbcType="BIGINT" javaType="java.lang.Long"/> | ||||
| @@ -170,7 +178,8 @@ | ||||
|         <result property="prop3.value.doubleValue" column="prop3_double_value" jdbcType="FLOAT" javaType="java.lang.Double"/> | ||||
|         <result property="prop3.value.stringValue" column="prop3_string_value" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|  | ||||
|         <association property="node" resultMap="alfresco.node.result_Node"/> | ||||
|         <result property="storeProtocol" column="protocol" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|         <result property="storeIdentifier" column="identifier" jdbcType="VARCHAR" javaType="java.lang.String"/> | ||||
|          | ||||
|     </resultMap> | ||||
|      | ||||
| @@ -972,8 +981,8 @@ | ||||
|     </select> | ||||
|  | ||||
|     <!-- GetChildren - with explicit prop filtering and/or sorting --> | ||||
|     <select id="select_GetChildrenCannedQueryWithProps" parameterType="FilterSortNode" resultMap="result_FilterSortNode"> | ||||
|        select | ||||
|     <select id="select_GetChildrenCannedQueryWithProps" parameterType="FilterSortNode" resultMap="result_FilterSortNode" flushCache="true"> | ||||
|        select distinct | ||||
|             childNode.id             as id, | ||||
|             childNode.version        as version, | ||||
|             childStore.id            as store_id, | ||||
| @@ -989,7 +998,7 @@ | ||||
|             childNode.audit_created  as audit_created, | ||||
|             childNode.audit_modifier as audit_modifier, | ||||
|             childNode.audit_modified as audit_modified, | ||||
|             childNode.audit_accessed  as audit_accessed | ||||
|             childNode.audit_accessed as audit_accessed | ||||
|             <if test="prop1qnameId != null"> | ||||
|           , prop1.node_id            as prop1_node_id, | ||||
|             prop1.qname_id           as prop1_qname_id, | ||||
| @@ -1067,9 +1076,6 @@ | ||||
|                     #{item} | ||||
|                 </foreach> | ||||
|             </if> | ||||
|         <if test="prop1qnameId == null and auditableProps == false"> | ||||
|             <include refid="alfresco.node.select_ChildAssoc_OrderBy"/> | ||||
|         </if> | ||||
|     </select> | ||||
|      | ||||
|     <!-- GetChildren - with no explicit sorting (or prop filtering) - note: still filtered by child type (and optionally primary or secondary) --> | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
| repository.name=Main Repository | ||||
|  | ||||
| # Schema number | ||||
| version.schema=19500 | ||||
| version.schema=19600 | ||||
|  | ||||
| # Directory configuration | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user