mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	Compare commits
	
		
			5 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 428a82c195 | ||
|  | 519ef19c83 | ||
|  | f19849b547 | ||
|  | d956a4f4aa | ||
|  | 71f649d1bd | 
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-community-repo-amps</artifactId> | ||||
|       <version>17.183</version> | ||||
|       <version>18.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-community-parent</artifactId> | ||||
|       <version>17.183</version> | ||||
|       <version>18.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-automation-community-repo</artifactId> | ||||
|       <version>17.183</version> | ||||
|       <version>18.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <build> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-community-parent</artifactId> | ||||
|       <version>17.183</version> | ||||
|       <version>18.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-community-repo-parent</artifactId> | ||||
|       <version>17.183</version> | ||||
|       <version>18.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <properties> | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| # Version label | ||||
| version.major=7 | ||||
| version.minor=3 | ||||
| version.revision=0 | ||||
| version.revision=1 | ||||
| version.label= | ||||
|  | ||||
| # Edition label | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-governance-services-community-repo-parent</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <build> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <modules> | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-amps</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-community-repo</artifactId> | ||||
|       <version>17.183</version> | ||||
|       <version>18.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <dependencies> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <dependencies> | ||||
|   | ||||
| @@ -9,6 +9,6 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-packaging</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
| </project> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-packaging</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <modules> | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-packaging</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <organization> | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <developers> | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <developers> | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <developers> | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-tests</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <developers> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo-packaging</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|   | ||||
							
								
								
									
										6
									
								
								pom.xml
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								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>17.183</version> | ||||
|     <version>18.2</version> | ||||
|     <packaging>pom</packaging> | ||||
|     <name>Alfresco Community Repo Parent</name> | ||||
|  | ||||
| @@ -25,7 +25,7 @@ | ||||
|     <properties> | ||||
|         <acs.version.major>7</acs.version.major> | ||||
|         <acs.version.minor>3</acs.version.minor> | ||||
|         <acs.version.revision>0</acs.version.revision> | ||||
|         <acs.version.revision>1</acs.version.revision> | ||||
|         <acs.version.label /> | ||||
|         <amp.min.version>${acs.version.major}.0.0</amp.min.version> | ||||
|  | ||||
| @@ -149,7 +149,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>17.183</tag> | ||||
|         <tag>18.2</tag> | ||||
|     </scm> | ||||
|  | ||||
|     <distributionManagement> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <dependencies> | ||||
|   | ||||
| @@ -295,7 +295,18 @@ public class AuditImpl implements Audit | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             totalItems = hasMoreItems ? getAuditEntriesCountByApp(auditApplication) : totalRetrievedItems; | ||||
|             if (hasMoreItems) { | ||||
|                 if (q != null) { | ||||
|                     // filtering via "where" clause | ||||
|                     AuditEntryQueryWalker propertyWalker = new AuditEntryQueryWalker(); | ||||
|                     QueryHelper.walk(q, propertyWalker); | ||||
|                     totalItems = getAuditEntriesCountByAppAndProperties(auditApplication, propertyWalker); | ||||
|                 } else { | ||||
|                     totalItems = getAuditEntriesCountByApp(auditApplication); | ||||
|                 } | ||||
|             } else { | ||||
|                 totalItems = totalRetrievedItems; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         entriesAudit = (skipCount >= totalRetrievedItems) | ||||
| @@ -895,4 +906,19 @@ public class AuditImpl implements Audit | ||||
|         final String applicationName = auditApplication.getKey().substring(1); | ||||
|         return auditService.getAuditEntriesCountByApp(applicationName); | ||||
|     } | ||||
|  | ||||
|     public int getAuditEntriesCountByAppAndProperties(AuditService.AuditApplication auditApplication, AuditEntryQueryWalker propertyWalker) | ||||
|     { | ||||
|         final String applicationName = auditApplication.getKey().substring(1); | ||||
|  | ||||
|         AuditQueryParameters parameters = new AuditQueryParameters(); | ||||
|         parameters.setApplicationName(applicationName); | ||||
|         parameters.setFromTime(propertyWalker.getFromTime()); | ||||
|         parameters.setToTime(propertyWalker.getToTime()); | ||||
|         parameters.setFromId(propertyWalker.getFromId()); | ||||
|         parameters.setToId(propertyWalker.getToId()); | ||||
|         parameters.setUser(propertyWalker.getCreatedByUser()); | ||||
|  | ||||
|         return auditService.getAuditEntriesCountByAppAndProperties(applicationName, parameters); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -34,6 +34,9 @@ import static org.junit.Assert.assertTrue; | ||||
| import static org.junit.Assert.fail; | ||||
|  | ||||
| import java.net.URL; | ||||
| import java.time.ZonedDateTime; | ||||
| import java.time.format.DateTimeFormatter; | ||||
| import java.time.temporal.ChronoUnit; | ||||
| import java.util.Date; | ||||
| import java.util.HashMap; | ||||
| import java.util.List; | ||||
| @@ -386,6 +389,7 @@ public class AuditAppTest extends AbstractSingleNetworkSiteTest | ||||
|         AuditApp auditApp = auditAppsProxy.getAuditApp("alfresco-access"); | ||||
|  | ||||
|         testGetAuditEntries(auditAppsProxy, auditApp); | ||||
|         testGetAuditEntriesWhereCreatedAt(auditAppsProxy, auditApp); | ||||
|         testAuditEntriesSorting(auditAppsProxy, auditApp); | ||||
|         testAuditEntriesWhereDate(auditAppsProxy, auditApp); | ||||
|         testAuditEntriesWhereId(auditAppsProxy, auditApp); | ||||
| @@ -396,6 +400,30 @@ public class AuditAppTest extends AbstractSingleNetworkSiteTest | ||||
|         testDeleteAuditEntries(auditAppsProxy, auditApp); | ||||
|     } | ||||
|  | ||||
|     private void testGetAuditEntriesWhereCreatedAt(AuditApps auditAppsProxy, AuditApp auditApp) throws Exception | ||||
|     { | ||||
|         // get "totalItems" for a specific time interval | ||||
|         Map<String, String> params = new HashMap<>(); | ||||
|  | ||||
|         final ZonedDateTime beginDate = ZonedDateTime.now().minusHours(1).truncatedTo(ChronoUnit.MINUTES); | ||||
|         final ZonedDateTime endDate = ZonedDateTime.now().truncatedTo(ChronoUnit.MINUTES); | ||||
|         params.put("where","(createdAt BETWEEN ('"+beginDate.format(DateTimeFormatter.ISO_OFFSET_DATE_TIME)+"' , '"+endDate.format(DateTimeFormatter.ISO_OFFSET_DATE_TIME)+"'))"); | ||||
|  | ||||
|         ListResponse<AuditEntry> auditEntries = auditAppsProxy.getAuditAppEntries(auditApp.getId(), params, | ||||
|                 HttpServletResponse.SC_OK); | ||||
|         int totalItemsWithDefaultMaxSize = auditEntries.getPaging().getTotalItems(); | ||||
|         assertTrue( totalItemsWithDefaultMaxSize > 1 ); | ||||
|  | ||||
|         // get "totalItems" for a specific time internal (with maxSize=1) | ||||
|         params.put("maxSize","1"); | ||||
|         auditEntries = auditAppsProxy.getAuditAppEntries(auditApp.getId(), params, | ||||
|                 HttpServletResponse.SC_OK); | ||||
|         int totalItemsWithMaxSize1 = auditEntries.getPaging().getTotalItems(); | ||||
|  | ||||
|         // number of "totalItems" must be the same, regardless maxSize | ||||
|         assertEquals(totalItemsWithMaxSize1, totalItemsWithDefaultMaxSize); | ||||
|     } | ||||
|  | ||||
|     private void testGetAuditEntries(AuditApps auditAppsProxy, AuditApp auditApp) throws Exception  | ||||
|     { | ||||
|         // Positive tests | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <parent> | ||||
|         <groupId>org.alfresco</groupId> | ||||
|         <artifactId>alfresco-community-repo</artifactId> | ||||
|         <version>17.183</version> | ||||
|         <version>18.2</version> | ||||
|     </parent> | ||||
|  | ||||
|     <dependencies> | ||||
|   | ||||
| @@ -272,4 +272,16 @@ public interface AuditComponent | ||||
|     { | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Issue an audit query to retrieve count of records for a given application and properties | ||||
|      * | ||||
|      * @param applicationName             the name of the application | ||||
|      * @param parameters                  audit parameters provided by the <code>where</code> clause on the ReST API | ||||
|      * @return                            a map containing min/max and the associated value | ||||
|      */ | ||||
|     default int getAuditEntriesCountByAppAndProperties(String applicationName, AuditQueryParameters parameters) | ||||
|     { | ||||
|         return -1; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -955,4 +955,11 @@ public class AuditComponentImpl implements AuditComponent | ||||
|  | ||||
|         return auditDAO.getAuditEntriesCountByApp(applicationId); | ||||
|     } | ||||
|  | ||||
|     @Override public int getAuditEntriesCountByAppAndProperties(String applicationName, AuditQueryParameters parameters) | ||||
|     { | ||||
|         org.alfresco.repo.domain.audit.AuditQueryParameters dbParameters = new org.alfresco.repo.domain.audit.AuditQueryParameters(); | ||||
|  | ||||
|         return auditDAO.getAuditEntriesCountByAppAndProperties(applicationName, parameters); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -186,4 +186,12 @@ public class AuditServiceImpl implements AuditService | ||||
|     { | ||||
|         return auditComponent.getAuditEntriesCountByApp(applicationName); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     @Override public int getAuditEntriesCountByAppAndProperties(String applicationName, AuditQueryParameters parameters) | ||||
|     { | ||||
|         return auditComponent.getAuditEntriesCountByAppAndProperties(applicationName, parameters); | ||||
|     } | ||||
| } | ||||
| @@ -1,28 +1,28 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Repository | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2016 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software.  | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of  | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is  | ||||
|  * provided under the following open source license terms: | ||||
|  *  | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  *  | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  *  | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Repository | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2016 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software.  | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of  | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is  | ||||
|  * provided under the following open source license terms: | ||||
|  *  | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  *  | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  *  | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
| package org.alfresco.repo.domain.audit; | ||||
|  | ||||
| import java.io.IOException; | ||||
| @@ -452,37 +452,86 @@ public abstract class AbstractAuditDAOImpl implements AuditDAO | ||||
|             org.alfresco.service.cmr.audit.AuditQueryParameters parameters, | ||||
|             int maxResults) | ||||
|     { | ||||
|         String searchKey = null; | ||||
|         Serializable searchValue = null; | ||||
|         if (parameters.getSearchKeyValues().size() > 0) | ||||
|         { | ||||
|             // Only handle one pair for now | ||||
|             Pair<String, Serializable> searchKeyValue = parameters.getSearchKeyValues().get(0); | ||||
|             searchKey = searchKeyValue.getFirst(); | ||||
|             searchValue = searchKeyValue.getSecond(); | ||||
|         } | ||||
|          | ||||
|         AuditQueryRowHandler rowHandler = new AuditQueryRowHandler(callback); | ||||
|         findAuditEntries( | ||||
|                 rowHandler, | ||||
|                 parameters.isForward(), | ||||
|                 parameters.getApplicationName(), | ||||
|                 parameters.getUser(), | ||||
|                 parameters.getFromId(), | ||||
|                 parameters.getToId(), | ||||
|                 parameters.getFromTime(), | ||||
|                 parameters.getToTime(), | ||||
|                 maxResults, | ||||
|                 searchKey, | ||||
|                 searchValue); | ||||
|                 parameters); | ||||
|     } | ||||
|      | ||||
|     protected abstract void findAuditEntries( | ||||
|             AuditQueryRowHandler rowHandler, | ||||
|             boolean forward, | ||||
|             String applicationName, String user, | ||||
|             Long fromId, Long toId, | ||||
|             Long fromTime, Long toTime, | ||||
|             int maxResults, | ||||
|             String searchKey, Serializable searchValue); | ||||
|             org.alfresco.service.cmr.audit.AuditQueryParameters restParameters); | ||||
|  | ||||
|     protected AuditQueryParameters convertFromRestAuditQueryParameters(org.alfresco.service.cmr.audit.AuditQueryParameters restParameters) | ||||
|     { | ||||
|         AuditQueryParameters dbParameters = new AuditQueryParameters(); | ||||
|  | ||||
|         String appName = restParameters.getApplicationName(); | ||||
|         if (appName != null) | ||||
|         { | ||||
|             // Look up the application's ID (this is unique) | ||||
|             Pair<Long, Serializable> appNamePair = propertyValueDAO.getPropertyValue(appName); | ||||
|             if (appNamePair == null) | ||||
|             { | ||||
|                 // No such value | ||||
|                 return null; | ||||
|             } | ||||
|             dbParameters.setAuditAppNameId(appNamePair.getFirst()); | ||||
|         } | ||||
|  | ||||
|         String user = restParameters.getUser(); | ||||
|         if (user != null) | ||||
|         { | ||||
|             // Look up the application's ID (this is unique) | ||||
|             Pair<Long, Serializable> userPair = propertyValueDAO.getPropertyValue(user); | ||||
|             if (userPair == null) | ||||
|             { | ||||
|                 // No such value | ||||
|                 return null; | ||||
|             } | ||||
|             dbParameters.setAuditUserId(userPair.getFirst()); | ||||
|         } | ||||
|  | ||||
|         dbParameters.setAuditFromId(restParameters.getFromId()); | ||||
|         dbParameters.setAuditToId(restParameters.getToId()); | ||||
|         dbParameters.setAuditFromTime(restParameters.getFromTime()); | ||||
|         dbParameters.setAuditToTime(restParameters.getToTime()); | ||||
|  | ||||
|         String searchKey = null; | ||||
|         Serializable searchValue = null; | ||||
|         if (restParameters.getSearchKeyValues().size() > 0) | ||||
|         { | ||||
|             // Only handle one pair for now | ||||
|             Pair<String, Serializable> searchKeyValue = restParameters.getSearchKeyValues().get(0); | ||||
|             searchKey = searchKeyValue.getFirst(); | ||||
|             searchValue = searchKeyValue.getSecond(); | ||||
|         } | ||||
|         if (searchKey != null) | ||||
|         { | ||||
|             // Look up the ID of the search key | ||||
|             Pair<Long, Serializable> searchKeyPair = propertyValueDAO.getPropertyValue(searchKey); | ||||
|             if (searchKeyPair == null) | ||||
|             { | ||||
|                 // No such value | ||||
|                 return null; | ||||
|             } | ||||
|             dbParameters.setSearchKeyId(searchKeyPair.getFirst()); | ||||
|         } | ||||
|         if (searchValue != null) | ||||
|         { | ||||
|             // Look up the ID of the search key | ||||
|             Pair<Long, Serializable> searchValuePair = propertyValueDAO.getPropertyValue(searchValue); | ||||
|             if (searchValuePair == null) | ||||
|             { | ||||
|                 // No such value | ||||
|                 return null; | ||||
|             } | ||||
|             dbParameters.setSearchValueId(searchValuePair.getFirst()); | ||||
|         } | ||||
|         dbParameters.setForward(restParameters.isForward()); | ||||
|  | ||||
|         return dbParameters; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -244,4 +244,16 @@ public interface AuditDAO | ||||
|     { | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Issue an audit query to retrieve count of records for a given application and properties | ||||
|      * | ||||
|      * @param applicationName   name of the application to be queried | ||||
|      * @param parameters        audit parameters provided by the <code>where</code> clause on the ReST API | ||||
|      * @return                  a map containing min/max and the associated value | ||||
|      */ | ||||
|     default int getAuditEntriesCountByAppAndProperties(String applicationName, org.alfresco.service.cmr.audit.AuditQueryParameters parameters) | ||||
|     { | ||||
|         return -1; | ||||
|     } | ||||
| } | ||||
| @@ -66,6 +66,7 @@ public class AuditDAOImpl extends AbstractAuditDAOImpl | ||||
|     private static final String INSERT_ENTRY = "alfresco.audit.insert.insert_AuditEntry"; | ||||
|     private static final String SELECT_MINMAX_ENTRY_FOR_APP = "alfresco.audit.select_MinMaxAuditEntryId"; | ||||
|     private static final String SELECT_COUNT_ENTRIES_FOR_APP = "alfresco.audit.select_CountAuditEntryId"; | ||||
|     private static final String SELECT_COUNT_ENTRIES_FOR_APP_WITH_PROPERTIES = "select_CountAuditEntryIdWithWhereClause"; | ||||
|      | ||||
|     @SuppressWarnings("unused") | ||||
|     private static final String SELECT_ENTRIES_SIMPLE = "alfresco.audit.select_AuditEntriesSimple"; | ||||
| @@ -235,68 +236,29 @@ public class AuditDAOImpl extends AbstractAuditDAOImpl | ||||
|         return result; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public int getAuditEntriesCountByAppAndProperties(String applicationName, org.alfresco.service.cmr.audit.AuditQueryParameters parameters) | ||||
|     { | ||||
|         AuditQueryParameters dbParameters = convertFromRestAuditQueryParameters(parameters); | ||||
|  | ||||
|         int result = template.selectOne(SELECT_COUNT_ENTRIES_FOR_APP_WITH_PROPERTIES, dbParameters); | ||||
|  | ||||
|         return result; | ||||
|     } | ||||
|  | ||||
|     @SuppressWarnings("unchecked") | ||||
|     @Override | ||||
|     protected void findAuditEntries( | ||||
|             final AuditQueryRowHandler rowHandler, | ||||
|             boolean forward, | ||||
|             String appName, String user, | ||||
|             Long fromId, Long toId, | ||||
|             Long fromTime, Long toTime, | ||||
|             int maxResults, | ||||
|             String searchKey, Serializable searchValue) | ||||
|             org.alfresco.service.cmr.audit.AuditQueryParameters restParameters) | ||||
|     { | ||||
|         AuditQueryParameters params = new AuditQueryParameters(); | ||||
|         if (appName != null) | ||||
|         AuditQueryParameters params = convertFromRestAuditQueryParameters(restParameters); | ||||
|         if (params==null) | ||||
|         { | ||||
|             // Look up the application's ID (this is unique) | ||||
|             Pair<Long, Serializable> appNamePair = propertyValueDAO.getPropertyValue(appName); | ||||
|             if (appNamePair == null) | ||||
|             { | ||||
|                 // No such value | ||||
|                 return; | ||||
|             } | ||||
|             params.setAuditAppNameId(appNamePair.getFirst()); | ||||
|             return; | ||||
|         } | ||||
|         if (user != null) | ||||
|         { | ||||
|             // Look up the application's ID (this is unique) | ||||
|             Pair<Long, Serializable> userPair = propertyValueDAO.getPropertyValue(user); | ||||
|             if (userPair == null) | ||||
|             { | ||||
|                 // No such value | ||||
|                 return; | ||||
|             } | ||||
|             params.setAuditUserId(userPair.getFirst()); | ||||
|         } | ||||
|         params.setAuditFromId(fromId); | ||||
|         params.setAuditToId(toId); | ||||
|         params.setAuditFromTime(fromTime); | ||||
|         params.setAuditToTime(toTime); | ||||
|         if (searchKey != null) | ||||
|         { | ||||
|             // Look up the ID of the search key | ||||
|             Pair<Long, Serializable> searchKeyPair = propertyValueDAO.getPropertyValue(searchKey); | ||||
|             if (searchKeyPair == null) | ||||
|             { | ||||
|                 // No such value | ||||
|                 return; | ||||
|             } | ||||
|             params.setSearchKeyId(searchKeyPair.getFirst()); | ||||
|         } | ||||
|         if (searchValue != null) | ||||
|         { | ||||
|             // Look up the ID of the search key | ||||
|             Pair<Long, Serializable> searchValuePair = propertyValueDAO.getPropertyValue(searchValue); | ||||
|             if (searchValuePair == null) | ||||
|             { | ||||
|                 // No such value | ||||
|                 return; | ||||
|             } | ||||
|             params.setSearchValueId(searchValuePair.getFirst()); | ||||
|         } | ||||
|         params.setForward(forward); | ||||
|          | ||||
|  | ||||
|         if (maxResults > 0) | ||||
|         { | ||||
|             // Query without getting the values.  We gather all the results and batch-fetch the audited | ||||
|   | ||||
| @@ -252,4 +252,16 @@ public interface AuditService | ||||
|     { | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Issue an audit query to retrieve min / max audit record id for a given application and properties | ||||
|      * | ||||
|      * @param applicationName               the name of the application | ||||
|      * @param parameters                    audit parameters provided by the <code>where</code> clause on the ReST API | ||||
|      * @return                              a map containing min/max and the associated value | ||||
|      */ | ||||
|     default int getAuditEntriesCountByAppAndProperties(String applicationName, AuditQueryParameters parameters) | ||||
|     { | ||||
|         return -1; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -50,6 +50,15 @@ | ||||
|     <!-- Parameter Maps --> | ||||
|     <!--                --> | ||||
|  | ||||
|     <parameterMap id="parameter_AuditAppId_WhereClauseMap" type="map"> | ||||
|         <parameter property="auditAppNameId" jdbcType="BIGINT" javaType="Long"/> | ||||
|         <parameter property="auditUserId" jdbcType="BIGINT" javaType="Long"/> | ||||
|         <parameter property="auditFromTime" jdbcType="BIGINT" javaType="Long"/> | ||||
|         <parameter property="auditToTime" jdbcType="BIGINT" javaType="Long"/> | ||||
|         <parameter property="auditFromId" jdbcType="BIGINT" javaType="Long"/> | ||||
|         <parameter property="auditToId" jdbcType="BIGINT" javaType="Long"/> | ||||
|     </parameterMap> | ||||
|  | ||||
|     <parameterMap id="parameter_IdMap" type="map"> | ||||
|         <parameter property="id" jdbcType="BIGINT" javaType="java.lang.Long"/> | ||||
|     </parameterMap> | ||||
| @@ -291,6 +300,20 @@ | ||||
|         alf_audit_entry.audit_app_id = #{auditAppId} | ||||
|     </select> | ||||
|  | ||||
|     <select id="select_CountAuditEntryIdWithWhereClause" parameterMap="parameter_AuditAppId_WhereClauseMap" resultType="int"> | ||||
|         select | ||||
|             COUNT(entry.id) | ||||
|         from | ||||
|             alf_audit_entry as entry | ||||
|         <if test="auditAppNameId != null"> | ||||
|             join alf_audit_app app on (entry.audit_app_id = app.id) | ||||
|         </if> | ||||
|         <if test="keyOrValueSearch == true"> | ||||
|             join alf_prop_link sp_pl on (sp_pl.root_prop_id = entry.audit_values_id) | ||||
|         </if> | ||||
|         <include refid="select_AuditEntriesWhereSnippet"/> | ||||
|     </select> | ||||
|  | ||||
|     <!-- Get the maximum/minimum audit entry id for application --> | ||||
|     <select id="select_MinMaxAuditEntryId" parameterMap="parameter_IdMinMaxMap" resultMap="result_minMaxMap"> | ||||
|         select | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
| repository.name=Main Repository | ||||
|  | ||||
| # Schema number | ||||
| version.schema=17000 | ||||
| version.schema=17100 | ||||
|  | ||||
| # Directory configuration | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user