mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	Compare commits
	
		
			83 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | b3dcb3ea35 | ||
|  | 7a49b4c331 | ||
|  | dc0b1988ca | ||
|  | 378abdfe9b | ||
|  | 5efeeffe3c | ||
|  | d15a71fddd | ||
|  | 0f2d7a857d | ||
|  | e30707fd47 | ||
|  | 373e0a2d35 | ||
|  | e5443cf558 | ||
|  | 8badf8747a | ||
|  | f4274f6900 | ||
|  | 5184a95d5f | ||
|  | 80c79a45b7 | ||
|  | d1a67e2773 | ||
|  | 881b8f05c9 | ||
|  | e74ec9425c | ||
|  | f855bda65c | ||
|  | 27406cda19 | ||
|  | e5b3afc560 | ||
|  | f13a0480dc | ||
|  | 68c0aea1f5 | ||
|  | 9e91d28ade | ||
|  | 8f1175de64 | ||
|  | 7d4b74cab7 | ||
|  | b51374532e | ||
|  | 6e5b64be12 | ||
|  | 67195f6dda | ||
|  | d060c548b3 | ||
|  | 9de39009a7 | ||
|  | b920670ebd | ||
|  | 94fd1f4c98 | ||
|  | 5a04dabd72 | ||
|  | 00eef170ef | ||
|  | 43dd274b6c | ||
|  | 842687e25d | ||
|  | 3306879d8c | ||
|  | 8276344ce6 | ||
|  | bb534040a1 | ||
|  | b14526e7e1 | ||
|  | 7c7c2548aa | ||
|  | f0daad17fe | ||
|  | b2044531db | ||
|  | 09cc78f4f3 | ||
|  | b734eb6f78 | ||
|  | 069f886b1f | ||
|  | cdfa16093d | ||
|  | 5474d91dae | ||
|  | 42d07fe59c | ||
|  | 231ac79977 | ||
|  | 8fcdac6d1f | ||
|  | 534b6f444f | ||
|  | 31f9883cc8 | ||
|  | 130e4ff363 | ||
|  | 5ae22f75d0 | ||
|  | 1e386f9d98 | ||
|  | 5d4a859617 | ||
|  | 01b4859b73 | ||
|  | fd0f50d7c9 | ||
|  | afff08edfb | ||
|  | 84c83a1d3f | ||
|  | df5607e11b | ||
|  | 8ff1f976f1 | ||
|  | 24dee74d77 | ||
|  | 99db3f275c | ||
|  | fd8744af7f | ||
|  | bce301d392 | ||
|  | f397daf9f1 | ||
|  | 4b549bf474 | ||
|  | e7a8cc2b2b | ||
|  | 386c33c3c0 | ||
|  | 45d6a114c6 | ||
|  | 3f2f654ac9 | ||
|  | 27e955e947 | ||
|  | 91a8d6deb2 | ||
|  | c9b0389533 | ||
|  | 27177f6ea3 | ||
|  | 1c7fb4fa32 | ||
|  | ae63f29c1f | ||
|  | 252f177d8e | ||
|  | 5df64264ed | ||
|  | 656f5e29a5 | ||
|  | 58cb8bf389 | 
							
								
								
									
										14
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							| @@ -42,16 +42,17 @@ jobs: | ||||
|       !contains(github.event.head_commit.message, '[force') | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/get-build-info@v8.16.0 | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/free-hosted-runner-disk-space@v8.16.0 | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/setup-java-build@v8.16.0 | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|       - id: changed-files | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/github-list-changes@v8.16.0 | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/github-list-changes@v6.1.0 | ||||
|         with: | ||||
|           write-list-to-env: true | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/pre-commit@v8.16.0 | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/pre-commit@v6.1.0 | ||||
|       - name: "Init" | ||||
|         run: bash ./scripts/ci/init.sh | ||||
|       - name: "Prepare maven cache and check compilation" | ||||
| @@ -145,7 +146,7 @@ jobs: | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/get-build-info@v8.16.0 | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/free-hosted-runner-disk-space@v8.16.0 | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/setup-java-build@v8.16.0 | ||||
|       - uses: Alfresco/ya-pmd-scan@v4.3.0 | ||||
|       - uses: Alfresco/ya-pmd-scan@v4.0.0 | ||||
|         with: | ||||
|           classpath-build-command: "mvn test-compile -ntp -Pags -pl \"-:alfresco-community-repo-docker\"" | ||||
|  | ||||
| @@ -266,7 +267,6 @@ jobs: | ||||
|       - name: "Set transformers tag" | ||||
|         run: echo "TRANSFORMERS_TAG=$(mvn help:evaluate -Dexpression=dependency.alfresco-transform-core.version -q -DforceStdout)" >> $GITHUB_ENV | ||||
|       - name: "Set up the environment" | ||||
|         timeout-minutes: ${{ fromJSON(env.GITHUB_ACTIONS_DEPLOY_TIMEOUT) }} | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose.yaml --profile ${{ matrix.compose-profile }} up -d | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
| @@ -875,7 +875,6 @@ jobs: | ||||
|             echo "HOSTNAME_VERIFICATION_DISABLED=false" >> "$GITHUB_ENV" | ||||
|           fi | ||||
|       - name: "Set up the environment" | ||||
|         timeout-minutes: ${{ fromJSON(env.GITHUB_ACTIONS_DEPLOY_TIMEOUT) }} | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose.yaml --profile ${{ matrix.compose-profile }} up -d | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
| @@ -977,7 +976,6 @@ jobs: | ||||
|           bash ./scripts/ci/init.sh | ||||
|           bash ./scripts/ci/build.sh | ||||
|       - name: "Set up the environment" | ||||
|         timeout-minutes: ${{ fromJSON(env.GITHUB_ACTIONS_DEPLOY_TIMEOUT) }} | ||||
|         run: | | ||||
|           ${{ env.TAS_SCRIPTS }}/start-compose.sh ${{ env.TAS_ENVIRONMENT }}/docker-compose-minimal+transforms.yml | ||||
|           ${{ env.TAS_SCRIPTS }}/wait-for-alfresco-start.sh "http://localhost:8082/alfresco" | ||||
|   | ||||
| @@ -147,7 +147,7 @@ | ||||
|         "filename": ".github/workflows/ci.yml", | ||||
|         "hashed_secret": "128f14373ccfaff49e3664045d3a11b50cbb7b39", | ||||
|         "is_verified": false, | ||||
|         "line_number": 902 | ||||
|         "line_number": 901 | ||||
|       } | ||||
|     ], | ||||
|     ".github/workflows/master_release.yml": [ | ||||
| @@ -166,7 +166,7 @@ | ||||
|         "filename": "amps/ags/rm-automation/rm-automation-community-rest-api/src/test/java/org/alfresco/rest/rm/community/base/TestData.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 57, | ||||
|         "line_number": 58, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -176,7 +176,7 @@ | ||||
|         "filename": "amps/ags/rm-automation/rm-automation-community-rest-api/src/test/java/org/alfresco/rest/rm/community/retentionschedule/RetentionScheduleStepTests.java", | ||||
|         "hashed_secret": "e3557f3b0f2189660980d213f75d1a7828d56af1", | ||||
|         "is_verified": false, | ||||
|         "line_number": 83, | ||||
|         "line_number": 85, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -731,7 +731,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/rest/api/tests/AbstractBaseApiTest.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 111, | ||||
|         "line_number": 120, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1273,7 +1273,7 @@ | ||||
|         "filename": "repository/src/main/resources/alfresco/repository.properties", | ||||
|         "hashed_secret": "84551ae5442affc9f1a2d3b4c86ae8b24860149d", | ||||
|         "is_verified": false, | ||||
|         "line_number": 771, | ||||
|         "line_number": 770, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1627,7 +1627,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/security/authentication/identityservice/SpringBasedIdentityServiceFacadeUnitTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 48, | ||||
|         "line_number": 46, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1888,5 +1888,5 @@ | ||||
|       } | ||||
|     ] | ||||
|   }, | ||||
|   "generated_at": "2025-05-15T21:47:13Z" | ||||
|   "generated_at": "2025-03-31T12:42:09Z" | ||||
| } | ||||
|   | ||||
| @@ -126,3 +126,4 @@ Please use [**this guide**](CONTRIBUTING.md) to make a contribution to the proje | ||||
|  | ||||
| - [Alfresco Content Services Documentation](https://docs.alfresco.com/content-services/latest/) | ||||
| - [Alfresco Platform](https://www.hyland.com/en/products/alfresco-platform) | ||||
|  | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-community-repo-amps</artifactId> | ||||
|       <version>23.7.0.1</version> | ||||
|       <version>23.3.12.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-community-parent</artifactId> | ||||
|       <version>23.7.0.1</version> | ||||
|       <version>23.3.12.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-automation-community-repo</artifactId> | ||||
|       <version>23.7.0.1</version> | ||||
|       <version>23.3.12.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <build> | ||||
| @@ -98,7 +98,7 @@ | ||||
|       <dependency> | ||||
|          <groupId>com.github.docker-java</groupId> | ||||
|          <artifactId>docker-java</artifactId> | ||||
|          <version>3.4.0</version> | ||||
|          <version>3.3.6</version> | ||||
|          <exclusions> | ||||
|             <exclusion> | ||||
|                <groupId>org.bouncycastle</groupId> | ||||
|   | ||||
| @@ -26,12 +26,11 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.core; | ||||
|  | ||||
| import lombok.Getter; | ||||
| import org.springframework.beans.factory.annotation.Value; | ||||
| import org.springframework.context.annotation.Configuration; | ||||
| import org.springframework.context.annotation.PropertySource; | ||||
|  | ||||
| import lombok.Getter; | ||||
|  | ||||
| /** | ||||
|  * Extends {@link RestProperties} to be able to change/add properties | ||||
|  * | ||||
| @@ -45,18 +44,18 @@ import lombok.Getter; | ||||
| @PropertySource(value = "classpath:local.properties", ignoreResourceNotFound = true) | ||||
| public class RMRestProperties extends RestProperties | ||||
| { | ||||
|     @Value ("${alfresco.scheme}") | ||||
|     @Value("${alfresco.scheme}") | ||||
|     private String scheme; | ||||
|  | ||||
|     @Value ("${alfresco.server}") | ||||
|     @Value("${alfresco.server}") | ||||
|     private String server; | ||||
|  | ||||
|     @Value ("${alfresco.port}") | ||||
|     @Value("${alfresco.port}") | ||||
|     private String port; | ||||
|  | ||||
|     @Value ("${rest.rmPath}") | ||||
|     @Value("${rest.rmPath}") | ||||
|     private String restRmPath; | ||||
|  | ||||
|     @Value ("${docker.host}") | ||||
|     @Value("${docker.host}") | ||||
|     private String dockerHost; | ||||
| } | ||||
|   | ||||
| @@ -27,6 +27,11 @@ | ||||
| package org.alfresco.rest.core; | ||||
|  | ||||
| import io.restassured.builder.RequestSpecBuilder; | ||||
| import lombok.Getter; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.context.annotation.Scope; | ||||
| import org.springframework.http.HttpStatus; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import org.alfresco.rest.exception.EmptyJsonResponseException; | ||||
| import org.alfresco.rest.model.RestErrorModel; | ||||
| @@ -38,12 +43,6 @@ import org.alfresco.rest.requests.search.SearchAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.GSCoreAPI; | ||||
| import org.alfresco.utility.model.StatusModel; | ||||
| import org.alfresco.utility.model.UserModel; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.context.annotation.Scope; | ||||
| import org.springframework.http.HttpStatus; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import lombok.Getter; | ||||
|  | ||||
| /** | ||||
|  * Extends {@link RestWrapper} in order to call GS APIs with our own properties | ||||
| @@ -153,15 +152,18 @@ public class RMRestWrapper | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * You can handle the request sent to server by calling this method. | ||||
|      * If for example you want to sent multipart form data you can use: <pre> | ||||
|      * You can handle the request sent to server by calling this method. If for example you want to sent multipart form data you can use: | ||||
|      *  | ||||
|      * <pre> | ||||
|      * restClient.configureRequestSpec() | ||||
|      *              .addMultiPart("filedata", Utility.getResourceTestDataFile("restapi-resource")) | ||||
|      *              .addFormParam("renditions", "doclib") | ||||
|      *              .addFormParam("autoRename", true); | ||||
|      *         .addMultiPart("filedata", Utility.getResourceTestDataFile("restapi-resource")) | ||||
|      *         .addFormParam("renditions", "doclib") | ||||
|      *         .addFormParam("autoRename", true); | ||||
|      * | ||||
|      * restClient.withCoreAPI().usingNode(ContentModel.my()).createNode(); | ||||
|      * </pre> This will create the node using the multipart data defined. | ||||
|      * </pre> | ||||
|      *  | ||||
|      * This will create the node using the multipart data defined. | ||||
|      */ | ||||
|     public RequestSpecBuilder configureRequestSpec() | ||||
|     { | ||||
| @@ -171,7 +173,8 @@ public class RMRestWrapper | ||||
|     /** | ||||
|      * Process a response that returns a html | ||||
|      * | ||||
|      * @throws EmptyJsonResponseException If there is no response from the server. | ||||
|      * @throws EmptyJsonResponseException | ||||
|      *             If there is no response from the server. | ||||
|      */ | ||||
|     public RestHtmlResponse processHtmlResponse(RestRequest simpleRequest) | ||||
|     { | ||||
|   | ||||
| @@ -32,6 +32,10 @@ import jakarta.annotation.Resource; | ||||
|  | ||||
| import lombok.Getter; | ||||
| import lombok.Setter; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.context.annotation.Scope; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import org.alfresco.rest.requests.Node; | ||||
| import org.alfresco.rest.requests.coreAPI.RestCoreAPI; | ||||
| import org.alfresco.rest.requests.search.SearchAPI; | ||||
| @@ -45,17 +49,14 @@ import org.alfresco.rest.rm.community.requests.gscore.api.RMUserAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RecordCategoryAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RecordFolderAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RecordsAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RetentionScheduleAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.TransferAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.TransferContainerAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.UnfiledContainerAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.UnfiledRecordFolderAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RetentionScheduleAPI; | ||||
| import org.alfresco.utility.data.DataUserAIS; | ||||
| import org.alfresco.utility.model.RepoTestModel; | ||||
| import org.alfresco.utility.model.UserModel; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.context.annotation.Scope; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| /** | ||||
|  * REST API Factory which provides access to the APIs | ||||
| @@ -68,7 +69,7 @@ import org.springframework.stereotype.Service; | ||||
| public class RestAPIFactory | ||||
| { | ||||
|     @Autowired | ||||
|     @Getter (value = PROTECTED) | ||||
|     @Getter(value = PROTECTED) | ||||
|     private DataUserAIS dataUser; | ||||
|  | ||||
|     @Resource(name = "RMRestWrapper") | ||||
|   | ||||
| @@ -44,11 +44,13 @@ public class SearchRequestBuilder extends SearchRequest | ||||
|     { | ||||
|         new SearchRequest(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set the sql statement for the SearchRequest | ||||
|      * | ||||
|      * @param query sql statement | ||||
|      * @return search  request | ||||
|      * @param query | ||||
|      *            sql statement | ||||
|      * @return search request | ||||
|      */ | ||||
|     public SearchRequestBuilder setQueryBuilder(RestRequestQueryModel query) | ||||
|     { | ||||
| @@ -59,7 +61,8 @@ public class SearchRequestBuilder extends SearchRequest | ||||
|     /** | ||||
|      * Set the paging statement for the SearchRequest | ||||
|      * | ||||
|      * @param paging pagination requested | ||||
|      * @param paging | ||||
|      *            pagination requested | ||||
|      * @return search request | ||||
|      */ | ||||
|     public SearchRequestBuilder setPagingBuilder(Pagination paging) | ||||
| @@ -82,7 +85,8 @@ public class SearchRequestBuilder extends SearchRequest | ||||
|     /** | ||||
|      * Set the requested fields for the SearchRequest | ||||
|      * | ||||
|      * @param fields requested fields | ||||
|      * @param fields | ||||
|      *            requested fields | ||||
|      * @return search request | ||||
|      */ | ||||
|     public SearchRequestBuilder setFieldsBuilder(List<String> fields) | ||||
|   | ||||
| @@ -26,12 +26,12 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.core.v0; | ||||
|  | ||||
| import jakarta.json.Json; | ||||
| import jakarta.json.JsonReader; | ||||
| import java.io.IOException; | ||||
| import java.io.InputStream; | ||||
| import java.time.format.DateTimeFormatter; | ||||
| import java.time.format.DateTimeFormatterBuilder; | ||||
| import jakarta.json.Json; | ||||
| import jakarta.json.JsonReader; | ||||
|  | ||||
| import org.apache.commons.io.IOUtils; | ||||
| import org.apache.http.HttpEntity; | ||||
| @@ -52,20 +52,20 @@ public class APIUtils | ||||
| { | ||||
|     /** Logger for this class. */ | ||||
|     private static final Logger LOGGER = LoggerFactory.getLogger(APIUtils.class); | ||||
|     /** The ISO instant formatter that formats or parses an instant in UTC, such as '2011-12-03T10:15:305Z' | ||||
|      * similar with {@link DateTimeFormatter#ISO_INSTANT}, but with only 3 nanoseconds*/ | ||||
|     public static final DateTimeFormatter ISO_INSTANT_FORMATTER = | ||||
|             new DateTimeFormatterBuilder().appendInstant(3).toFormatter(); | ||||
|     /** | ||||
|      * The ISO instant formatter that formats or parses an instant in UTC, such as '2011-12-03T10:15:305Z' similar with {@link DateTimeFormatter#ISO_INSTANT}, but with only 3 nanoseconds | ||||
|      */ | ||||
|     public static final DateTimeFormatter ISO_INSTANT_FORMATTER = new DateTimeFormatterBuilder().appendInstant(3).toFormatter(); | ||||
|  | ||||
|     /** Private constructor for helper class. */ | ||||
|     private APIUtils() | ||||
|     { | ||||
|     } | ||||
|     {} | ||||
|  | ||||
|     /** | ||||
|      * Extract the body of a HTTP response as a JSON object. | ||||
|      * | ||||
|      * @param httpResponse The HTTP response. | ||||
|      * @param httpResponse | ||||
|      *            The HTTP response. | ||||
|      * @return A JSON representation of the object. | ||||
|      */ | ||||
|     public static JSONObject convertHTTPResponseToJSON(HttpResponse httpResponse) | ||||
| @@ -86,7 +86,8 @@ public class APIUtils | ||||
|     /** | ||||
|      * Util method to extract the message string from the HTTP response | ||||
|      * | ||||
|      * @param httpResponse http response | ||||
|      * @param httpResponse | ||||
|      *            http response | ||||
|      * @return error message from the http response | ||||
|      */ | ||||
|     public static String extractErrorMessageFromHttpResponse(HttpResponse httpResponse) | ||||
|   | ||||
| @@ -39,9 +39,6 @@ import java.util.HashMap; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
|  | ||||
| import org.alfresco.dataprep.AlfrescoHttpClient; | ||||
| import org.alfresco.dataprep.AlfrescoHttpClientFactory; | ||||
| import org.alfresco.dataprep.ContentService; | ||||
| import org.apache.chemistry.opencmis.client.api.CmisObject; | ||||
| import org.apache.chemistry.opencmis.commons.exceptions.CmisObjectNotFoundException; | ||||
| import org.apache.http.HttpResponse; | ||||
| @@ -64,6 +61,10 @@ import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
|  | ||||
| import org.alfresco.dataprep.AlfrescoHttpClient; | ||||
| import org.alfresco.dataprep.AlfrescoHttpClientFactory; | ||||
| import org.alfresco.dataprep.ContentService; | ||||
|  | ||||
| /** | ||||
|  * The base API class containing common methods for making v0 API requests | ||||
|  * | ||||
| @@ -98,9 +99,11 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Helper method to extract list of properties values from result. | ||||
|      * | ||||
|      * @param result the response | ||||
|      * @param result | ||||
|      *            the response | ||||
|      * @return list of specified property values in result | ||||
|      * @throws RuntimeException for malformed response | ||||
|      * @throws RuntimeException | ||||
|      *             for malformed response | ||||
|      */ | ||||
|     protected List<String> getPropertyValues(JSONObject result, String propertyName) | ||||
|     { | ||||
| @@ -139,7 +142,7 @@ public abstract class BaseAPI | ||||
|             for (int i = 0; i < items.length(); i++) | ||||
|             { | ||||
|                 JSONObject item = items.getJSONObject(i); | ||||
|                 if(nodeRef.equals(item.getString("nodeRef"))) | ||||
|                 if (nodeRef.equals(item.getString("nodeRef"))) | ||||
|                 { | ||||
|                     propertyValue = item.getJSONObject("properties").getString(propertyName); | ||||
|                 } | ||||
| @@ -156,9 +159,11 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Helper method to extract property values from request result and put them in map as a list that corresponds to a unique property value. | ||||
|      * | ||||
|      * @param requestResult the request response | ||||
|      * @param requestResult | ||||
|      *            the request response | ||||
|      * @return a map containing information about multiple properties values that correspond to a unique one | ||||
|      * @throws RuntimeException for malformed response | ||||
|      * @throws RuntimeException | ||||
|      *             for malformed response | ||||
|      */ | ||||
|     protected Map<String, List<String>> getPropertyValuesByUniquePropertyValue(JSONObject requestResult, String uniqueProperty, List<String> otherProperties) | ||||
|     { | ||||
| @@ -189,11 +194,12 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Retrieves the nodeRef of an item (category, folder or record) with the given path | ||||
|      * | ||||
|      * @param username the username | ||||
|      * @param password the password | ||||
|      * @param path     the path to the container eg. in case of a category it would be the category name, | ||||
|      *                 in case of a folder it would be /categoryName/folderName | ||||
|      *                 when trying to get File Plan, the path would be "" | ||||
|      * @param username | ||||
|      *            the username | ||||
|      * @param password | ||||
|      *            the password | ||||
|      * @param path | ||||
|      *            the path to the container eg. in case of a category it would be the category name, in case of a folder it would be /categoryName/folderName when trying to get File Plan, the path would be "" | ||||
|      * @return the container nodeRef | ||||
|      */ | ||||
|     public String getItemNodeRef(String username, String password, String path) | ||||
| @@ -204,9 +210,12 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Retrieve a Cmis object by its path | ||||
|      * | ||||
|      * @param username the user's username | ||||
|      * @param password its password | ||||
|      * @param path     the object path | ||||
|      * @param username | ||||
|      *            the user's username | ||||
|      * @param password | ||||
|      *            its password | ||||
|      * @param path | ||||
|      *            the object path | ||||
|      * @return the object in case it exists, null if its does not exist | ||||
|      */ | ||||
|     protected CmisObject getObjectByPath(String username, String password, String path) | ||||
| @@ -215,7 +224,8 @@ public abstract class BaseAPI | ||||
|         try | ||||
|         { | ||||
|             object = contentService.getCMISSession(username, password).getObjectByPath(path); | ||||
|         } catch (CmisObjectNotFoundException notFoundError) | ||||
|         } | ||||
|         catch (CmisObjectNotFoundException notFoundError) | ||||
|         { | ||||
|             return null; | ||||
|         } | ||||
| @@ -225,9 +235,12 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Generic faceted request. | ||||
|      * | ||||
|      * @param username the username | ||||
|      * @param password the password | ||||
|      * @param parameters if the request has parameters | ||||
|      * @param username | ||||
|      *            the username | ||||
|      * @param password | ||||
|      *            the password | ||||
|      * @param parameters | ||||
|      *            if the request has parameters | ||||
|      * @return result object (see API reference for more details), null for any errors | ||||
|      */ | ||||
|     protected JSONObject facetedRequest(String username, String password, List<NameValuePair> parameters, String requestURI) | ||||
| @@ -237,13 +250,13 @@ public abstract class BaseAPI | ||||
|  | ||||
|         if (parameters == null || parameters.isEmpty()) | ||||
|         { | ||||
|              requestURL = MessageFormat.format( | ||||
|             requestURL = MessageFormat.format( | ||||
|                     requestURI, | ||||
|                     client.getAlfrescoUrl()); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|              requestURL = MessageFormat.format( | ||||
|             requestURL = MessageFormat.format( | ||||
|                     requestURI, | ||||
|                     client.getAlfrescoUrl(), | ||||
|                     URLEncodedUtils.format(parameters, "UTF-8")); | ||||
| @@ -255,21 +268,26 @@ public abstract class BaseAPI | ||||
|  | ||||
|     /** | ||||
|      * Helper method for GET requests | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param urlTemplate request URL template | ||||
|      * @param urlTemplateParams zero or more parameters used with <i>urlTemplate</i> | ||||
|      *  | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param urlTemplate | ||||
|      *            request URL template | ||||
|      * @param urlTemplateParams | ||||
|      *            zero or more parameters used with <i>urlTemplate</i> | ||||
|      */ | ||||
|     protected JSONObject doGetRequest(String adminUser, | ||||
|         String adminPassword, | ||||
|         String urlTemplate, | ||||
|         String ... urlTemplateParams) | ||||
|             String adminPassword, | ||||
|             String urlTemplate, | ||||
|             String... urlTemplateParams) | ||||
|     { | ||||
|         AlfrescoHttpClient client = alfrescoHttpClientFactory.getObject(); | ||||
|         String requestUrl = MessageFormat.format( | ||||
|             urlTemplate, | ||||
|             client.getApiUrl(), | ||||
|             urlTemplateParams); | ||||
|                 urlTemplate, | ||||
|                 client.getApiUrl(), | ||||
|                 urlTemplateParams); | ||||
|         client.close(); | ||||
|  | ||||
|         try | ||||
| @@ -284,21 +302,26 @@ public abstract class BaseAPI | ||||
|  | ||||
|     /** | ||||
|      * Helper method for Delete requests | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param urlTemplate request URL template | ||||
|      * @param urlTemplateParams zero or more parameters used with <i>urlTemplate</i> | ||||
|      *  | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param urlTemplate | ||||
|      *            request URL template | ||||
|      * @param urlTemplateParams | ||||
|      *            zero or more parameters used with <i>urlTemplate</i> | ||||
|      */ | ||||
|     protected JSONObject doDeleteRequest(String adminUser, | ||||
|         String adminPassword, | ||||
|         String urlTemplate, | ||||
|         String ... urlTemplateParams) | ||||
|             String adminPassword, | ||||
|             String urlTemplate, | ||||
|             String... urlTemplateParams) | ||||
|     { | ||||
|         AlfrescoHttpClient client = alfrescoHttpClientFactory.getObject(); | ||||
|         String requestUrl = MessageFormat.format( | ||||
|             urlTemplate, | ||||
|             client.getApiUrl(), | ||||
|             urlTemplateParams); | ||||
|                 urlTemplate, | ||||
|                 client.getApiUrl(), | ||||
|                 urlTemplateParams); | ||||
|         client.close(); | ||||
|  | ||||
|         try | ||||
| @@ -313,23 +336,29 @@ public abstract class BaseAPI | ||||
|  | ||||
|     /** | ||||
|      * Helper method for PUT requests | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param requestParams zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate request URL template | ||||
|      * @param urlTemplateParams zero or more parameters used with <i>urlTemplate</i> | ||||
|      *  | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param requestParams | ||||
|      *            zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate | ||||
|      *            request URL template | ||||
|      * @param urlTemplateParams | ||||
|      *            zero or more parameters used with <i>urlTemplate</i> | ||||
|      */ | ||||
|     protected JSONObject doPutRequest(String adminUser, | ||||
|         String adminPassword, | ||||
|         JSONObject requestParams, | ||||
|         String urlTemplate, | ||||
|         String ... urlTemplateParams) | ||||
|             String adminPassword, | ||||
|             JSONObject requestParams, | ||||
|             String urlTemplate, | ||||
|             String... urlTemplateParams) | ||||
|     { | ||||
|         AlfrescoHttpClient client = alfrescoHttpClientFactory.getObject(); | ||||
|         String requestUrl = MessageFormat.format( | ||||
|             urlTemplate, | ||||
|             client.getApiUrl(), | ||||
|             urlTemplateParams); | ||||
|                 urlTemplate, | ||||
|                 client.getApiUrl(), | ||||
|                 urlTemplateParams); | ||||
|         client.close(); | ||||
|  | ||||
|         try | ||||
| @@ -345,19 +374,25 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Helper method for PUT requests | ||||
|      * | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param expectedStatusCode The expected return status code. | ||||
|      * @param requestParams zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate request URL template | ||||
|      * @param urlTemplateParams zero or more parameters used with <i>urlTemplate</i> | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param expectedStatusCode | ||||
|      *            The expected return status code. | ||||
|      * @param requestParams | ||||
|      *            zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate | ||||
|      *            request URL template | ||||
|      * @param urlTemplateParams | ||||
|      *            zero or more parameters used with <i>urlTemplate</i> | ||||
|      */ | ||||
|     protected HttpResponse doPutJsonRequest(String adminUser, | ||||
|                 String adminPassword, | ||||
|                 int expectedStatusCode, | ||||
|                 JSONObject requestParams, | ||||
|                 String urlTemplate, | ||||
|                 String... urlTemplateParams) | ||||
|             String adminPassword, | ||||
|             int expectedStatusCode, | ||||
|             JSONObject requestParams, | ||||
|             String urlTemplate, | ||||
|             String... urlTemplateParams) | ||||
|     { | ||||
|         AlfrescoHttpClient client = alfrescoHttpClientFactory.getObject(); | ||||
|         return doPutJsonRequest(adminUser, adminPassword, expectedStatusCode, client.getApiUrl(), requestParams, urlTemplate, urlTemplateParams); | ||||
| @@ -366,22 +401,30 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Helper method for PUT requests | ||||
|      * | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param expectedStatusCode The expected return status code. | ||||
|      * @param urlStart the start of the URL (for example "alfresco/s/slingshot"). | ||||
|      * @param requestParams zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate request URL template | ||||
|      * @param urlTemplateParams zero or more parameters used with <i>urlTemplate</i> | ||||
|      * @throws AssertionError if the returned status code is not as expected. | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param expectedStatusCode | ||||
|      *            The expected return status code. | ||||
|      * @param urlStart | ||||
|      *            the start of the URL (for example "alfresco/s/slingshot"). | ||||
|      * @param requestParams | ||||
|      *            zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate | ||||
|      *            request URL template | ||||
|      * @param urlTemplateParams | ||||
|      *            zero or more parameters used with <i>urlTemplate</i> | ||||
|      * @throws AssertionError | ||||
|      *             if the returned status code is not as expected. | ||||
|      */ | ||||
|     private HttpResponse doPutJsonRequest(String adminUser, | ||||
|                 String adminPassword, | ||||
|                 int expectedStatusCode, | ||||
|                 String urlStart, | ||||
|                 JSONObject requestParams, | ||||
|                 String urlTemplate, | ||||
|                 String... urlTemplateParams) | ||||
|             String adminPassword, | ||||
|             int expectedStatusCode, | ||||
|             String urlStart, | ||||
|             JSONObject requestParams, | ||||
|             String urlTemplate, | ||||
|             String... urlTemplateParams) | ||||
|     { | ||||
|         String requestUrl = formatRequestUrl(urlStart, urlTemplate, urlTemplateParams); | ||||
|         try | ||||
| @@ -399,9 +442,12 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Fill in the parameters for a URL template. | ||||
|      * | ||||
|      * @param urlStart The start of the URL. | ||||
|      * @param urlTemplate The template. | ||||
|      * @param urlTemplateParams Any parameters that need to be filled into the URL template. | ||||
|      * @param urlStart | ||||
|      *            The start of the URL. | ||||
|      * @param urlTemplate | ||||
|      *            The template. | ||||
|      * @param urlTemplateParams | ||||
|      *            Any parameters that need to be filled into the URL template. | ||||
|      * @return The resultant URL. | ||||
|      */ | ||||
|     private String formatRequestUrl(String urlStart, String urlTemplate, String[] urlTemplateParams) | ||||
| @@ -416,23 +462,29 @@ public abstract class BaseAPI | ||||
|  | ||||
|     /** | ||||
|      * Helper method for POST requests | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param requestParams zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate request URL template | ||||
|      * @param urlTemplateParams zero or more parameters used with <i>urlTemplate</i> | ||||
|      *  | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param requestParams | ||||
|      *            zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate | ||||
|      *            request URL template | ||||
|      * @param urlTemplateParams | ||||
|      *            zero or more parameters used with <i>urlTemplate</i> | ||||
|      */ | ||||
|     protected JSONObject doPostRequest(String adminUser, | ||||
|         String adminPassword, | ||||
|         JSONObject requestParams, | ||||
|         String urlTemplate, | ||||
|         String ... urlTemplateParams) | ||||
|             String adminPassword, | ||||
|             JSONObject requestParams, | ||||
|             String urlTemplate, | ||||
|             String... urlTemplateParams) | ||||
|     { | ||||
|         AlfrescoHttpClient client = alfrescoHttpClientFactory.getObject(); | ||||
|         String requestUrl = MessageFormat.format( | ||||
|             urlTemplate, | ||||
|             client.getApiUrl(), | ||||
|             urlTemplateParams); | ||||
|                 urlTemplate, | ||||
|                 client.getApiUrl(), | ||||
|                 urlTemplateParams); | ||||
|         client.close(); | ||||
|  | ||||
|         try | ||||
| @@ -448,19 +500,25 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Helper method for POST requests | ||||
|      * | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param expectedStatusCode The expected return status code. | ||||
|      * @param requestParams zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate request URL template | ||||
|      * @param urlTemplateParams zero or more parameters used with <i>urlTemplate</i> | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param expectedStatusCode | ||||
|      *            The expected return status code. | ||||
|      * @param requestParams | ||||
|      *            zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate | ||||
|      *            request URL template | ||||
|      * @param urlTemplateParams | ||||
|      *            zero or more parameters used with <i>urlTemplate</i> | ||||
|      */ | ||||
|     protected HttpResponse doPostJsonRequest(String adminUser, | ||||
|                                     String adminPassword, | ||||
|                                     int expectedStatusCode, | ||||
|                                     JSONObject requestParams, | ||||
|                                     String urlTemplate, | ||||
|                                     String... urlTemplateParams) | ||||
|             String adminPassword, | ||||
|             int expectedStatusCode, | ||||
|             JSONObject requestParams, | ||||
|             String urlTemplate, | ||||
|             String... urlTemplateParams) | ||||
|     { | ||||
|         AlfrescoHttpClient client = alfrescoHttpClientFactory.getObject(); | ||||
|         return doPostJsonRequest(adminUser, adminPassword, expectedStatusCode, client.getApiUrl(), requestParams, urlTemplate, urlTemplateParams); | ||||
| @@ -469,19 +527,25 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Helper method for POST requests to slingshot. | ||||
|      * | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param expectedStatusCode The expected return status code. | ||||
|      * @param requestParams zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate request URL template | ||||
|      * @param urlTemplateParams zero or more parameters used with <i>urlTemplate</i> | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param expectedStatusCode | ||||
|      *            The expected return status code. | ||||
|      * @param requestParams | ||||
|      *            zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate | ||||
|      *            request URL template | ||||
|      * @param urlTemplateParams | ||||
|      *            zero or more parameters used with <i>urlTemplate</i> | ||||
|      */ | ||||
|     protected HttpResponse doSlingshotPostJsonRequest(String adminUser, | ||||
|                 String adminPassword, | ||||
|                 int expectedStatusCode, | ||||
|                 JSONObject requestParams, | ||||
|                 String urlTemplate, | ||||
|                 String... urlTemplateParams) | ||||
|             String adminPassword, | ||||
|             int expectedStatusCode, | ||||
|             JSONObject requestParams, | ||||
|             String urlTemplate, | ||||
|             String... urlTemplateParams) | ||||
|     { | ||||
|         AlfrescoHttpClient client = alfrescoHttpClientFactory.getObject(); | ||||
|         return doPostJsonRequest(adminUser, adminPassword, expectedStatusCode, client.getAlfrescoUrl() + SLINGSHOT_PREFIX, requestParams, urlTemplate, urlTemplateParams); | ||||
| @@ -490,22 +554,30 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Helper method for POST requests | ||||
|      * | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param expectedStatusCode The expected return status code. | ||||
|      * @param urlStart the start of the URL (for example "alfresco/s/slingshot"). | ||||
|      * @param requestParams zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate request URL template | ||||
|      * @param urlTemplateParams zero or more parameters used with <i>urlTemplate</i> | ||||
|      * @throws AssertionError if the returned status code is not as expected. | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param expectedStatusCode | ||||
|      *            The expected return status code. | ||||
|      * @param urlStart | ||||
|      *            the start of the URL (for example "alfresco/s/slingshot"). | ||||
|      * @param requestParams | ||||
|      *            zero or more endpoint specific request parameters | ||||
|      * @param urlTemplate | ||||
|      *            request URL template | ||||
|      * @param urlTemplateParams | ||||
|      *            zero or more parameters used with <i>urlTemplate</i> | ||||
|      * @throws AssertionError | ||||
|      *             if the returned status code is not as expected. | ||||
|      */ | ||||
|     private HttpResponse doPostJsonRequest(String adminUser, | ||||
|                 String adminPassword, | ||||
|                 int expectedStatusCode, | ||||
|                 String urlStart, | ||||
|                 JSONObject requestParams, | ||||
|                 String urlTemplate, | ||||
|                 String... urlTemplateParams) | ||||
|             String adminPassword, | ||||
|             int expectedStatusCode, | ||||
|             String urlStart, | ||||
|             JSONObject requestParams, | ||||
|             String urlTemplate, | ||||
|             String... urlTemplateParams) | ||||
|     { | ||||
|         String requestUrl; | ||||
|         requestUrl = formatRequestUrl(urlStart, urlTemplate, urlTemplateParams); | ||||
| @@ -529,7 +601,8 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Try to convert the response body to a JSON object. | ||||
|      * | ||||
|      * @param response The response. | ||||
|      * @param response | ||||
|      *            The response. | ||||
|      * @return The JSON object or null if it was not possible to convert the response. | ||||
|      */ | ||||
|     private JSONObject responseBodyToJson(HttpResponse response) | ||||
| @@ -554,21 +627,29 @@ public abstract class BaseAPI | ||||
|  | ||||
|     /** | ||||
|      * Helper method for handling generic HTTP requests | ||||
|      * @param requestType request type (a subclass of {@link HttpRequestBase}) | ||||
|      * @param requestUrl URL the request is to be sent to | ||||
|      * @param adminUser user with administrative privileges | ||||
|      * @param adminPassword password for adminUser | ||||
|      * @param requestParams endpoint specific request parameters | ||||
|      *  | ||||
|      * @param requestType | ||||
|      *            request type (a subclass of {@link HttpRequestBase}) | ||||
|      * @param requestUrl | ||||
|      *            URL the request is to be sent to | ||||
|      * @param adminUser | ||||
|      *            user with administrative privileges | ||||
|      * @param adminPassword | ||||
|      *            password for adminUser | ||||
|      * @param requestParams | ||||
|      *            endpoint specific request parameters | ||||
|      * @return response body | ||||
|      * @throws IllegalAccessException for invalid <i>requestType</i> | ||||
|      * @throws InstantiationException for invalid <i>requestType</i> | ||||
|      * @throws IllegalAccessException | ||||
|      *             for invalid <i>requestType</i> | ||||
|      * @throws InstantiationException | ||||
|      *             for invalid <i>requestType</i> | ||||
|      */ | ||||
|     private <T extends HttpRequestBase> JSONObject doRequest( | ||||
|         Class<T> requestType, | ||||
|         String requestUrl, | ||||
|         String adminUser, | ||||
|         String adminPassword, | ||||
|         JSONObject requestParams) throws InstantiationException, IllegalAccessException | ||||
|             Class<T> requestType, | ||||
|             String requestUrl, | ||||
|             String adminUser, | ||||
|             String adminPassword, | ||||
|             JSONObject requestParams) throws InstantiationException, IllegalAccessException | ||||
|     { | ||||
|         AlfrescoHttpClient client = alfrescoHttpClientFactory.getObject(); | ||||
|         T request = requestType.newInstance(); | ||||
| @@ -593,34 +674,34 @@ public abstract class BaseAPI | ||||
|  | ||||
|             switch (response.getStatusLine().getStatusCode()) | ||||
|             { | ||||
|                 case HttpStatus.SC_OK: | ||||
|                 case HttpStatus.SC_CREATED: | ||||
|                     // request successful | ||||
|                     if (responseBody != null) | ||||
|                     { | ||||
|                         returnValues = responseBody; | ||||
|                     } | ||||
|                     break; | ||||
|             case HttpStatus.SC_OK: | ||||
|             case HttpStatus.SC_CREATED: | ||||
|                 // request successful | ||||
|                 if (responseBody != null) | ||||
|                 { | ||||
|                     returnValues = responseBody; | ||||
|                 } | ||||
|                 break; | ||||
|  | ||||
|                 case HttpStatus.SC_INTERNAL_SERVER_ERROR: | ||||
| 					if (responseBody != null  && responseBody.has(EXCEPTION_KEY)) | ||||
|                     { | ||||
|                         LOGGER.error("Request failed with error message: {}", responseBody.getString(MESSAGE_KEY)); | ||||
|                         returnValues = responseBody; | ||||
|                     } | ||||
|                     break; | ||||
|                 case HttpStatus.SC_BAD_REQUEST: | ||||
|                 case HttpStatus.SC_UNPROCESSABLE_ENTITY: | ||||
|                     if (responseBody != null  && responseBody.has(EXCEPTION_KEY)) | ||||
|                     { | ||||
|                         LOGGER.error("Request failed: {}", responseBody.getString(EXCEPTION_KEY)); | ||||
|                         returnValues = responseBody; | ||||
|                     } | ||||
|                     break; | ||||
|             case HttpStatus.SC_INTERNAL_SERVER_ERROR: | ||||
|                 if (responseBody != null && responseBody.has(EXCEPTION_KEY)) | ||||
|                 { | ||||
|                     LOGGER.error("Request failed with error message: {}", responseBody.getString(MESSAGE_KEY)); | ||||
|                     returnValues = responseBody; | ||||
|                 } | ||||
|                 break; | ||||
|             case HttpStatus.SC_BAD_REQUEST: | ||||
|             case HttpStatus.SC_UNPROCESSABLE_ENTITY: | ||||
|                 if (responseBody != null && responseBody.has(EXCEPTION_KEY)) | ||||
|                 { | ||||
|                     LOGGER.error("Request failed: {}", responseBody.getString(EXCEPTION_KEY)); | ||||
|                     returnValues = responseBody; | ||||
|                 } | ||||
|                 break; | ||||
|  | ||||
|                 default: | ||||
|                     LOGGER.error("Request returned unexpected HTTP status {}", response.getStatusLine().getStatusCode()); | ||||
|                     break; | ||||
|             default: | ||||
|                 LOGGER.error("Request returned unexpected HTTP status {}", response.getStatusLine().getStatusCode()); | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
|         catch (JSONException error) | ||||
| @@ -686,40 +767,16 @@ public abstract class BaseAPI | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Used to set RM items properties | ||||
|      * including records, categories and folders | ||||
|      * Used to set RM items properties including records, categories and folders | ||||
|      */ | ||||
|     public enum RMProperty | ||||
|     { | ||||
|         NAME, | ||||
|         TITLE, | ||||
|         CONTENT, | ||||
|         DESCRIPTION, | ||||
|         AUTHOR, | ||||
|         PHYSICAL_SIZE, | ||||
|         NUMBER_OF_COPIES, | ||||
|         STORAGE_LOCATION, | ||||
|         SHELF, | ||||
|         BOX, | ||||
|         FILE, | ||||
|         ORIGINATOR, | ||||
|         ORIGINATING_ORGANIZATION, | ||||
|         PUBLICATION_DATE | ||||
|         NAME, TITLE, CONTENT, DESCRIPTION, AUTHOR, PHYSICAL_SIZE, NUMBER_OF_COPIES, STORAGE_LOCATION, SHELF, BOX, FILE, ORIGINATOR, ORIGINATING_ORGANIZATION, PUBLICATION_DATE | ||||
|     } | ||||
|  | ||||
|     public enum RETENTION_SCHEDULE | ||||
|     { | ||||
|         NAME, | ||||
|         DESCRIPTION, | ||||
|         RETENTION_AUTHORITY, | ||||
|         RETENTION_INSTRUCTIONS, | ||||
|         RETENTION_PERIOD, | ||||
|         RETENTION_LOCATION, | ||||
|         RETENTION_PERIOD_PROPERTY, | ||||
|         RETENTION_GHOST, | ||||
|         RETENTION_ELIGIBLE_FIRST_EVENT, | ||||
|         RETENTION_EVENTS, | ||||
|         COMBINE_DISPOSITION_STEP_CONDITIONS | ||||
|         NAME, DESCRIPTION, RETENTION_AUTHORITY, RETENTION_INSTRUCTIONS, RETENTION_PERIOD, RETENTION_LOCATION, RETENTION_PERIOD_PROPERTY, RETENTION_GHOST, RETENTION_ELIGIBLE_FIRST_EVENT, RETENTION_EVENTS, COMBINE_DISPOSITION_STEP_CONDITIONS | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -727,14 +784,8 @@ public abstract class BaseAPI | ||||
|      */ | ||||
|     public enum RM_ACTIONS | ||||
|     { | ||||
|         EDIT_DISPOSITION_DATE("editDispositionActionAsOfDate"), | ||||
|         END_RETENTION("retain"), | ||||
|         CUT_OFF("cutoff"), | ||||
|         UNDO_CUT_OFF("undoCutoff"), | ||||
|         TRANSFER("transfer"), | ||||
|         COMPLETE_EVENT("completeEvent"), | ||||
|         UNDO_EVENT("undoEvent"), | ||||
|         DESTROY("destroy"); | ||||
|         EDIT_DISPOSITION_DATE("editDispositionActionAsOfDate"), END_RETENTION("retain"), CUT_OFF("cutoff"), UNDO_CUT_OFF("undoCutoff"), TRANSFER("transfer"), COMPLETE_EVENT("completeEvent"), UNDO_EVENT("undoEvent"), DESTROY("destroy"); | ||||
|  | ||||
|         String action; | ||||
|  | ||||
|         private RM_ACTIONS(String action) | ||||
| @@ -750,17 +801,16 @@ public abstract class BaseAPI | ||||
|  | ||||
|     public enum PermissionType | ||||
|     { | ||||
|         SET_READ, | ||||
|         REMOVE_READ, | ||||
|         SET_READ_AND_FILE, | ||||
|         REMOVE_READ_AND_FILE, | ||||
|         SET_READ, REMOVE_READ, SET_READ_AND_FILE, REMOVE_READ_AND_FILE, | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Util to return the property value from a map | ||||
|      * | ||||
|      * @param properties the map containing properties | ||||
|      * @param property   to get value for | ||||
|      * @param properties | ||||
|      *            the map containing properties | ||||
|      * @param property | ||||
|      *            to get value for | ||||
|      * @return the property value | ||||
|      */ | ||||
|     public <K extends Enum<?>> String getPropertyValue(Map<K, String> properties, Enum<?> property) | ||||
| @@ -776,10 +826,14 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Retrieves the property value and decides if that gets to be added to the request | ||||
|      * | ||||
|      * @param requestParams        the request parameters | ||||
|      * @param propertyRequestValue the property name in the request, eg. "prop_cm_name" | ||||
|      * @param itemProperties       map of item's properties values | ||||
|      * @param property             the property in the property map to check value for | ||||
|      * @param requestParams | ||||
|      *            the request parameters | ||||
|      * @param propertyRequestValue | ||||
|      *            the property name in the request, eg. "prop_cm_name" | ||||
|      * @param itemProperties | ||||
|      *            map of item's properties values | ||||
|      * @param property | ||||
|      *            the property in the property map to check value for | ||||
|      * @return the json object used in request with the property with its value added if that is not null or empty | ||||
|      */ | ||||
|     protected <K extends Enum<?>> JSONObject addPropertyToRequest(JSONObject requestParams, String propertyRequestValue, Map<K, String> itemProperties, Enum<?> property) throws JSONException | ||||
| @@ -796,12 +850,14 @@ public abstract class BaseAPI | ||||
|     /** | ||||
|      * Deletes the category, folder or record given as parameter | ||||
|      * | ||||
|      * @param username the username with whom the delete is performed | ||||
|      * @param password the user's password | ||||
|      * @param itemPath the path to the item eg. in case of a category it would be the "/" + category name, | ||||
|      *                 in case of a folder or subCategory it would be /categoryName/folderName or /categoryName/subCategoryName/ | ||||
|      *                 in case of a record /categoryName/folderName/recordName | ||||
|      * @throws AssertionError if the delete was not successful. | ||||
|      * @param username | ||||
|      *            the username with whom the delete is performed | ||||
|      * @param password | ||||
|      *            the user's password | ||||
|      * @param itemPath | ||||
|      *            the path to the item eg. in case of a category it would be the "/" + category name, in case of a folder or subCategory it would be /categoryName/folderName or /categoryName/subCategoryName/ in case of a record /categoryName/folderName/recordName | ||||
|      * @throws AssertionError | ||||
|      *             if the delete was not successful. | ||||
|      */ | ||||
|     protected void deleteItem(String username, String password, String itemPath) | ||||
|     { | ||||
|   | ||||
| @@ -28,13 +28,8 @@ package org.alfresco.rest.core.v0; | ||||
|  | ||||
| public enum RMEvents | ||||
| { | ||||
|     ABOLISHED("abolished"), | ||||
|     ALL_ALLOWANCES_GRANTED_ARE_TERMINATED("all_allowances_granted_are_terminated"), | ||||
|     CASE_CLOSED("case_closed"), | ||||
|     DECLASSIFICATION_REVIEW("declassification_review"), | ||||
|     OBSOLETE("obsolete"), | ||||
|     NO_LONGER_NEEDED("no_longer_needed"), | ||||
|     STUDY_COMPLETE("study_complete"); | ||||
|     ABOLISHED("abolished"), ALL_ALLOWANCES_GRANTED_ARE_TERMINATED("all_allowances_granted_are_terminated"), CASE_CLOSED("case_closed"), DECLASSIFICATION_REVIEW("declassification_review"), OBSOLETE("obsolete"), NO_LONGER_NEEDED("no_longer_needed"), STUDY_COMPLETE("study_complete"); | ||||
|  | ||||
|     private String eventName; | ||||
|  | ||||
|     RMEvents(String eventName) | ||||
|   | ||||
| @@ -30,11 +30,11 @@ import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
| @@ -47,43 +47,43 @@ import org.alfresco.utility.model.TestModel; | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| @JsonIgnoreProperties (ignoreUnknown = true) | ||||
| @JsonIgnoreProperties(ignoreUnknown = true) | ||||
| public class AuditEntry extends TestModel | ||||
| { | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeName; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private List<Object> changedValues; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String identifier; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String path; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeRef; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String fullName; | ||||
|  | ||||
|     @JsonProperty | ||||
|     private String createPerson; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String userName; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String userRole; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String event; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String timestamp; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -29,24 +29,13 @@ package org.alfresco.rest.rm.community.model.audit; | ||||
| /** | ||||
|  * Enumerates the list of events audited | ||||
|  * | ||||
|  * @author  Rodica Sutu | ||||
|  * @author Rodica Sutu | ||||
|  * @since 2.7 | ||||
|  * | ||||
|  */ | ||||
| public enum AuditEvents | ||||
| { | ||||
|     CREATE_PERSON("Create Person", "Create User"), | ||||
|     DELETE_PERSON("Delete Person", "Delete User"), | ||||
|     CREATE_USER_GROUP("Create User Group", "Create User Group"), | ||||
|     DELETE_USER_GROUP("Delete User Group", "Delete User Group"), | ||||
|     ADD_TO_USER_GROUP("Add To User Group", "Add To User Group"), | ||||
|     REMOVE_FROM_USER_GROUP("Remove From User Group", "Remove From User Group"), | ||||
|     LOGIN_UNSUCCESSFUL("Login.Failure", "Login Unsuccessful"), | ||||
|     LOGIN_SUCCESSFUL("Login.Success", "Login Successful"), | ||||
|     CREATE_HOLD("Create Hold", "Create Hold"), | ||||
|     DELETE_HOLD("Delete Hold", "Delete Hold"), | ||||
|     ADD_TO_HOLD("Add To Hold", "Add To Hold"), | ||||
|     REMOVE_FROM_HOLD("Remove From Hold", "Remove From Hold"); | ||||
|     CREATE_PERSON("Create Person", "Create User"), DELETE_PERSON("Delete Person", "Delete User"), CREATE_USER_GROUP("Create User Group", "Create User Group"), DELETE_USER_GROUP("Delete User Group", "Delete User Group"), ADD_TO_USER_GROUP("Add To User Group", "Add To User Group"), REMOVE_FROM_USER_GROUP("Remove From User Group", "Remove From User Group"), LOGIN_UNSUCCESSFUL("Login.Failure", "Login Unsuccessful"), LOGIN_SUCCESSFUL("Login.Success", "Login Successful"), CREATE_HOLD("Create Hold", "Create Hold"), DELETE_HOLD("Delete Hold", "Delete Hold"), ADD_TO_HOLD("Add To Hold", "Add To Hold"), REMOVE_FROM_HOLD("Remove From Hold", "Remove From Hold"); | ||||
|  | ||||
|     /** event audited */ | ||||
|     public final String event; | ||||
|   | ||||
| @@ -29,7 +29,6 @@ package org.alfresco.rest.rm.community.model.common; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| @@ -47,15 +46,15 @@ import lombok.NoArgsConstructor; | ||||
| @AllArgsConstructor | ||||
| public class IdNamePair | ||||
| { | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private List<String> aspectNames; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
| } | ||||
|   | ||||
| @@ -27,10 +27,10 @@ | ||||
| package org.alfresco.rest.rm.community.model.common; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
|  | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
| @@ -42,9 +42,9 @@ import org.alfresco.utility.model.TestModel; | ||||
| @Builder | ||||
| @Data | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| //@NoArgsConstructor | ||||
| //@AllArgsConstructor | ||||
| @JsonIgnoreProperties (ignoreUnknown = true) | ||||
| // @NoArgsConstructor | ||||
| // @AllArgsConstructor | ||||
| @JsonIgnoreProperties(ignoreUnknown = true) | ||||
| public class Owner extends TestModel | ||||
| { | ||||
|  | ||||
|   | ||||
| @@ -29,15 +29,14 @@ package org.alfresco.rest.rm.community.model.common; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for path parameter | ||||
|  * | ||||
| @@ -51,12 +50,12 @@ import lombok.NoArgsConstructor; | ||||
| @AllArgsConstructor | ||||
| public class Path extends TestModel | ||||
| { | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private Boolean isComplete; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private List<IdNamePair> elements; | ||||
| } | ||||
|   | ||||
| @@ -27,7 +27,6 @@ | ||||
| package org.alfresco.rest.rm.community.model.common; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| @@ -45,9 +44,9 @@ import lombok.NoArgsConstructor; | ||||
| @AllArgsConstructor | ||||
| public class ReviewPeriod | ||||
| { | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String periodType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String expression; | ||||
| } | ||||
|   | ||||
| @@ -34,10 +34,8 @@ package org.alfresco.rest.rm.community.model.custom; | ||||
|  */ | ||||
| public enum CustomDefinitions | ||||
| { | ||||
|     ATTACHMENT("Attachment"), | ||||
|     MESSAGE("Message"), | ||||
|     NEXT_VERSION("Next Version"), | ||||
|     RENDITION("Rendition"); | ||||
|     ATTACHMENT("Attachment"), MESSAGE("Message"), NEXT_VERSION("Next Version"), RENDITION("Rendition"); | ||||
|  | ||||
|     /** | ||||
|      * The name of custom reference. | ||||
|      */ | ||||
|   | ||||
| @@ -29,17 +29,16 @@ package org.alfresco.rest.rm.community.model.fileplan; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for file plan | ||||
|  * | ||||
| @@ -58,34 +57,34 @@ public class FilePlan extends TestModel | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private List<String> aspectNames; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private FilePlanProperties properties; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -34,15 +34,14 @@ import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanCo | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_TITLE; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for file plan properties | ||||
|  * | ||||
| @@ -59,24 +58,24 @@ public class FilePlanProperties extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_COMPONENT_ID) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_COMPONENT_ID) | ||||
|     private String componentd; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
|  | ||||
|     /************************/ | ||||
|     /** Optional parameters */ | ||||
|     /************************/ | ||||
|     @JsonProperty (PROPERTIES_COUNT) | ||||
|     @JsonProperty(PROPERTIES_COUNT) | ||||
|     private Integer count; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_TITLE) | ||||
|     @JsonProperty(PROPERTIES_TITLE) | ||||
|     private String title; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_DESCRIPTION) | ||||
|     @JsonProperty(PROPERTIES_DESCRIPTION) | ||||
|     private String description; | ||||
| } | ||||
|   | ||||
| @@ -36,16 +36,15 @@ public class FilePlanComponentAspects | ||||
| { | ||||
|     /** Private constructor to prevent instantiation. */ | ||||
|     private FilePlanComponentAspects() | ||||
|     { | ||||
|     } | ||||
|     {} | ||||
|  | ||||
|     // aspect present on completed records | ||||
|     public static final String ASPECTS_COMPLETED_RECORD = "rma:declaredRecord"; | ||||
|  | ||||
| 	// aspect present on record folders/categories with vital records | ||||
|     public static final String ASPECTS_VITAL_RECORD_DEFINITION= "rma:vitalRecordDefinition"; | ||||
|     // aspect present on record folders/categories with vital records | ||||
|     public static final String ASPECTS_VITAL_RECORD_DEFINITION = "rma:vitalRecordDefinition"; | ||||
|  | ||||
| 	// aspect present on vital records | ||||
|     // aspect present on vital records | ||||
|     public static final String ASPECTS_VITAL_RECORD = "rma:vitalRecord"; | ||||
|  | ||||
|     // Frozen aspect | ||||
|   | ||||
| @@ -47,7 +47,7 @@ public class FilePlanComponentFields | ||||
|     public static final String PROPERTIES_VITAL_RECORD_INDICATOR = "rma:vitalRecordIndicator"; | ||||
|     public static final String PROPERTIES_REVIEW_PERIOD = "rma:reviewPeriod"; | ||||
|     public static final String PROPERTIES_OWNER = "cm:owner"; | ||||
|     public static final String PROPERTIES_AUTHOR="cm:author"; | ||||
|     public static final String PROPERTIES_AUTHOR = "cm:author"; | ||||
|  | ||||
|     /** Common properties for record folders and records */ | ||||
|     public static final String PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE = "rma:recordSearchHasDispositionSchedule"; | ||||
|   | ||||
| @@ -29,11 +29,11 @@ package org.alfresco.rest.rm.community.model.hold; | ||||
| import java.util.Objects; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
| @@ -72,7 +72,7 @@ public class Hold extends TestModel | ||||
|         } | ||||
|         Hold hold = (Hold) o; | ||||
|         return Objects.equals(id, hold.id) && Objects.equals(name, hold.name) | ||||
|             && Objects.equals(description, hold.description) && Objects.equals(reason, hold.reason); | ||||
|                 && Objects.equals(description, hold.description) && Objects.equals(reason, hold.reason); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|   | ||||
| @@ -27,11 +27,11 @@ | ||||
| package org.alfresco.rest.rm.community.model.hold; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.search.RestRequestQueryModel; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
|   | ||||
| @@ -26,8 +26,6 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model.hold; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
|   | ||||
| @@ -30,6 +30,7 @@ import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -34,5 +34,4 @@ import org.alfresco.rest.core.RestModels; | ||||
|  * @author Damian Ujma | ||||
|  */ | ||||
| public class HoldBulkStatusCollection extends RestModels<HoldBulkStatusEntry, HoldBulkStatusCollection> | ||||
| { | ||||
| } | ||||
| {} | ||||
|   | ||||
| @@ -26,13 +26,12 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model.hold; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| @Builder | ||||
|   | ||||
| @@ -27,12 +27,12 @@ | ||||
| package org.alfresco.rest.rm.community.model.hold; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -34,5 +34,4 @@ import org.alfresco.rest.core.RestModels; | ||||
|  * @author Damian Ujma | ||||
|  */ | ||||
| public class HoldChildCollection extends RestModels<HoldChildEntry, HoldChildCollection> | ||||
| { | ||||
| } | ||||
| {} | ||||
|   | ||||
| @@ -27,12 +27,12 @@ | ||||
| package org.alfresco.rest.rm.community.model.hold; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -34,5 +34,4 @@ import org.alfresco.rest.core.RestModels; | ||||
|  * @author Damian Ujma | ||||
|  */ | ||||
| public class HoldCollection extends RestModels<HoldEntry, HoldCollection> | ||||
| { | ||||
| } | ||||
| {} | ||||
|   | ||||
| @@ -27,12 +27,12 @@ | ||||
| package org.alfresco.rest.rm.community.model.hold; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -27,12 +27,12 @@ | ||||
| package org.alfresco.rest.rm.community.model.hold; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -27,12 +27,12 @@ | ||||
| package org.alfresco.rest.rm.community.model.hold; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -28,11 +28,11 @@ package org.alfresco.rest.rm.community.model.hold.v0; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
| @@ -45,12 +45,12 @@ import org.alfresco.utility.model.TestModel; | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| @JsonIgnoreProperties (ignoreUnknown = true) | ||||
| @JsonIgnoreProperties(ignoreUnknown = true) | ||||
| public class HoldEntry extends TestModel | ||||
| { | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeRef; | ||||
| } | ||||
|   | ||||
| @@ -29,6 +29,11 @@ package org.alfresco.rest.rm.community.model.record; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.core.IRestModel; | ||||
| import org.alfresco.rest.core.assertion.ModelAssertion; | ||||
| @@ -37,12 +42,6 @@ import org.alfresco.rest.model.RestNodeModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| /** | ||||
|  * POJO for record | ||||
|  * | ||||
| @@ -61,28 +60,28 @@ public class Record extends TestModel implements IRestModel<RestNodeModel> | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     /************************/ | ||||
| @@ -118,7 +117,7 @@ public class Record extends TestModel implements IRestModel<RestNodeModel> | ||||
|         return assertThat(); | ||||
|     } | ||||
|  | ||||
|     @JsonProperty (value = "entry") | ||||
|     @JsonProperty(value = "entry") | ||||
|     RestNodeModel model; | ||||
|  | ||||
|     @Override | ||||
|   | ||||
| @@ -27,15 +27,14 @@ | ||||
| package org.alfresco.rest.rm.community.model.record; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for File records | ||||
|  * | ||||
|   | ||||
| @@ -27,15 +27,14 @@ | ||||
| package org.alfresco.rest.rm.community.model.record; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for record content field | ||||
|  * | ||||
| @@ -50,15 +49,15 @@ import lombok.NoArgsConstructor; | ||||
| @AllArgsConstructor | ||||
| public class RecordContent extends TestModel | ||||
| { | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String mimeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String mimeTypeName; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private Integer sizeInBytes; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String encoding; | ||||
| } | ||||
|   | ||||
| @@ -64,7 +64,6 @@ import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanCo | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD_EXPRESSION; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RESOLUTION_UNIT; | ||||
|  | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_REVIEW_AS_OF; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RMV_VERSIONED; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_ROOT_NODE_REF; | ||||
| @@ -85,12 +84,12 @@ import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| @@ -111,160 +110,160 @@ public class RecordProperties extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_DATE_FILED) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_DATE_FILED) | ||||
|     private String dateField; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     private Boolean recordSearchHasDispositionSchedule; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_ORIGINAL_NAME) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_ORIGINAL_NAME) | ||||
|     private String originalName; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_CLASSIFICATION) | ||||
|     @JsonProperty(PROPERTIES_CLASSIFICATION) | ||||
|     private List<String> classification; | ||||
|  | ||||
|     /*********************************/ | ||||
|     /** Electronic record parameters */ | ||||
|     /*********************************/ | ||||
|     @JsonProperty (PROPERTIES_VERSION_TYPE) | ||||
|     @JsonProperty(PROPERTIES_VERSION_TYPE) | ||||
|     private String versionType; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_VERSION_LABEL) | ||||
|     @JsonProperty(PROPERTIES_VERSION_LABEL) | ||||
|     private String versionLabel; | ||||
|  | ||||
|     @JsonProperty(PROPERTIES_VERSIONED_NODEREF) | ||||
|     private String versionedNodeRef; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RMV_VERSIONED) | ||||
|     @JsonProperty(PROPERTIES_RMV_VERSIONED) | ||||
|     private String recordVersionLabel; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_DATE_TIME_ORIGINAL) | ||||
|     @JsonProperty(PROPERTIES_DATE_TIME_ORIGINAL) | ||||
|     private String dateTimeOriginal; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_EXPOSURE_TIME) | ||||
|     @JsonProperty(PROPERTIES_EXPOSURE_TIME) | ||||
|     private Double exposureTime; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_FLASH) | ||||
|     @JsonProperty(PROPERTIES_FLASH) | ||||
|     private Boolean flash; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_F_NUMBER) | ||||
|     @JsonProperty(PROPERTIES_F_NUMBER) | ||||
|     private Double fNumber; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_FOCAL_LENGTH) | ||||
|     @JsonProperty(PROPERTIES_FOCAL_LENGTH) | ||||
|     private Double focalLength; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ISO_SPEED_RATINGS) | ||||
|     @JsonProperty(PROPERTIES_ISO_SPEED_RATINGS) | ||||
|     private Integer isoSpeedRatings; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_MANUFACTURER) | ||||
|     @JsonProperty(PROPERTIES_MANUFACTURER) | ||||
|     private String manufacturer; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_MODEL) | ||||
|     @JsonProperty(PROPERTIES_MODEL) | ||||
|     private String model; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ORIENTATION) | ||||
|     @JsonProperty(PROPERTIES_ORIENTATION) | ||||
|     private Integer orientation; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PIXEL_X_DIMENSION) | ||||
|     @JsonProperty(PROPERTIES_PIXEL_X_DIMENSION) | ||||
|     private Integer pixelXDimension; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PIXEL_Y_DIMENSION) | ||||
|     @JsonProperty(PROPERTIES_PIXEL_Y_DIMENSION) | ||||
|     private Integer pixelYDimension; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RESOLUTION_UNIT) | ||||
|     @JsonProperty(PROPERTIES_RESOLUTION_UNIT) | ||||
|     private String resolutionUnit; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_SOFTWARE) | ||||
|     @JsonProperty(PROPERTIES_SOFTWARE) | ||||
|     private String software; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_X_RESOLUTION) | ||||
|     @JsonProperty(PROPERTIES_X_RESOLUTION) | ||||
|     private Double xResolution; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_Y_RESOLUTION) | ||||
|     @JsonProperty(PROPERTIES_Y_RESOLUTION) | ||||
|     private Double yResolution; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_ORIGINATING_LOCATION) | ||||
|     @JsonProperty(PROPERTIES_RECORD_ORIGINATING_LOCATION) | ||||
|     private String originatingLocation; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_ORIGINATING_USER_ID) | ||||
|     @JsonProperty(PROPERTIES_RECORD_ORIGINATING_USER_ID) | ||||
|     private String originatingUserId; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_ORIGINATING_CREATION_DATE) | ||||
|     @JsonProperty(PROPERTIES_RECORD_ORIGINATING_CREATION_DATE) | ||||
|     private String originatingCreationDate; | ||||
|  | ||||
|     /*************************************/ | ||||
|     /** Non-electronic record parameters */ | ||||
|     /*************************************/ | ||||
|     @JsonProperty (PROPERTIES_TITLE) | ||||
|     @JsonProperty(PROPERTIES_TITLE) | ||||
|     private String title; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_SHELF) | ||||
|     @JsonProperty(PROPERTIES_SHELF) | ||||
|     private String shelf; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_STORAGE_LOCATION) | ||||
|     @JsonProperty(PROPERTIES_STORAGE_LOCATION) | ||||
|     private String storageLocation; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_FILE) | ||||
|     @JsonProperty(PROPERTIES_FILE) | ||||
|     private String file; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_BOX) | ||||
|     @JsonProperty(PROPERTIES_BOX) | ||||
|     private String box; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_DESCRIPTION) | ||||
|     @JsonProperty(PROPERTIES_DESCRIPTION) | ||||
|     private String description; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_NUMBER_OF_COPIES) | ||||
|     @JsonProperty(PROPERTIES_NUMBER_OF_COPIES) | ||||
|     private Integer numberOfCopies; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PHYSICAL_SIZE) | ||||
|     @JsonProperty(PROPERTIES_PHYSICAL_SIZE) | ||||
|     private Integer physicalSize; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_OWNER) | ||||
|     @JsonProperty(PROPERTIES_OWNER) | ||||
|     private Owner owner; | ||||
|  | ||||
|     @JsonProperty(PROPERTIES_AUTHOR) | ||||
|     private String author; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD_EXPRESSION) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD_EXPRESSION) | ||||
|     private String recordSearchDispositionPeriodExpression; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY) | ||||
|     private String recordSearchDispositionAuthority; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_AS_OF) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_AS_OF) | ||||
|     private Date recordSearchDispositionActionAsOf; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD) | ||||
|     private String recordSearchDispositionPeriod; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_NAME) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_NAME) | ||||
|     private String recordSearchDispositionActionName; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS_ELIGIBLE) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS_ELIGIBLE) | ||||
|     private Boolean recordSearchDispositionEventsEligible; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS) | ||||
|     private List<String> recordSearchDispositionEvents; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_INSTRUCTIONS) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_INSTRUCTIONS) | ||||
|     private String recordSearchDispositionInstructions; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD) | ||||
|     private String recordSearchVitalRecordReviewPeriod; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD_EXPRESSION) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD_EXPRESSION) | ||||
|     private String recordSearchVitalRecordReviewPeriodExpression; | ||||
|  | ||||
|     @JsonProperty(PROPERTIES_REVIEW_AS_OF) | ||||
|     private Date reviewAsOf; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_STORE) | ||||
|     @JsonProperty(PROPERTIES_STORE) | ||||
|     private String store; | ||||
|  | ||||
|     @JsonProperty(PROPERTIES_WORM_UNLOCK_DATE) | ||||
|   | ||||
| @@ -29,17 +29,16 @@ package org.alfresco.rest.rm.community.model.recordcategory; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category | ||||
|  * | ||||
| @@ -59,34 +58,34 @@ public class RecordCategory extends TestModel | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private List<String> aspectNames; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RecordCategoryProperties properties; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -29,17 +29,16 @@ package org.alfresco.rest.rm.community.model.recordcategory; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category child | ||||
|  * | ||||
| @@ -58,28 +57,28 @@ public class RecordCategoryChild extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -27,12 +27,11 @@ | ||||
| package org.alfresco.rest.rm.community.model.recordcategory; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category child entry | ||||
|  * | ||||
|   | ||||
| @@ -32,15 +32,15 @@ import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanCo | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_IS_CLOSED; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_LOCATION; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_OWNER; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD_EXPRESSION; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_AS_OF; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_NAME; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS_ELIGIBLE; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_INSTRUCTIONS; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD_EXPRESSION; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_REVIEW_PERIOD; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_ROOT_NODE_REF; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_TITLE; | ||||
| @@ -51,18 +51,17 @@ import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.rest.rm.community.model.common.ReviewPeriod; | ||||
| import org.alfresco.rest.rm.community.util.ReviewPeriodSerializer; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.rest.rm.community.model.common.ReviewPeriod; | ||||
| import org.alfresco.rest.rm.community.util.ReviewPeriodSerializer; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category child properties | ||||
|  * | ||||
| @@ -79,65 +78,65 @@ public class RecordCategoryChildProperties extends TestModel | ||||
|     /**************************************************************************/ | ||||
|     /** Mandatory parameters - Shared by record categories and record folders */ | ||||
|     /**************************************************************************/ | ||||
|     @JsonProperty (required = true, value = PROPERTIES_TITLE) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_TITLE) | ||||
|     private String title; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_VITAL_RECORD_INDICATOR) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_VITAL_RECORD_INDICATOR) | ||||
|     private Boolean vitalRecordIndicator; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_REVIEW_PERIOD) | ||||
|     @JsonSerialize (using = ReviewPeriodSerializer.class) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_REVIEW_PERIOD) | ||||
|     @JsonSerialize(using = ReviewPeriodSerializer.class) | ||||
|     private ReviewPeriod reviewPeriod; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_DESCRIPTION) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_DESCRIPTION) | ||||
|     private String description; | ||||
|  | ||||
|     /*********************************************************/ | ||||
|     /** Optional parameters - Applies only to record folders */ | ||||
|     /*********************************************************/ | ||||
|     @JsonProperty (PROPERTIES_HELD_CHILDREN_COUNT) | ||||
|     @JsonProperty(PROPERTIES_HELD_CHILDREN_COUNT) | ||||
|     private Integer heldChildrenCount; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_LOCATION) | ||||
|     @JsonProperty(PROPERTIES_LOCATION) | ||||
|     private String location; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_IS_CLOSED) | ||||
|     @JsonProperty(PROPERTIES_IS_CLOSED) | ||||
|     private Boolean isClosed; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     private Boolean recordSearchHasDispositionSchedule; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD_EXPRESSION) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD_EXPRESSION) | ||||
|     private String recordSearchDispositionPeriodExpression; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY) | ||||
|     private String recordSearchDispositionAuthority; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_AS_OF) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_AS_OF) | ||||
|     private Date recordSearchDispositionActionAsOf; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_PERIOD) | ||||
|     private String recordSearchDispositionPeriod; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_NAME) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_ACTION_NAME) | ||||
|     private String recordSearchDispositionActionName; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS_ELIGIBLE) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS_ELIGIBLE) | ||||
|     private Boolean recordSearchDispositionEventsEligible; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_INSTRUCTIONS) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_INSTRUCTIONS) | ||||
|     private String recordSearchDispositionInstructions; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_EVENTS) | ||||
|     private List<String> recordSearchDispositionEvents; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_OWNER) | ||||
|     @JsonProperty(PROPERTIES_OWNER) | ||||
|     private Owner owner; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -27,13 +27,12 @@ | ||||
| package org.alfresco.rest.rm.community.model.recordcategory; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
| import org.alfresco.rest.rm.community.model.fileplan.FilePlan; | ||||
|  | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| /** | ||||
|  * POJO for file plan entry | ||||
|  * | ||||
|   | ||||
| @@ -35,24 +35,22 @@ import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanCo | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_TITLE; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_VITAL_RECORD_INDICATOR; | ||||
|  | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.rest.rm.community.model.common.ReviewPeriod; | ||||
| import org.alfresco.rest.rm.community.util.ReviewPeriodSerializer; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.rest.rm.community.model.common.ReviewPeriod; | ||||
| import org.alfresco.rest.rm.community.util.ReviewPeriodSerializer; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category properties | ||||
|  * | ||||
| @@ -64,37 +62,37 @@ import lombok.NoArgsConstructor; | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| @JsonIgnoreProperties (ignoreUnknown = true) | ||||
| @JsonIgnoreProperties(ignoreUnknown = true) | ||||
| public class RecordCategoryProperties extends TestModel | ||||
| { | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_REVIEW_PERIOD) | ||||
|     @JsonSerialize (using = ReviewPeriodSerializer.class) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_REVIEW_PERIOD) | ||||
|     @JsonSerialize(using = ReviewPeriodSerializer.class) | ||||
|     private ReviewPeriod reviewPeriod; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_VITAL_RECORD_INDICATOR) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_VITAL_RECORD_INDICATOR) | ||||
|     private Boolean vitalRecordIndicator; | ||||
|  | ||||
|     /************************/ | ||||
|     /** Optional parameters */ | ||||
|     /************************/ | ||||
|     @JsonProperty (PROPERTIES_TITLE) | ||||
|     @JsonProperty(PROPERTIES_TITLE) | ||||
|     private String title; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_DESCRIPTION) | ||||
|     @JsonProperty(PROPERTIES_DESCRIPTION) | ||||
|     private String description; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_OWNER) | ||||
|     @JsonProperty(PROPERTIES_OWNER) | ||||
|     private Owner owner; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_CLASSIFICATION) | ||||
|     @JsonProperty(PROPERTIES_CLASSIFICATION) | ||||
|     private List<String> classification; | ||||
| } | ||||
|   | ||||
| @@ -29,17 +29,16 @@ package org.alfresco.rest.rm.community.model.recordfolder; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for record folder | ||||
|  * | ||||
| @@ -56,34 +55,34 @@ public class RecordFolder extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private List<String> aspectNames; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RecordFolderProperties properties; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -27,16 +27,15 @@ | ||||
| package org.alfresco.rest.rm.community.model.recordfolder; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
| import org.alfresco.rest.rm.community.model.record.Record; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
| import org.alfresco.rest.rm.community.model.record.Record; | ||||
|  | ||||
| /** | ||||
|  * POJO for record folder entry | ||||
|  * | ||||
|   | ||||
| @@ -33,10 +33,8 @@ import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanCo | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_IS_CLOSED; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_LOCATION; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_OWNER; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields | ||||
|         .PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields | ||||
|         .PROPERTIES_RECORD_SEARCH_DISPOSITION_INSTRUCTIONS; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_DISPOSITION_INSTRUCTIONS; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD_EXPRESSION; | ||||
| @@ -50,18 +48,17 @@ import java.util.List; | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.rest.rm.community.model.common.ReviewPeriod; | ||||
| import org.alfresco.rest.rm.community.util.ReviewPeriodSerializer; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.rest.rm.community.model.common.ReviewPeriod; | ||||
| import org.alfresco.rest.rm.community.util.ReviewPeriodSerializer; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for record folder properties | ||||
|  * | ||||
| @@ -73,62 +70,62 @@ import lombok.NoArgsConstructor; | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| @JsonIgnoreProperties (ignoreUnknown = true) | ||||
| @JsonIgnoreProperties(ignoreUnknown = true) | ||||
| public class RecordFolderProperties extends TestModel | ||||
| { | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IS_CLOSED) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IS_CLOSED) | ||||
|     private Boolean isClosed; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_HELD_CHILDREN_COUNT) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_HELD_CHILDREN_COUNT) | ||||
|     private Integer heldChildrenCount; | ||||
|  | ||||
|     /************************/ | ||||
|     /** Optional parameters */ | ||||
|     /************************/ | ||||
|     @JsonProperty (PROPERTIES_TITLE) | ||||
|     @JsonProperty(PROPERTIES_TITLE) | ||||
|     private String title; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_VITAL_RECORD_INDICATOR) | ||||
|     @JsonProperty(PROPERTIES_VITAL_RECORD_INDICATOR) | ||||
|     private Boolean vitalRecordIndicator; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_LOCATION) | ||||
|     @JsonProperty(PROPERTIES_LOCATION) | ||||
|     private String location; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     private Boolean recordSearchHasDispositionSchedule; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_REVIEW_PERIOD) | ||||
|     @JsonSerialize (using = ReviewPeriodSerializer.class) | ||||
|     @JsonProperty(PROPERTIES_REVIEW_PERIOD) | ||||
|     @JsonSerialize(using = ReviewPeriodSerializer.class) | ||||
|     private ReviewPeriod reviewPeriod; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_CLASSIFICATION) | ||||
|     @JsonProperty(PROPERTIES_CLASSIFICATION) | ||||
|     private List<String> classification; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_DESCRIPTION) | ||||
|     @JsonProperty(PROPERTIES_DESCRIPTION) | ||||
|     private String description; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_OWNER) | ||||
|     @JsonProperty(PROPERTIES_OWNER) | ||||
|     private Owner owner; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD) | ||||
|     private String recordSearchVitalRecordReviewPeriod; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD_EXPRESSION) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_VITAL_RECORD_REVIEW_PERIOD_EXPRESSION) | ||||
|     private String recordSearchVitalRecordReviewPeriodExpression; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_AUTHORITY) | ||||
|     private String recordSearchDispositionAuthority; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_DISPOSITION_INSTRUCTIONS) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_DISPOSITION_INSTRUCTIONS) | ||||
|     private String recordSearchDispositionInstructions; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -26,12 +26,13 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model.retentionschedule; | ||||
|  | ||||
| import lombok.EqualsAndHashCode; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
| import lombok.Data; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * retention schedule | ||||
|  */ | ||||
| @@ -39,7 +40,7 @@ import java.util.List; | ||||
| @Data | ||||
| public class RetentionSchedule extends TestModel | ||||
| { | ||||
|     private String id ; | ||||
|     private String id; | ||||
|     private String parentId; | ||||
|     private String authority; | ||||
|     private String instructions; | ||||
| @@ -52,7 +53,8 @@ public class RetentionSchedule extends TestModel | ||||
|         return isRecordLevel; | ||||
|     } | ||||
|  | ||||
|     public void setIsRecordLevel(boolean recordLevel) { | ||||
|     public void setIsRecordLevel(boolean recordLevel) | ||||
|     { | ||||
|         isRecordLevel = recordLevel; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -27,6 +27,7 @@ | ||||
| package org.alfresco.rest.rm.community.model.retentionschedule; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| import lombok.Data; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -27,6 +27,6 @@ | ||||
| package org.alfresco.rest.rm.community.model.retentionschedule; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| public class RetentionScheduleCollection extends RestModels<RetentionScheduleEntry, RetentionScheduleCollection> | ||||
| { | ||||
| } | ||||
| {} | ||||
|   | ||||
| @@ -28,7 +28,9 @@ package org.alfresco.rest.rm.community.model.retentionschedule; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import lombok.Data; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| @Data | ||||
| public class RetentionScheduleEntry extends RestModels<RetentionSchedule, RetentionScheduleEntry> | ||||
| { | ||||
|   | ||||
| @@ -29,5 +29,4 @@ package org.alfresco.rest.rm.community.model.retentionschedule; | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| public class RetentionScheduleStepCollection extends RestModels<RetentionScheduleStepEntry, RetentionScheduleStepCollection> | ||||
| { | ||||
| } | ||||
| {} | ||||
|   | ||||
| @@ -28,6 +28,7 @@ package org.alfresco.rest.rm.community.model.retentionschedule; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import lombok.Data; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| @Data | ||||
|   | ||||
| @@ -31,26 +31,7 @@ package org.alfresco.rest.rm.community.model.rules; | ||||
|  */ | ||||
| public enum ActionsOnRule | ||||
| { | ||||
|     COMPLETE_RECORD("declareRecord"), | ||||
|     REOPEN_RECORD("undeclareRecord"), | ||||
|     OPEN_RECORD_FOLDER("openRecordFolder"), | ||||
|     CLOSE_RECORD_FOLDER("closeRecordFolder"), | ||||
|     FILE_TO("fileTo"), | ||||
|     COPY_TO("copyTo"), | ||||
|     MOVE_TO("moveTo"), | ||||
|     LINK_TO("linkTo"), | ||||
|     REJECT("reject"), | ||||
|     REQUEST_INFORMATION("requestInfo"), | ||||
|     COMPLETE_EVENT("completeEvent"), | ||||
|     ADD_RECORD_TYPES("addRecordTypes"), | ||||
|     EXECUTE_SCRIPT("executeScript"), | ||||
|     SEND_EMAIL("sendEmail"), | ||||
|     SET_PROPERTY_VALUE_COLL_SITE("set-property-value"), | ||||
|     SET_PROPERTY_VALUE_RM("setPropertyValue"), | ||||
|     HIDE_RECORD("hide-record"), | ||||
|     DECLARE_VERSION_AS_RECORD("declare-as-version-record"), | ||||
|     DECLARE_AS_RECORD("create-record"), | ||||
|     WORM_LOCK("wormLock"); | ||||
|     COMPLETE_RECORD("declareRecord"), REOPEN_RECORD("undeclareRecord"), OPEN_RECORD_FOLDER("openRecordFolder"), CLOSE_RECORD_FOLDER("closeRecordFolder"), FILE_TO("fileTo"), COPY_TO("copyTo"), MOVE_TO("moveTo"), LINK_TO("linkTo"), REJECT("reject"), REQUEST_INFORMATION("requestInfo"), COMPLETE_EVENT("completeEvent"), ADD_RECORD_TYPES("addRecordTypes"), EXECUTE_SCRIPT("executeScript"), SEND_EMAIL("sendEmail"), SET_PROPERTY_VALUE_COLL_SITE("set-property-value"), SET_PROPERTY_VALUE_RM("setPropertyValue"), HIDE_RECORD("hide-record"), DECLARE_VERSION_AS_RECORD("declare-as-version-record"), DECLARE_AS_RECORD("create-record"), WORM_LOCK("wormLock"); | ||||
|  | ||||
|     private String actionValue; | ||||
|  | ||||
|   | ||||
| @@ -31,18 +31,17 @@ package org.alfresco.rest.rm.community.model.rules; | ||||
|  */ | ||||
| public enum ConditionsOnRule | ||||
| { | ||||
|     UPDATE("update"), | ||||
|     ADDED("inbound"), | ||||
|     REMOVED("outbound"); | ||||
|     UPDATE("update"), ADDED("inbound"), REMOVED("outbound"); | ||||
|  | ||||
|     private String whenConditionValue; | ||||
|  | ||||
|     ConditionsOnRule(String value) | ||||
|     { | ||||
|             this.whenConditionValue = value; | ||||
|         this.whenConditionValue = value; | ||||
|     } | ||||
|  | ||||
|     public String getWhenConditionValue() | ||||
|     { | ||||
|             return whenConditionValue; | ||||
|         return whenConditionValue; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -200,4 +200,3 @@ public class RuleDefinition | ||||
|         return this; | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -27,15 +27,14 @@ | ||||
| package org.alfresco.rest.rm.community.model.site; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.model.RestSiteModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestSiteModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for RM Site component | ||||
|  * | ||||
| @@ -48,7 +47,7 @@ import lombok.NoArgsConstructor; | ||||
| @AllArgsConstructor | ||||
| public class RMSite extends RestSiteModel | ||||
| { | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RMSiteCompliance compliance; | ||||
|  | ||||
|     /** Private constructor allowing Lombok to include superclass fields in the builder. */ | ||||
|   | ||||
| @@ -34,6 +34,5 @@ package org.alfresco.rest.rm.community.model.site; | ||||
|  */ | ||||
| public enum RMSiteCompliance | ||||
| { | ||||
|     STANDARD, | ||||
|     DOD5015 | ||||
|     STANDARD, DOD5015 | ||||
| } | ||||
|   | ||||
| @@ -27,16 +27,8 @@ | ||||
| package org.alfresco.rest.rm.community.model.site; | ||||
|  | ||||
| /** | ||||
|  *RM Site properties from the RM Model Schema | ||||
|  *"entry": { | ||||
|  *      "id": "string", | ||||
|  *      "guid": "string", | ||||
|  *      "title": "string", | ||||
|  *      "description": "string", | ||||
|  *      "visibility": "{@link org.springframework.social.alfresco.api.entities.Site.Visibility}", | ||||
|  *      "compliance": "{@link RMSiteCompliance}", | ||||
|  *      "role": "{@link org.alfresco.utility.constants.UserRole}" | ||||
|  *} | ||||
|  * RM Site properties from the RM Model Schema "entry": { "id": "string", "guid": "string", "title": "string", "description": "string", "visibility": "{@link org.springframework.social.alfresco.api.entities.Site.Visibility}", "compliance": "{@link RMSiteCompliance}", "role": "{@link org.alfresco.utility.constants.UserRole}" } | ||||
|  *  | ||||
|  * @author Tuna Aksoy | ||||
|  * @author Rodica Sutu | ||||
|  * @since 2.6 | ||||
| @@ -47,6 +39,6 @@ public class RMSiteFields | ||||
|     public static final String COMPLIANCE = "compliance"; | ||||
|     public static final String TITLE = "title"; | ||||
|     public static final String DESCRIPTION = "description"; | ||||
|     public static final String VISIBILITY ="visibility"; | ||||
|     public static final String VISIBILITY = "visibility"; | ||||
|     public static final String ROLE = "role"; | ||||
| } | ||||
|   | ||||
| @@ -30,16 +30,15 @@ package org.alfresco.rest.rm.community.model.transfer; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for Transfer | ||||
|  * | ||||
| @@ -56,28 +55,28 @@ public class Transfer extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private List<String> aspectNames; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private TransferProperties properties; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -30,17 +30,16 @@ package org.alfresco.rest.rm.community.model.transfer; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for transfer child | ||||
|  * | ||||
| @@ -57,28 +56,28 @@ public class TransferChild extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -31,6 +31,7 @@ import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|  * Handle collection of {@link TransferChildEntry} | ||||
|  *  | ||||
|  * @author Silviu Dinuta | ||||
|  * @since 2.6 | ||||
|  */ | ||||
|   | ||||
| @@ -27,16 +27,15 @@ | ||||
|  | ||||
| package org.alfresco.rest.rm.community.model.transfer; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|  * POJO for transfer child entry | ||||
|  * | ||||
|   | ||||
| @@ -64,20 +64,19 @@ import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanCo | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_X_RESOLUTION; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_Y_RESOLUTION; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.rest.rm.community.model.common.ReviewPeriod; | ||||
| import org.alfresco.rest.rm.community.util.ReviewPeriodSerializer; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.rest.rm.community.model.common.ReviewPeriod; | ||||
| import org.alfresco.rest.rm.community.util.ReviewPeriodSerializer; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for transfer child properties | ||||
|  * | ||||
| @@ -92,128 +91,127 @@ import lombok.NoArgsConstructor; | ||||
| public class TransferChildProperties extends TestModel | ||||
| { | ||||
|     /**************************************************************************/ | ||||
|     /** Mandatory parameters - Shared by record folders and records*/ | ||||
|     /** Mandatory parameters - Shared by record folders and records */ | ||||
|     /**************************************************************************/ | ||||
|     @JsonProperty (PROPERTIES_TITLE) | ||||
|     @JsonProperty(PROPERTIES_TITLE) | ||||
|     private String title; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_DESCRIPTION) | ||||
|     @JsonProperty(PROPERTIES_DESCRIPTION) | ||||
|     private String description; | ||||
|  | ||||
|     /*********************************************************/ | ||||
|     /** Optional parameters - Applies only to record folders */ | ||||
|     /*********************************************************/ | ||||
|     @JsonProperty (PROPERTIES_VITAL_RECORD_INDICATOR) | ||||
|     @JsonProperty(PROPERTIES_VITAL_RECORD_INDICATOR) | ||||
|     private Boolean vitalRecordIndicator; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_REVIEW_PERIOD) | ||||
|     @JsonSerialize (using = ReviewPeriodSerializer.class) | ||||
|     @JsonProperty(PROPERTIES_REVIEW_PERIOD) | ||||
|     @JsonSerialize(using = ReviewPeriodSerializer.class) | ||||
|     private ReviewPeriod reviewPeriod; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_HELD_CHILDREN_COUNT) | ||||
|     @JsonProperty(PROPERTIES_HELD_CHILDREN_COUNT) | ||||
|     private Integer heldChildrenCount; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_LOCATION) | ||||
|     @JsonProperty(PROPERTIES_LOCATION) | ||||
|     private String location; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_IS_CLOSED) | ||||
|     @JsonProperty(PROPERTIES_IS_CLOSED) | ||||
|     private Boolean isClosed; | ||||
|  | ||||
|     /*********************************************************/ | ||||
|     /** Optional parameters - Applies only to records */ | ||||
|     /*********************************************************/ | ||||
|     @JsonProperty (PROPERTIES_DATE_FILED) | ||||
|     @JsonProperty(PROPERTIES_DATE_FILED) | ||||
|     private String dateField; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     @JsonProperty(PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     private Boolean recordSearchHasDispositionSchedule; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ORIGINAL_NAME) | ||||
|     @JsonProperty(PROPERTIES_ORIGINAL_NAME) | ||||
|     private String originalName; | ||||
|  | ||||
|  | ||||
|     /*********************************/ | ||||
|     /** Electronic record parameters */ | ||||
|     /*********************************/ | ||||
|     @JsonProperty (PROPERTIES_VERSION_TYPE) | ||||
|     @JsonProperty(PROPERTIES_VERSION_TYPE) | ||||
|     private String versionType; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_VERSION_LABEL) | ||||
|     @JsonProperty(PROPERTIES_VERSION_LABEL) | ||||
|     private String versionLabel; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_DATE_TIME_ORIGINAL) | ||||
|     @JsonProperty(PROPERTIES_DATE_TIME_ORIGINAL) | ||||
|     private String dateTimeOriginal; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_EXPOSURE_TIME) | ||||
|     @JsonProperty(PROPERTIES_EXPOSURE_TIME) | ||||
|     private Double exposureTime; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_FLASH) | ||||
|     @JsonProperty(PROPERTIES_FLASH) | ||||
|     private Boolean flash; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_F_NUMBER) | ||||
|     @JsonProperty(PROPERTIES_F_NUMBER) | ||||
|     private Double fNumber; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_FOCAL_LENGTH) | ||||
|     @JsonProperty(PROPERTIES_FOCAL_LENGTH) | ||||
|     private Double focalLength; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ISO_SPEED_RATINGS) | ||||
|     @JsonProperty(PROPERTIES_ISO_SPEED_RATINGS) | ||||
|     private Integer isoSpeedRatings; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_MANUFACTURER) | ||||
|     @JsonProperty(PROPERTIES_MANUFACTURER) | ||||
|     private String manufacturer; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_MODEL) | ||||
|     @JsonProperty(PROPERTIES_MODEL) | ||||
|     private String model; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ORIENTATION) | ||||
|     @JsonProperty(PROPERTIES_ORIENTATION) | ||||
|     private Integer orientation; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PIXEL_X_DIMENSION) | ||||
|     @JsonProperty(PROPERTIES_PIXEL_X_DIMENSION) | ||||
|     private Integer pixelXDimension; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PIXEL_Y_DIMENSION) | ||||
|     @JsonProperty(PROPERTIES_PIXEL_Y_DIMENSION) | ||||
|     private Integer pixelYDimension; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RESOLUTION_UNIT) | ||||
|     @JsonProperty(PROPERTIES_RESOLUTION_UNIT) | ||||
|     private String resolutionUnit; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_SOFTWARE) | ||||
|     @JsonProperty(PROPERTIES_SOFTWARE) | ||||
|     private String software; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_X_RESOLUTION) | ||||
|     @JsonProperty(PROPERTIES_X_RESOLUTION) | ||||
|     private Double xResolution; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_Y_RESOLUTION) | ||||
|     @JsonProperty(PROPERTIES_Y_RESOLUTION) | ||||
|     private Double yResolution; | ||||
|  | ||||
|     /*************************************/ | ||||
|     /** Non-electronic record parameters */ | ||||
|     /*************************************/ | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_SHELF) | ||||
|     @JsonProperty(PROPERTIES_SHELF) | ||||
|     private String shelf; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_STORAGE_LOCATION) | ||||
|     @JsonProperty(PROPERTIES_STORAGE_LOCATION) | ||||
|     private String storageLocation; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_FILE) | ||||
|     @JsonProperty(PROPERTIES_FILE) | ||||
|     private String file; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_BOX) | ||||
|     @JsonProperty(PROPERTIES_BOX) | ||||
|     private String box; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_NUMBER_OF_COPIES) | ||||
|     @JsonProperty(PROPERTIES_NUMBER_OF_COPIES) | ||||
|     private Integer numberOfCopies; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PHYSICAL_SIZE) | ||||
|     @JsonProperty(PROPERTIES_PHYSICAL_SIZE) | ||||
|     private Integer physicalSize; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_OWNER) | ||||
|     @JsonProperty(PROPERTIES_OWNER) | ||||
|     private Owner owner; | ||||
| } | ||||
|   | ||||
| @@ -31,6 +31,7 @@ import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|  * Handle collection of {@link TransferEntry} | ||||
|  *  | ||||
|  * @author Silviu Dinuta | ||||
|  * @since 2.6 | ||||
|  */ | ||||
|   | ||||
| @@ -27,17 +27,16 @@ | ||||
|  | ||||
| package org.alfresco.rest.rm.community.model.transfer; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
| import org.alfresco.rest.rm.community.model.transfercontainer.TransferContainer; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
| import org.alfresco.rest.rm.community.model.transfercontainer.TransferContainer; | ||||
|  | ||||
| /** | ||||
|  * POJO for transfer entry | ||||
|  * | ||||
|   | ||||
| @@ -27,24 +27,23 @@ | ||||
|  | ||||
| package org.alfresco.rest.rm.community.model.transfer; | ||||
|  | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_ACCESSION_INDICATOR; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_IDENTIFIER; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_OWNER; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_ROOT_NODE_REF; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_PDF_INDICATOR; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_ROOT_NODE_REF; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_TRANSFER_LOCATION; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_ACCESSION_INDICATOR; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for Transfer properties | ||||
|  * | ||||
| @@ -61,24 +60,24 @@ public class TransferProperties extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     /************************/ | ||||
|     /** Optional parameters */ | ||||
|     /************************/ | ||||
|     @JsonProperty (PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_OWNER) | ||||
|     @JsonProperty(PROPERTIES_OWNER) | ||||
|     private Owner owner; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PDF_INDICATOR) | ||||
|     @JsonProperty(PROPERTIES_PDF_INDICATOR) | ||||
|     private Boolean pdfIndicator; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_TRANSFER_LOCATION) | ||||
|     @JsonProperty(PROPERTIES_TRANSFER_LOCATION) | ||||
|     private String transferLocation; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ACCESSION_INDICATOR) | ||||
|     @JsonProperty(PROPERTIES_ACCESSION_INDICATOR) | ||||
|     private Boolean accessionIndicator; | ||||
| } | ||||
|   | ||||
| @@ -30,16 +30,15 @@ package org.alfresco.rest.rm.community.model.transfercontainer; | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for Transfer Container | ||||
|  * | ||||
| @@ -56,34 +55,34 @@ public class TransferContainer extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private List<String> aspectNames; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private TransferContainerProperties properties; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -31,16 +31,15 @@ import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanCo | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_IDENTIFIER; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentFields.PROPERTIES_ROOT_NODE_REF; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for Transfer Container properties | ||||
|  * | ||||
| @@ -57,16 +56,16 @@ public class TransferContainerProperties extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     /************************/ | ||||
|     /** Optional parameters */ | ||||
|     /************************/ | ||||
|     @JsonProperty (PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_COUNT) | ||||
|     @JsonProperty(PROPERTIES_COUNT) | ||||
|     private Integer count; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -28,18 +28,17 @@ package org.alfresco.rest.rm.community.model.unfiledcontainer; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for unfiled container | ||||
|  * | ||||
| @@ -56,34 +55,34 @@ public class UnfiledContainer extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private List<String> aspectNames; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private UnfiledContainerProperties properties; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -28,20 +28,19 @@ package org.alfresco.rest.rm.community.model.unfiledcontainer; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.rest.rm.community.model.record.RecordContent; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.rest.rm.community.model.record.RecordContent; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category child | ||||
|  * | ||||
| @@ -53,40 +52,40 @@ import lombok.NoArgsConstructor; | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| @JsonIgnoreProperties (ignoreUnknown = true) | ||||
| @JsonIgnoreProperties(ignoreUnknown = true) | ||||
| public class UnfiledContainerChild extends TestModel | ||||
| { | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private Boolean isUnfiledRecordFolder; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private Boolean isRecord; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -27,12 +27,11 @@ | ||||
| package org.alfresco.rest.rm.community.model.unfiledcontainer; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category child entry | ||||
|  * | ||||
|   | ||||
| @@ -61,16 +61,15 @@ import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanCo | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.rm.community.model.common.Owner; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category child properties | ||||
|  * | ||||
| @@ -83,112 +82,112 @@ import lombok.NoArgsConstructor; | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| @JsonIgnoreProperties (ignoreUnknown = true) | ||||
| @JsonIgnoreProperties(ignoreUnknown = true) | ||||
| public class UnfiledContainerChildProperties extends TestModel | ||||
| { | ||||
|     /**************************************************************************/ | ||||
|     /** Mandatory parameters - Shared by unfiled record folder and records */ | ||||
|     /**************************************************************************/ | ||||
|     @JsonProperty (required = true, value = PROPERTIES_TITLE) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_TITLE) | ||||
|     private String title; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_DESCRIPTION) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_DESCRIPTION) | ||||
|     private String description; | ||||
|  | ||||
|     @JsonProperty (value = PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     @JsonProperty(value = PROPERTIES_RECORD_SEARCH_HAS_DISPOSITION_SCHEDULE) | ||||
|     private Boolean recordSearchHasDispositionSchedule; | ||||
|  | ||||
|     /*********************************/ | ||||
|     /** Electronic record parameters */ | ||||
|     /*********************************/ | ||||
|     @JsonProperty (PROPERTIES_VERSION_TYPE) | ||||
|     @JsonProperty(PROPERTIES_VERSION_TYPE) | ||||
|     private String versionType; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_VERSION_LABEL) | ||||
|     @JsonProperty(PROPERTIES_VERSION_LABEL) | ||||
|     private String versionLabel; | ||||
|  | ||||
|     @JsonProperty(PROPERTIES_VERSIONED_NODEREF) | ||||
|     private String versionedNodeRef; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RMV_VERSIONED) | ||||
|     @JsonProperty(PROPERTIES_RMV_VERSIONED) | ||||
|     private String recordVersionLabel; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_DATE_TIME_ORIGINAL) | ||||
|     @JsonProperty(PROPERTIES_DATE_TIME_ORIGINAL) | ||||
|     private String dateTimeOriginal; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_EXPOSURE_TIME) | ||||
|     @JsonProperty(PROPERTIES_EXPOSURE_TIME) | ||||
|     private Double exposureTime; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_FLASH) | ||||
|     @JsonProperty(PROPERTIES_FLASH) | ||||
|     private Boolean flash; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_F_NUMBER) | ||||
|     @JsonProperty(PROPERTIES_F_NUMBER) | ||||
|     private Double fNumber; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_FOCAL_LENGTH) | ||||
|     @JsonProperty(PROPERTIES_FOCAL_LENGTH) | ||||
|     private Double focalLength; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ISO_SPEED_RATINGS) | ||||
|     @JsonProperty(PROPERTIES_ISO_SPEED_RATINGS) | ||||
|     private Integer isoSpeedRatings; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_MANUFACTURER) | ||||
|     @JsonProperty(PROPERTIES_MANUFACTURER) | ||||
|     private String manufacturer; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_MODEL) | ||||
|     @JsonProperty(PROPERTIES_MODEL) | ||||
|     private String model; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ORIENTATION) | ||||
|     @JsonProperty(PROPERTIES_ORIENTATION) | ||||
|     private Integer orientation; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PIXEL_X_DIMENSION) | ||||
|     @JsonProperty(PROPERTIES_PIXEL_X_DIMENSION) | ||||
|     private Integer pixelXDimension; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PIXEL_Y_DIMENSION) | ||||
|     @JsonProperty(PROPERTIES_PIXEL_Y_DIMENSION) | ||||
|     private Integer pixelYDimension; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_RESOLUTION_UNIT) | ||||
|     @JsonProperty(PROPERTIES_RESOLUTION_UNIT) | ||||
|     private String resolutionUnit; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_SOFTWARE) | ||||
|     @JsonProperty(PROPERTIES_SOFTWARE) | ||||
|     private String software; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_X_RESOLUTION) | ||||
|     @JsonProperty(PROPERTIES_X_RESOLUTION) | ||||
|     private Double xResolution; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_Y_RESOLUTION) | ||||
|     @JsonProperty(PROPERTIES_Y_RESOLUTION) | ||||
|     private Double yResolution; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_ORIGINAL_NAME) | ||||
|     @JsonProperty(PROPERTIES_ORIGINAL_NAME) | ||||
|     private String originalName; | ||||
|  | ||||
|     /*************************************/ | ||||
|     /** Non-electronic record parameters */ | ||||
|     /*************************************/ | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_SHELF) | ||||
|     @JsonProperty(PROPERTIES_SHELF) | ||||
|     private String shelf; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_STORAGE_LOCATION) | ||||
|     @JsonProperty(PROPERTIES_STORAGE_LOCATION) | ||||
|     private String storageLocation; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_FILE) | ||||
|     @JsonProperty(PROPERTIES_FILE) | ||||
|     private String file; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_BOX) | ||||
|     @JsonProperty(PROPERTIES_BOX) | ||||
|     private String box; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_NUMBER_OF_COPIES) | ||||
|     @JsonProperty(PROPERTIES_NUMBER_OF_COPIES) | ||||
|     private Integer numberOfCopies; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_PHYSICAL_SIZE) | ||||
|     @JsonProperty(PROPERTIES_PHYSICAL_SIZE) | ||||
|     private Integer physicalSize; | ||||
|  | ||||
|     @JsonProperty (PROPERTIES_OWNER) | ||||
|     @JsonProperty(PROPERTIES_OWNER) | ||||
|     private Owner owner; | ||||
| } | ||||
|   | ||||
| @@ -31,15 +31,14 @@ import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanCo | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for file plan properties | ||||
|  * | ||||
| @@ -51,15 +50,15 @@ import lombok.NoArgsConstructor; | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| @JsonIgnoreProperties (ignoreUnknown = true) | ||||
| @JsonIgnoreProperties(ignoreUnknown = true) | ||||
| public class UnfiledContainerProperties extends TestModel | ||||
| { | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_IDENTIFIER) | ||||
|     private String identifier; | ||||
|  | ||||
|     @JsonProperty (required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     @JsonProperty(required = true, value = PROPERTIES_ROOT_NODE_REF) | ||||
|     private String rootNodeRef; | ||||
| } | ||||
|   | ||||
| @@ -28,19 +28,18 @@ package org.alfresco.rest.rm.community.model.unfiledcontainer; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.rest.rm.community.model.record.RecordContent; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.rest.model.RestByUserModel; | ||||
| import org.alfresco.rest.rm.community.model.common.Path; | ||||
| import org.alfresco.rest.rm.community.model.record.RecordContent; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for unfiled container | ||||
|  * | ||||
| @@ -57,28 +56,28 @@ public class UnfiledRecordFolder extends TestModel | ||||
|     /*************************/ | ||||
|     /** Mandatory parameters */ | ||||
|     /*************************/ | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String createdAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel createdByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String modifiedAt; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private RestByUserModel modifiedByUser; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String id; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String nodeType; | ||||
|  | ||||
|     @JsonProperty (required = true) | ||||
|     @JsonProperty(required = true) | ||||
|     private String parentId; | ||||
|  | ||||
|     /************************/ | ||||
|   | ||||
| @@ -34,9 +34,7 @@ package org.alfresco.rest.rm.community.model.user; | ||||
|  */ | ||||
| public enum UserPermissions | ||||
| { | ||||
|     PERMISSION_FILING("Filing"), | ||||
|     PERMISSION_READ_RECORDS("ReadRecords"), | ||||
|     PERMISSION_FILE_RECORDS("FileRecords"); | ||||
|     PERMISSION_FILING("Filing"), PERMISSION_READ_RECORDS("ReadRecords"), PERMISSION_FILE_RECORDS("FileRecords"); | ||||
|  | ||||
|     public final String permissionId; | ||||
|  | ||||
|   | ||||
| @@ -35,12 +35,7 @@ package org.alfresco.rest.rm.community.model.user; | ||||
|  */ | ||||
| public enum UserRoles | ||||
| { | ||||
|     IN_PLACE_WRITERS("ExtendedWriters", "In-Place Writers"), | ||||
|     ROLE_RM_ADMIN("Administrator", "Records Management Administrator"), | ||||
|     ROLE_RM_MANAGER("RecordsManager", "Records Management Manager"), | ||||
|     ROLE_RM_POWER_USER("PowerUser", "Records Management Power User"), | ||||
|     ROLE_RM_SECURITY_OFFICER("SecurityOfficer", "Records Management Security Officer"), | ||||
|     ROLE_RM_USER("User", "Records Management User"); | ||||
|     IN_PLACE_WRITERS("ExtendedWriters", "In-Place Writers"), ROLE_RM_ADMIN("Administrator", "Records Management Administrator"), ROLE_RM_MANAGER("RecordsManager", "Records Management Manager"), ROLE_RM_POWER_USER("PowerUser", "Records Management Power User"), ROLE_RM_SECURITY_OFFICER("SecurityOfficer", "Records Management Security Officer"), ROLE_RM_USER("User", "Records Management User"); | ||||
|  | ||||
|     public final String roleId; | ||||
|     public final String displayName; | ||||
| @@ -51,5 +46,4 @@ public enum UserRoles | ||||
|         this.displayName = displayName; | ||||
|     } | ||||
|  | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -29,12 +29,12 @@ package org.alfresco.rest.rm.community.requests; | ||||
| import static lombok.AccessLevel.PRIVATE; | ||||
| import static lombok.AccessLevel.PROTECTED; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.requests.ModelRequest; | ||||
|  | ||||
| import lombok.Getter; | ||||
| import lombok.Setter; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.requests.ModelRequest; | ||||
|  | ||||
| /** | ||||
|  * Extends {@link ModelRequest} to set {@link RMRestWrapper} | ||||
|  * | ||||
| @@ -43,8 +43,8 @@ import lombok.Setter; | ||||
|  */ | ||||
| public abstract class RMModelRequest<Request> extends ModelRequest<Request> | ||||
| { | ||||
|     @Getter (value = PROTECTED) | ||||
|     @Setter (value = PRIVATE) | ||||
|     @Getter(value = PROTECTED) | ||||
|     @Setter(value = PRIVATE) | ||||
|     private RMRestWrapper rmRestWrapper; | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -33,8 +33,8 @@ import io.restassured.RestAssured; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestProperties; | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.ActionsExecutionAPI; | ||||
| import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.ActionsExecutionAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.FilePlanAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.FilesAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.HoldsAPI; | ||||
| @@ -43,15 +43,14 @@ import org.alfresco.rest.rm.community.requests.gscore.api.RMUserAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RecordCategoryAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RecordFolderAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RecordsAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RetentionScheduleAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.TransferAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.TransferContainerAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.UnfiledContainerAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.UnfiledRecordFolderAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.RetentionScheduleAPI; | ||||
|  | ||||
| /** | ||||
|  * Defines the entire GS Core API | ||||
|  * {@link http://host:port/gs-api-explorer} select "GS Core API" | ||||
|  * Defines the entire GS Core API {@link http://host:port/gs-api-explorer} select "GS Core API" | ||||
|  * | ||||
|  * @author Tuna Aksoy | ||||
|  * @since 2.6 | ||||
| @@ -61,8 +60,10 @@ public class GSCoreAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Constructor | ||||
|      * | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestProperties RM REST Properties | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      * @param rmRestProperties | ||||
|      *            RM REST Properties | ||||
|      */ | ||||
|     public GSCoreAPI(RMRestWrapper rmRestWrapper, RMRestProperties rmRestProperties) | ||||
|     { | ||||
| @@ -80,7 +81,7 @@ public class GSCoreAPI extends RMModelRequest | ||||
|      */ | ||||
|     public RMSiteAPI usingRMSite() | ||||
|     { | ||||
|       return new RMSiteAPI(getRmRestWrapper()); | ||||
|         return new RMSiteAPI(getRmRestWrapper()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -193,7 +194,10 @@ public class GSCoreAPI extends RMModelRequest | ||||
|         return new ActionsExecutionAPI(getRmRestWrapper()); | ||||
|     } | ||||
|  | ||||
|     public HoldsAPI usingHoldsAPI() { return new HoldsAPI(getRmRestWrapper()); } | ||||
|     public HoldsAPI usingHoldsAPI() | ||||
|     { | ||||
|         return new HoldsAPI(getRmRestWrapper()); | ||||
|     } | ||||
|  | ||||
|     public RetentionScheduleAPI usingRetentionScheduleAPI() | ||||
|     { | ||||
|   | ||||
| @@ -27,13 +27,13 @@ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import com.google.common.collect.ImmutableMap; | ||||
|  | ||||
| import lombok.SneakyThrows; | ||||
| import org.json.JSONObject; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.rules.ActionsOnRule; | ||||
| import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
| import org.alfresco.utility.model.RepoTestModel; | ||||
| import org.json.JSONObject; | ||||
|  | ||||
| /** | ||||
|  * Produces processed results from Core Actions API calls | ||||
| @@ -44,7 +44,8 @@ import org.json.JSONObject; | ||||
| public class ActionsExecutionAPI extends RMModelRequest | ||||
| { | ||||
|     /** | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public ActionsExecutionAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -54,81 +55,89 @@ public class ActionsExecutionAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Declares and files a document as record to a record folder using v1 actions api | ||||
|      * | ||||
|      * @param targetNode      the node on which the action is executed | ||||
|      * @param destinationPath the path to the record folder | ||||
|      * @param targetNode | ||||
|      *            the node on which the action is executed | ||||
|      * @param destinationPath | ||||
|      *            the path to the record folder | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public JSONObject declareAndFile(RepoTestModel targetNode, String destinationPath) throws Exception | ||||
|     { | ||||
|         return getRmRestWrapper().withCoreAPI().usingActions() | ||||
|                                  .executeAction(ActionsOnRule.DECLARE_AS_RECORD.getActionValue(), targetNode, | ||||
|                                          ImmutableMap.of("path", destinationPath)); | ||||
|                 .executeAction(ActionsOnRule.DECLARE_AS_RECORD.getActionValue(), targetNode, | ||||
|                         ImmutableMap.of("path", destinationPath)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Declares a document as record using v1 actions api | ||||
|      * | ||||
|      * @param targetNode the node on which the action is executed | ||||
|      * @param targetNode | ||||
|      *            the node on which the action is executed | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public JSONObject declareAsRecord(RepoTestModel targetNode) throws Exception | ||||
|     { | ||||
|         return getRmRestWrapper().withCoreAPI().usingActions() | ||||
|                                  .executeAction(ActionsOnRule.DECLARE_AS_RECORD.getActionValue(), targetNode); | ||||
|                 .executeAction(ActionsOnRule.DECLARE_AS_RECORD.getActionValue(), targetNode); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     /** | ||||
|      * Declares and file a document version as record to a record folder using v1 actions api | ||||
|      * | ||||
|      * @param targetNode      the node on which the action is executed | ||||
|      * @param destinationPath the path to the record folder | ||||
|      * @param targetNode | ||||
|      *            the node on which the action is executed | ||||
|      * @param destinationPath | ||||
|      *            the path to the record folder | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public JSONObject declareAndFileVersionAsRecord(RepoTestModel targetNode, String destinationPath) throws Exception | ||||
|     { | ||||
|         return getRmRestWrapper().withCoreAPI().usingActions() | ||||
|                                  .executeAction(ActionsOnRule.DECLARE_VERSION_AS_RECORD.getActionValue(), targetNode, | ||||
|                                          ImmutableMap.of("path", destinationPath)); | ||||
|                 .executeAction(ActionsOnRule.DECLARE_VERSION_AS_RECORD.getActionValue(), targetNode, | ||||
|                         ImmutableMap.of("path", destinationPath)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Declares a document version as record using v1 actions api | ||||
|      * | ||||
|      * @param targetNode the node on which the action is executed | ||||
|      * @param targetNode | ||||
|      *            the node on which the action is executed | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public JSONObject declareVersionAsRecord(RepoTestModel targetNode) throws Exception | ||||
|     { | ||||
|         return getRmRestWrapper().withCoreAPI().usingActions() | ||||
|                                  .executeAction(ActionsOnRule.DECLARE_VERSION_AS_RECORD.getActionValue(), targetNode); | ||||
|                 .executeAction(ActionsOnRule.DECLARE_VERSION_AS_RECORD.getActionValue(), targetNode); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Add WORM lock to a node using v1 actions api | ||||
|      * | ||||
|      * @param targetNode the node on which the action is executed | ||||
|      * @param targetNode | ||||
|      *            the node on which the action is executed | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     @SneakyThrows | ||||
|     public JSONObject addWORMLock(RepoTestModel targetNode) | ||||
|     { | ||||
|         return getRmRestWrapper().withCoreAPI().usingActions() | ||||
|                                  .executeAction(ActionsOnRule.WORM_LOCK.getActionValue(), targetNode); | ||||
|                 .executeAction(ActionsOnRule.WORM_LOCK.getActionValue(), targetNode); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * WORM lock a node for a period of days | ||||
|      * | ||||
|      * @param targetNode      the node on which the action is executed | ||||
|      * @param retentionPeriod the retention period in days for the WORM lock | ||||
|      * @param targetNode | ||||
|      *            the node on which the action is executed | ||||
|      * @param retentionPeriod | ||||
|      *            the retention period in days for the WORM lock | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     @SneakyThrows | ||||
|     public JSONObject addWORMLock(RepoTestModel targetNode, int retentionPeriod) | ||||
|     { | ||||
|         return getRmRestWrapper().withCoreAPI().usingActions() | ||||
|                                  .executeAction(ActionsOnRule.WORM_LOCK.getActionValue(), targetNode, | ||||
|                                          ImmutableMap.of("retentionPeriod", String.valueOf(retentionPeriod))); | ||||
|                 .executeAction(ActionsOnRule.WORM_LOCK.getActionValue(), targetNode, | ||||
|                         ImmutableMap.of("retentionPeriod", String.valueOf(retentionPeriod))); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -26,15 +26,16 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.fileplan.FilePlan; | ||||
| @@ -56,7 +57,8 @@ public class FilePlanAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public FilePlanAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -76,16 +78,19 @@ public class FilePlanAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets a file plan. | ||||
|      * | ||||
|      * @param filePlanId The identifier of a file plan | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param filePlanId | ||||
|      *            The identifier of a file plan | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link FilePlan} for the given {@code filePlanId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code filePlanId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code filePlanId}</li> | ||||
|      *  <li>{@code filePlanId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code filePlanId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code filePlanId}</li> | ||||
|      *             <li>{@code filePlanId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public FilePlan getFilePlan(String filePlanId, String parameters) | ||||
|     { | ||||
| @@ -95,8 +100,7 @@ public class FilePlanAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "/file-plans/{filePlanId}?{parameters}", | ||||
|                 filePlanId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -112,26 +116,28 @@ public class FilePlanAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the children (root categories) of a file plan. | ||||
|      * | ||||
|      * @param filePlanId The identifier of a file plan | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param filePlanId | ||||
|      *            The identifier of a file plan | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link RecordCategoryCollection} for the given {@code filePlanId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code filePlanId}</li> | ||||
|      *  <li>{@code filePlanId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code filePlanId}</li> | ||||
|      *             <li>{@code filePlanId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RecordCategoryCollection getRootRecordCategories(String filePlanId, String parameters) | ||||
|     { | ||||
|         mandatoryString("filePlanId", filePlanId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(RecordCategoryCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "file-plans/{filePlanId}/categories?{parameters}", | ||||
|             filePlanId, | ||||
|             parameters | ||||
|         )); | ||||
|                 GET, | ||||
|                 "file-plans/{filePlanId}/categories?{parameters}", | ||||
|                 filePlanId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -148,19 +154,23 @@ public class FilePlanAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Creates a root record category. | ||||
|      * | ||||
|      * @param recordCategoryModel The record category model which holds the information | ||||
|      * @param filePlanId The identifier of a file plan | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordCategoryModel | ||||
|      *            The record category model which holds the information | ||||
|      * @param filePlanId | ||||
|      *            The identifier of a file plan | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The created {@link RecordCategory} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code filePlanId} is not a valid format or {@code filePlanId} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to add children to {@code filePlanId}</li> | ||||
|      *  <li>{@code filePlanIds} does not exist</li> | ||||
|      *  <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *  <li>model integrity exception, including node name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code filePlanId} is not a valid format or {@code filePlanId} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to add children to {@code filePlanId}</li> | ||||
|      *             <li>{@code filePlanIds} does not exist</li> | ||||
|      *             <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *             <li>model integrity exception, including node name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RecordCategory createRootRecordCategory(RecordCategory recordCategoryModel, String filePlanId, String parameters) | ||||
|     { | ||||
| @@ -172,8 +182,7 @@ public class FilePlanAPI extends RMModelRequest | ||||
|                 toJson(recordCategoryModel), | ||||
|                 "file-plans/{filePlanId}/categories?{parameters}", | ||||
|                 filePlanId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -190,17 +199,21 @@ public class FilePlanAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Updates a file plan. | ||||
|      * | ||||
|      * @param filePlanModel The file plan  model which holds the information | ||||
|      * @param filePlanId    The identifier of the file plan | ||||
|      * @param parameters          The URL parameters to add | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      *                   <ul> | ||||
|      *                   <li>the update request is invalid or {@code filePlanId} is not a valid format or {@code filePlanModel} is invalid</li> | ||||
|      *                   <li>authentication fails</li> | ||||
|      *                   <li>current user does not have permission to update {@code filePlanId}</li> | ||||
|      *                   <li>{@code filePlanId} does not exist</li> | ||||
|      *                   <li>model integrity exception, including file name with invalid characters</li> | ||||
|      *                   </ul> | ||||
|      * @param filePlanModel | ||||
|      *            The file plan model which holds the information | ||||
|      * @param filePlanId | ||||
|      *            The identifier of the file plan | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>the update request is invalid or {@code filePlanId} is not a valid format or {@code filePlanModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to update {@code filePlanId}</li> | ||||
|      *             <li>{@code filePlanId} does not exist</li> | ||||
|      *             <li>model integrity exception, including file name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public FilePlan updateFilePlan(FilePlan filePlanModel, String filePlanId, String parameters) | ||||
|     { | ||||
| @@ -218,18 +231,22 @@ public class FilePlanAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Creates a hold. | ||||
|      * | ||||
|      * @param holdModel The hold model | ||||
|      * @param filePlanId The identifier of a file plan | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param holdModel | ||||
|      *            The hold model | ||||
|      * @param filePlanId | ||||
|      *            The identifier of a file plan | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The created {@link Hold} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code filePlanId} is not a valid format or {@code filePlanId} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to add children to {@code filePlanId}</li> | ||||
|      *  <li>{@code filePlanIds} does not exist</li> | ||||
|      *  <li>new name clashes with an existing node in the current parent container</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code filePlanId} is not a valid format or {@code filePlanId} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to add children to {@code filePlanId}</li> | ||||
|      *             <li>{@code filePlanIds} does not exist</li> | ||||
|      *             <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public Hold createHold(Hold holdModel, String filePlanId, String parameters) | ||||
|     { | ||||
| @@ -237,12 +254,11 @@ public class FilePlanAPI extends RMModelRequest | ||||
|         mandatoryObject("holdModel", holdModel); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(Hold.class, requestWithBody( | ||||
|             POST, | ||||
|             toJson(holdModel), | ||||
|             "file-plans/{filePlanId}/holds", | ||||
|             filePlanId, | ||||
|             parameters | ||||
|                                                                           )); | ||||
|                 POST, | ||||
|                 toJson(holdModel), | ||||
|                 "file-plans/{filePlanId}/holds", | ||||
|                 filePlanId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -256,26 +272,28 @@ public class FilePlanAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the holds of a file plan. | ||||
|      * | ||||
|      * @param filePlanId The identifier of a file plan | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param filePlanId | ||||
|      *            The identifier of a file plan | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link HoldCollection} for the given {@code filePlanId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code filePlanId}</li> | ||||
|      *  <li>{@code filePlanId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code filePlanId}</li> | ||||
|      *             <li>{@code filePlanId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public HoldCollection getHolds(String filePlanId, String parameters) | ||||
|     { | ||||
|         mandatoryString("filePlanId", filePlanId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(HoldCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "file-plans/{filePlanId}/holds?{parameters}", | ||||
|             filePlanId, | ||||
|             parameters | ||||
|                                                                                    )); | ||||
|                 GET, | ||||
|                 "file-plans/{filePlanId}/holds?{parameters}", | ||||
|                 filePlanId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -26,9 +26,10 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.record.Record; | ||||
| @@ -45,7 +46,8 @@ public class FilesAPI extends RMModelRequest<FilesAPI> | ||||
|     public static final String PARENT_ID_PARAM = "parentId"; | ||||
|  | ||||
|     /** | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public FilesAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -55,20 +57,20 @@ public class FilesAPI extends RMModelRequest<FilesAPI> | ||||
|     /** | ||||
|      * Declare file as record | ||||
|      * | ||||
|      * @param fileId The Id of a file to declare as record | ||||
|      * @param fileId | ||||
|      *            The Id of a file to declare as record | ||||
|      * @return The {@link Record} for created record | ||||
|      * @throws RuntimeException for malformed JSON responses | ||||
|      * @throws RuntimeException | ||||
|      *             for malformed JSON responses | ||||
|      */ | ||||
|     public Record declareAsRecord(String fileId) | ||||
|     { | ||||
|         mandatoryString("fileId", fileId); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(Record.class, simpleRequest( | ||||
|             POST, | ||||
|             "/files/{fileId}/declare?{parameters}", | ||||
|             fileId, | ||||
|             getRmRestWrapper().getParameters() | ||||
|         )); | ||||
|                 POST, | ||||
|                 "/files/{fileId}/declare?{parameters}", | ||||
|                 fileId, | ||||
|                 getRmRestWrapper().getParameters())); | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -26,17 +26,18 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.DELETE; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.hold.BulkBodyCancel; | ||||
| import org.alfresco.rest.rm.community.model.hold.Hold; | ||||
| @@ -68,27 +69,29 @@ public class HoldsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets a hold. | ||||
|      * | ||||
|      * @param holdId The identifier of a hold | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param holdId | ||||
|      *            The identifier of a hold | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link Hold} for the given {@code holdId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code holdId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code holdId}</li> | ||||
|      *  <li>{@code holdId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code holdId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code holdId}</li> | ||||
|      *             <li>{@code holdId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public Hold getHold(String holdId, String parameters) | ||||
|     { | ||||
|         mandatoryString("holdId", holdId); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(Hold.class, simpleRequest( | ||||
|             GET, | ||||
|             "holds/{holdId}?{parameters}", | ||||
|             holdId, | ||||
|             parameters | ||||
|                                                                         )); | ||||
|                 GET, | ||||
|                 "holds/{holdId}?{parameters}", | ||||
|                 holdId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -104,16 +107,20 @@ public class HoldsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Updates a hold. | ||||
|      * | ||||
|      * @param holdModel     The hold model which holds the information | ||||
|      * @param holdId        The identifier of the hold | ||||
|      * @param parameters          The URL parameters to add | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>the update request is invalid or {@code holdId} is not a valid format or {@code holdModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to update {@code holdId}</li> | ||||
|      *  <li>{@code holdId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @param holdModel | ||||
|      *            The hold model which holds the information | ||||
|      * @param holdId | ||||
|      *            The identifier of the hold | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>the update request is invalid or {@code holdId} is not a valid format or {@code holdModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to update {@code holdId}</li> | ||||
|      *             <li>{@code holdId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public Hold updateHold(Hold holdModel, String holdId, String parameters) | ||||
|     { | ||||
| @@ -121,12 +128,11 @@ public class HoldsAPI extends RMModelRequest | ||||
|         mandatoryString("holdId", holdId); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(Hold.class, requestWithBody( | ||||
|             PUT, | ||||
|             toJson(holdModel), | ||||
|             "holds/{holdId}?{parameters}", | ||||
|             holdId, | ||||
|             parameters | ||||
|                                                                             )); | ||||
|                 PUT, | ||||
|                 toJson(holdModel), | ||||
|                 "holds/{holdId}?{parameters}", | ||||
|                 holdId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -143,38 +149,42 @@ public class HoldsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Deletes a hold. | ||||
|      * | ||||
|      * @param holdId The identifier of a hold | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code holdId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to delete {@code holdId}</li> | ||||
|      *  <li>{@code holdId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @param holdId | ||||
|      *            The identifier of a hold | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code holdId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to delete {@code holdId}</li> | ||||
|      *             <li>{@code holdId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public void deleteHold(String holdId) | ||||
|     { | ||||
|         mandatoryString("holdId", holdId); | ||||
|  | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|             DELETE, | ||||
|             "holds/{holdId}", | ||||
|             holdId | ||||
|                                                           )); | ||||
|                 DELETE, | ||||
|                 "holds/{holdId}", | ||||
|                 holdId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Deletes a hold and stores a reason for deletion in the audit log. | ||||
|      * | ||||
|      * @param reason        The reason for hold deletion | ||||
|      * @param holdId        The identifier of a hold | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code holdId} is not a valid format or {@code reason} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to delete {@code holdId}</li> | ||||
|      *  <li>{@code holdId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @param reason | ||||
|      *            The reason for hold deletion | ||||
|      * @param holdId | ||||
|      *            The identifier of a hold | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code holdId} is not a valid format or {@code reason} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to delete {@code holdId}</li> | ||||
|      *             <li>{@code holdId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public HoldDeletionReason deleteHoldWithReason(HoldDeletionReason reason, String holdId) | ||||
|     { | ||||
| @@ -182,38 +192,41 @@ public class HoldsAPI extends RMModelRequest | ||||
|         mandatoryString("holdId", holdId); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(HoldDeletionReason.class, requestWithBody( | ||||
|             POST, | ||||
|             toJson(reason), | ||||
|             "holds/{holdId}/delete", | ||||
|             holdId | ||||
|                                                           )); | ||||
|                 POST, | ||||
|                 toJson(reason), | ||||
|                 "holds/{holdId}/delete", | ||||
|                 holdId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Adds the relationship between a child and a parent hold. | ||||
|      * | ||||
|      * @param holdChild The hold child model | ||||
|      * @param holdId The identifier of a hold | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param holdChild | ||||
|      *            The hold child model | ||||
|      * @param holdId | ||||
|      *            The identifier of a hold | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The created {@link Hold} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code holdId} is not a valid format or {@code holdId} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to add children to {@code holdId}</li> | ||||
|      *  <li>{@code holdId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code holdId} is not a valid format or {@code holdId} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to add children to {@code holdId}</li> | ||||
|      *             <li>{@code holdId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public HoldChild addChildToHold(HoldChild holdChild, String holdId, String parameters) | ||||
|     { | ||||
|         mandatoryObject("holdId", holdId); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(HoldChild.class, requestWithBody( | ||||
|             POST, | ||||
|             toJson(holdChild), | ||||
|             "holds/{holdId}/children", | ||||
|             holdId, | ||||
|             parameters)); | ||||
|                 POST, | ||||
|                 toJson(holdChild), | ||||
|                 "holds/{holdId}/children", | ||||
|                 holdId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -227,26 +240,28 @@ public class HoldsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the children of a hold. | ||||
|      * | ||||
|      * @param holdId The identifier of a hold | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param holdId | ||||
|      *            The identifier of a hold | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link HoldChildCollection} for the given {@code holdId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code holdId}</li> | ||||
|      *  <li>{@code holdId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code holdId}</li> | ||||
|      *             <li>{@code holdId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public HoldChildCollection getChildren(String holdId, String parameters) | ||||
|     { | ||||
|         mandatoryString("holdId", holdId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(HoldChildCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "holds/{holdId}/children", | ||||
|             holdId, | ||||
|             parameters | ||||
|                                                                                    )); | ||||
|                 GET, | ||||
|                 "holds/{holdId}/children", | ||||
|                 holdId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -260,16 +275,20 @@ public class HoldsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Deletes the relationship between a child and a parent hold. | ||||
|      * | ||||
|      * @param holdChildId The identifier of hold child | ||||
|      * @param holdId The identifier of a hold | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code holdId} or {@code holdChildId} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to delete children from {@code holdId}</li> | ||||
|      *  <li>{@code holdId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @param holdChildId | ||||
|      *            The identifier of hold child | ||||
|      * @param holdId | ||||
|      *            The identifier of a hold | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code holdId} or {@code holdChildId} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to delete children from {@code holdId}</li> | ||||
|      *             <li>{@code holdId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public void deleteHoldChild(String holdId, String holdChildId, String parameters) | ||||
|     { | ||||
| @@ -277,12 +296,11 @@ public class HoldsAPI extends RMModelRequest | ||||
|         mandatoryString("holdChildId", holdChildId); | ||||
|  | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|             DELETE, | ||||
|             "holds/{holdId}/children/{holdChildId}", | ||||
|             holdId, | ||||
|             holdChildId, | ||||
|             parameters | ||||
|                                                           )); | ||||
|                 DELETE, | ||||
|                 "holds/{holdId}/children/{holdChildId}", | ||||
|                 holdId, | ||||
|                 holdChildId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -296,17 +314,21 @@ public class HoldsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Starts a bulk process for a hold. | ||||
|      * | ||||
|      * @param holdBulkOperation The bulk operation details | ||||
|      * @param hold The identifier of a hold | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param holdBulkOperation | ||||
|      *            The bulk operation details | ||||
|      * @param hold | ||||
|      *            The identifier of a hold | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link HoldBulkOperationEntry} for the started bulk process | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code hold} or {@code holdBulkOperation} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to start a bulk process for {@code hold}</li> | ||||
|      *  <li>{@code hold} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code hold} or {@code holdBulkOperation} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to start a bulk process for {@code hold}</li> | ||||
|      *             <li>{@code hold} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public HoldBulkOperationEntry startBulkProcess(HoldBulkOperation holdBulkOperation, String hold, String parameters) | ||||
|     { | ||||
| @@ -314,12 +336,11 @@ public class HoldsAPI extends RMModelRequest | ||||
|         mandatoryString("hold", hold); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(HoldBulkOperationEntry.class, requestWithBody( | ||||
|             POST, | ||||
|             toJson(holdBulkOperation), | ||||
|             "holds/{hold}/bulk", | ||||
|             hold, | ||||
|             parameters | ||||
|                                                                                           )); | ||||
|                 POST, | ||||
|                 toJson(holdBulkOperation), | ||||
|                 "holds/{hold}/bulk", | ||||
|                 hold, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -333,17 +354,21 @@ public class HoldsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the status of a bulk process for a hold. | ||||
|      * | ||||
|      * @param holdId The identifier of a hold | ||||
|      * @param holdBulkStatusId The identifier of a bulk status operation | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param holdId | ||||
|      *            The identifier of a hold | ||||
|      * @param holdBulkStatusId | ||||
|      *            The identifier of a bulk status operation | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link HoldBulkStatus} for the given {@code holdId} and {@code holdBulkStatusId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code holdId} or {@code holdBulkStatusId} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to get the bulk status for {@code holdId}</li> | ||||
|      *  <li>{@code holdId} or {@code holdBulkStatusId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code holdId} or {@code holdBulkStatusId} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to get the bulk status for {@code holdId}</li> | ||||
|      *             <li>{@code holdId} or {@code holdBulkStatusId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public HoldBulkStatus getBulkStatus(String holdId, String holdBulkStatusId, String parameters) | ||||
|     { | ||||
| @@ -351,12 +376,11 @@ public class HoldsAPI extends RMModelRequest | ||||
|         mandatoryString("holdBulkStatusId", holdBulkStatusId); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(HoldBulkStatus.class, simpleRequest( | ||||
|             GET, | ||||
|             "holds/{holdId}/bulk-statuses/{holdBulkStatusId}", | ||||
|             holdId, | ||||
|             holdBulkStatusId, | ||||
|             parameters | ||||
|                                                                                    )); | ||||
|                 GET, | ||||
|                 "holds/{holdId}/bulk-statuses/{holdBulkStatusId}", | ||||
|                 holdId, | ||||
|                 holdBulkStatusId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -370,27 +394,29 @@ public class HoldsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the statuses of all bulk processes for a hold. | ||||
|      * | ||||
|      * @param holdId The identifier of a hold | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param holdId | ||||
|      *            The identifier of a hold | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link HoldBulkStatusCollection} for the given {@code holdId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *     <li>{@code holdId} is invalid</li> | ||||
|      *     <li>authentication fails</li> | ||||
|      *     <li>current user does not have permission to get the bulk statuses for {@code holdId}</li> | ||||
|      *     <li>{@code holdId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code holdId} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to get the bulk statuses for {@code holdId}</li> | ||||
|      *             <li>{@code holdId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public HoldBulkStatusCollection getBulkStatuses(String holdId, String parameters) | ||||
|     { | ||||
|         mandatoryString("holdId", holdId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(HoldBulkStatusCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "holds/{holdId}/bulk-statuses", | ||||
|             holdId, | ||||
|             parameters | ||||
|                                                                                              )); | ||||
|                 GET, | ||||
|                 "holds/{holdId}/bulk-statuses", | ||||
|                 holdId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -404,17 +430,22 @@ public class HoldsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Cancels a bulk operation for a hold. | ||||
|      * | ||||
|      * @param holdId The identifier of a hold | ||||
|      * @param bulkStatusId The identifier of a bulk status operation | ||||
|      * @param bulkBodyCancel The bulk body cancel model | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *     <li>{@code holdId}, {@code bulkStatusId} or {@code bulkBodyCancel} is invalid</li> | ||||
|      *     <li>authentication fails</li> | ||||
|      *     <li>current user does not have permission to cancel the bulk operation for {@code bulkStatusId}</li> | ||||
|      *     <li>{@code holdId} or {@code bulkStatusId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @param holdId | ||||
|      *            The identifier of a hold | ||||
|      * @param bulkStatusId | ||||
|      *            The identifier of a bulk status operation | ||||
|      * @param bulkBodyCancel | ||||
|      *            The bulk body cancel model | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code holdId}, {@code bulkStatusId} or {@code bulkBodyCancel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to cancel the bulk operation for {@code bulkStatusId}</li> | ||||
|      *             <li>{@code holdId} or {@code bulkStatusId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public void cancelBulkOperation(String holdId, String bulkStatusId, BulkBodyCancel bulkBodyCancel, String parameters) | ||||
|     { | ||||
| @@ -423,13 +454,12 @@ public class HoldsAPI extends RMModelRequest | ||||
|         mandatoryObject("bulkBodyCancel", bulkBodyCancel); | ||||
|  | ||||
|         getRmRestWrapper().processEmptyModel(requestWithBody( | ||||
|             POST, | ||||
|             toJson(bulkBodyCancel), | ||||
|             "holds/{holdId}/bulk-statuses/{bulkStatusId}/cancel", | ||||
|             holdId, | ||||
|             bulkStatusId, | ||||
|             parameters | ||||
|                                                           )); | ||||
|                 POST, | ||||
|                 toJson(bulkBodyCancel), | ||||
|                 "holds/{holdId}/bulk-statuses/{bulkStatusId}/cancel", | ||||
|                 holdId, | ||||
|                 bulkStatusId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -26,16 +26,17 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.springframework.http.HttpMethod.DELETE; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
| import static org.springframework.http.HttpStatus.OK; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.site.RMSite; | ||||
| import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
| @@ -51,7 +52,8 @@ public class RMSiteAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Constructor | ||||
|      * | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public RMSiteAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -62,34 +64,35 @@ public class RMSiteAPI extends RMModelRequest | ||||
|      * Get the RM site | ||||
|      * | ||||
|      * @return The {@link RMSite} for the given file plan component id | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>Api Response code 400 Invalid parameter: GET request is supported only for the RM site</li> | ||||
|      *  <li>Api Response code 401 If authentication failed</li> | ||||
|      *  <li>Api Response code 409 If RM Site does not exist</li> | ||||
|      *  <li>Api Response code default Unexpected error</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>Api Response code 400 Invalid parameter: GET request is supported only for the RM site</li> | ||||
|      *             <li>Api Response code 401 If authentication failed</li> | ||||
|      *             <li>Api Response code 409 If RM Site does not exist</li> | ||||
|      *             <li>Api Response code default Unexpected error</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RMSite getSite() | ||||
|     { | ||||
|         return getRmRestWrapper().processModel(RMSite.class, simpleRequest( | ||||
|                 GET, | ||||
|                 "gs-sites/rm" | ||||
|         )); | ||||
|                 "gs-sites/rm")); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Create the RM site | ||||
|      * | ||||
|      * @param rmSiteModel The properties of the rm site to be created | ||||
|      * @param rmSiteModel | ||||
|      *            The properties of the rm site to be created | ||||
|      * @return The {@link RMSite} with the given properties | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>Api Response code 400 Invalid parameter: title, or description exceed the maximum length; or siteBodyCreate invalid</li> | ||||
|      *  <li>Api Response code 401 If authentication failed</ | ||||
|      *  <li>Api Response code 409 RM Site already exists</li> | ||||
|      *  <li>Api Response code default Unexpected error</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>Api Response code 400 Invalid parameter: title, or description exceed the maximum length; or siteBodyCreate invalid</li> | ||||
|      *             <li>Api Response code 401 If authentication failed</<li>Api Response code 409 RM Site already exists</li> | ||||
|      *             <li>Api Response code default Unexpected error</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RMSite createRMSite(RMSite rmSiteModel) | ||||
|     { | ||||
| @@ -98,42 +101,43 @@ public class RMSiteAPI extends RMModelRequest | ||||
|         return getRmRestWrapper().processModel(RMSite.class, requestWithBody( | ||||
|                 POST, | ||||
|                 toJson(rmSiteModel), | ||||
|                 "gs-sites" | ||||
|         )); | ||||
|                 "gs-sites")); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Delete RM site | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>Api Response code 400 Invalid parameter: DELETE request is supported only for the RM site</li> | ||||
|      *  <li>Api Response code 401 If authentication failed</ | ||||
|      *  <li>Api Response code 403 Current user does not have permission to delete the site that is visible to them.</li> | ||||
|      *  <li>Api Response code 404 RM site does not exist</li> | ||||
|      *  <li>Api Response code default Unexpected error</li> | ||||
|      * </ul> | ||||
|      *  | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>Api Response code 400 Invalid parameter: DELETE request is supported only for the RM site</li> | ||||
|      *             <li>Api Response code 401 If authentication failed</<li>Api Response code 403 Current user does not have permission to delete the site that is visible to them.</li> | ||||
|      *             <li>Api Response code 404 RM site does not exist</li> | ||||
|      *             <li>Api Response code default Unexpected error</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public void deleteRMSite() | ||||
|     { | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|                 DELETE, | ||||
|                 "gs-sites/rm" | ||||
|         )); | ||||
|                 "gs-sites/rm")); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Update RM site | ||||
|      * | ||||
|      * @param rmSiteModel The properties to be updated | ||||
|      * @param rmSiteModel | ||||
|      *            The properties to be updated | ||||
|      * @return The updated {@link RMSite} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>Api Response code 400 the update request is invalid {@code rmSiteModel} is invalid</li> | ||||
|      *  <li>Api Response code 401 If authentication fails</li> | ||||
|      *  <li>Api Response code 403 does not have permission to update {@code RMSite}</li> | ||||
|      *  <li>Api Response code 404 {@code RMSiteModel} does not exist</li> | ||||
|      *  <li>Api Response code default Unexpected error,model integrity exception</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>Api Response code 400 the update request is invalid {@code rmSiteModel} is invalid</li> | ||||
|      *             <li>Api Response code 401 If authentication fails</li> | ||||
|      *             <li>Api Response code 403 does not have permission to update {@code RMSite}</li> | ||||
|      *             <li>Api Response code 404 {@code RMSiteModel} does not exist</li> | ||||
|      *             <li>Api Response code default Unexpected error,model integrity exception</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RMSite updateRMSite(RMSite rmSiteModel) | ||||
|     { | ||||
| @@ -142,21 +146,21 @@ public class RMSiteAPI extends RMModelRequest | ||||
|         return getRmRestWrapper().processModel(RMSite.class, requestWithBody( | ||||
|                 PUT, | ||||
|                 toJson(rmSiteModel), | ||||
|                 "gs-sites/rm" | ||||
|         )); | ||||
|                 "gs-sites/rm")); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Checks if the RM site exists or not | ||||
|      * | ||||
|      * @return <code>true</code> if the RM site exists, <code>false</code> otherwise | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>Api Response code 400 Invalid parameter: GET request is supported only for the RM site</li> | ||||
|      *  <li>Api Response code 401 If authentication failed</li> | ||||
|      *  <li>Api Response code 409 If RM Site does not exist</li> | ||||
|      *  <li>Api Response code default Unexpected error</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>Api Response code 400 Invalid parameter: GET request is supported only for the RM site</li> | ||||
|      *             <li>Api Response code 401 If authentication failed</li> | ||||
|      *             <li>Api Response code 409 If RM Site does not exist</li> | ||||
|      *             <li>Api Response code default Unexpected error</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public boolean existsRMSite() | ||||
|     { | ||||
|   | ||||
| @@ -26,17 +26,16 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static io.restassured.RestAssured.basic; | ||||
| import static io.restassured.RestAssured.given; | ||||
| import static org.jglue.fluentjson.JsonBuilderFactory.buildObject; | ||||
| import static org.springframework.http.HttpStatus.OK; | ||||
|  | ||||
| import com.google.gson.JsonObject; | ||||
|  | ||||
| import io.restassured.builder.RequestSpecBuilder; | ||||
| import io.restassured.http.ContentType; | ||||
| import io.restassured.response.Response; | ||||
| import io.restassured.specification.RequestSpecification; | ||||
| import static io.restassured.RestAssured.basic; | ||||
| import static io.restassured.RestAssured.given; | ||||
|  | ||||
| import org.alfresco.dataprep.AlfrescoHttpClient; | ||||
| import org.alfresco.dataprep.AlfrescoHttpClientFactory; | ||||
| @@ -59,7 +58,8 @@ import org.alfresco.utility.model.UserModel; | ||||
| public class RMUserAPI extends RMModelRequest | ||||
| { | ||||
|     /** | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public RMUserAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -68,6 +68,7 @@ public class RMUserAPI extends RMModelRequest | ||||
|  | ||||
|     /** | ||||
|      * Helper method to obtain {@link AlfrescoHttpClient} | ||||
|      *  | ||||
|      * @return Initialized {@link AlfrescoHttpClient} instance | ||||
|      */ | ||||
|     private AlfrescoHttpClient getAlfrescoHttpClient() | ||||
| @@ -85,9 +86,12 @@ public class RMUserAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Assign RM role to user | ||||
|      * | ||||
|      * @param userName User's username | ||||
|      * @param userRole User's RM role, one of {@link UserRoles} roles | ||||
|      * @throws RuntimeException for failed requests | ||||
|      * @param userName | ||||
|      *            User's username | ||||
|      * @param userRole | ||||
|      *            User's RM role, one of {@link UserRoles} roles | ||||
|      * @throws RuntimeException | ||||
|      *             for failed requests | ||||
|      */ | ||||
|     public void assignRoleToUser(String userName, String userRole) | ||||
|     { | ||||
| @@ -118,9 +122,13 @@ public class RMUserAPI extends RMModelRequest | ||||
|  | ||||
|     /** | ||||
|      * Helper method to add permission on a component to user | ||||
|      * @param filePlanComponentId The id of the file plan component on which permission should be given | ||||
|      * @param user {@link UserModel} for a user to be granted permission | ||||
|      * @param permission {@link UserPermissions} to be granted | ||||
|      *  | ||||
|      * @param filePlanComponentId | ||||
|      *            The id of the file plan component on which permission should be given | ||||
|      * @param user | ||||
|      *            {@link UserModel} for a user to be granted permission | ||||
|      * @param permission | ||||
|      *            {@link UserPermissions} to be granted | ||||
|      */ | ||||
|     public void addUserPermission(String filePlanComponentId, UserModel user, UserPermissions permission) | ||||
|     { | ||||
| @@ -161,9 +169,10 @@ public class RMUserAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Helper method to set permission inheritance on a file plan component | ||||
|      * | ||||
|      * @param filePlanComponentId The id of the file plan component on which inherited permission should be set | ||||
|      * @param isInherited          true if the permission is inherited | ||||
|      *                             false if the permission inheritance is disabled | ||||
|      * @param filePlanComponentId | ||||
|      *            The id of the file plan component on which inherited permission should be set | ||||
|      * @param isInherited | ||||
|      *            true if the permission is inherited false if the permission inheritance is disabled | ||||
|      */ | ||||
|     public void setUserPermissionInheritance(String filePlanComponentId, Boolean isInherited) | ||||
|     { | ||||
| @@ -199,13 +208,15 @@ public class RMUserAPI extends RMModelRequest | ||||
|         getRmRestWrapper().setStatusCode(Integer.toString(response.getStatusCode())); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     /** | ||||
|      * Creates a user with the given name using the old APIs | ||||
|      * | ||||
|      * @param userName The user name | ||||
|      * @param userPassword The user's password | ||||
|      * @param userEmail The user's e-mail address | ||||
|      * @param userName | ||||
|      *            The user name | ||||
|      * @param userPassword | ||||
|      *            The user's password | ||||
|      * @param userEmail | ||||
|      *            The user's e-mail address | ||||
|      * @return <code>true</code> if the user was created successfully, <code>false</code> otherwise. | ||||
|      */ | ||||
|     public boolean createUser(String userName, String userPassword, String userEmail) | ||||
| @@ -214,29 +225,29 @@ public class RMUserAPI extends RMModelRequest | ||||
|         final AlfrescoHttpClient client = getAlfrescoHttpClient(); | ||||
|  | ||||
|         JsonObject body = buildObject() | ||||
|             .add("userName", userName) | ||||
|             .add("firstName", userName) | ||||
|             .add("lastName", userName) | ||||
|             .add("password", userPassword) | ||||
|             .add("email", userEmail) | ||||
|             .getJson(); | ||||
|                 .add("userName", userName) | ||||
|                 .add("firstName", userName) | ||||
|                 .add("lastName", userName) | ||||
|                 .add("password", userPassword) | ||||
|                 .add("email", userEmail) | ||||
|                 .getJson(); | ||||
|  | ||||
|         final RequestSpecification spec = new RequestSpecBuilder() | ||||
|             .setBaseUri(client.getApiUrl()) | ||||
|             .setBasePath("/") | ||||
|             .setAuth(basic(adminUser.getUsername(), adminUser.getPassword())) | ||||
|             .setContentType(ContentType.JSON) | ||||
|             .setBody(body.toString()) | ||||
|             .build(); | ||||
|                 .setBaseUri(client.getApiUrl()) | ||||
|                 .setBasePath("/") | ||||
|                 .setAuth(basic(adminUser.getUsername(), adminUser.getPassword())) | ||||
|                 .setContentType(ContentType.JSON) | ||||
|                 .setBody(body.toString()) | ||||
|                 .build(); | ||||
|  | ||||
|         // create POST request to "people" endpoint | ||||
|         Response response = given() | ||||
|             .spec(spec) | ||||
|             .log().all() | ||||
|         .when() | ||||
|             .post("people") | ||||
|             .prettyPeek() | ||||
|             .andReturn(); | ||||
|                 .spec(spec) | ||||
|                 .log().all() | ||||
|                 .when() | ||||
|                 .post("people") | ||||
|                 .prettyPeek() | ||||
|                 .andReturn(); | ||||
|  | ||||
|         return (response.getStatusCode() == OK.value()); | ||||
|     } | ||||
|   | ||||
| @@ -26,17 +26,18 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.DELETE; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.recordcategory.RecordCategory; | ||||
| import org.alfresco.rest.rm.community.model.recordcategory.RecordCategoryChild; | ||||
| @@ -54,7 +55,8 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public RecordCategoryAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -64,15 +66,17 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Deletes a record category. | ||||
|      * | ||||
|      * @param recordCategoryId The identifier of a record category | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code recordCategoryId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to delete {@code recordCategoryId}</li> | ||||
|      *  <li>{@code recordCategoryId} does not exist</li> | ||||
|      *  <li>{@code recordCategoryId} is locked and cannot be deleted</li> | ||||
|      * </ul> | ||||
|      * @param recordCategoryId | ||||
|      *            The identifier of a record category | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordCategoryId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to delete {@code recordCategoryId}</li> | ||||
|      *             <li>{@code recordCategoryId} does not exist</li> | ||||
|      *             <li>{@code recordCategoryId} is locked and cannot be deleted</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public void deleteRecordCategory(String recordCategoryId) | ||||
|     { | ||||
| @@ -81,8 +85,7 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|                 DELETE, | ||||
|                 "record-categories/{recordCategoryId}", | ||||
|                 recordCategoryId | ||||
|         )); | ||||
|                 recordCategoryId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -98,16 +101,19 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets a record category. | ||||
|      * | ||||
|      * @param recordCategoryId The identifier of a record category | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordCategoryId | ||||
|      *            The identifier of a record category | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link RecordCategory} for the given {@code recordCategoryId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code recordCategoryId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code recordCategoryId}</li> | ||||
|      *  <li>{@code recordCategoryId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordCategoryId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code recordCategoryId}</li> | ||||
|      *             <li>{@code recordCategoryId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RecordCategory getRecordCategory(String recordCategoryId, String parameters) | ||||
|     { | ||||
| @@ -117,8 +123,7 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "record-categories/{recordCategoryId}?{parameters}", | ||||
|                 recordCategoryId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -135,19 +140,24 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Updates a record category. | ||||
|      * | ||||
|      * @param recordCategoryModel The record category model which holds the information | ||||
|      * @param recordCategoryId The identifier of a record category | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param returns The updated {@link RecordCategory} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>the update request is invalid or {@code recordCategoryId} is not a valid format or {@code recordCategoryModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to update {@code recordCategoryId}</li> | ||||
|      *  <li>{@code recordCategoryId} does not exist</li> | ||||
|      *  <li>the updated name clashes with an existing record category in the current parent category</li> | ||||
|      *  <li>model integrity exception, including file name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @param recordCategoryModel | ||||
|      *            The record category model which holds the information | ||||
|      * @param recordCategoryId | ||||
|      *            The identifier of a record category | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @param returns | ||||
|      *            The updated {@link RecordCategory} | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>the update request is invalid or {@code recordCategoryId} is not a valid format or {@code recordCategoryModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to update {@code recordCategoryId}</li> | ||||
|      *             <li>{@code recordCategoryId} does not exist</li> | ||||
|      *             <li>the updated name clashes with an existing record category in the current parent category</li> | ||||
|      *             <li>model integrity exception, including file name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RecordCategory updateRecordCategory(RecordCategory recordCategoryModel, String recordCategoryId, String parameters) | ||||
|     { | ||||
| @@ -159,8 +169,7 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|                 toJson(recordCategoryModel), | ||||
|                 "record-categories/{recordCategoryId}?{parameters}", | ||||
|                 recordCategoryId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -176,26 +185,28 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the children of a record category. | ||||
|      * | ||||
|      * @param recordCategoryId The identifier of a record category | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordCategoryId | ||||
|      *            The identifier of a record category | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link RecordCategoryChildCollection} for the given {@code recordCategoryId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code recordCategoryId}</li> | ||||
|      *  <li>{@code recordCategoryId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code recordCategoryId}</li> | ||||
|      *             <li>{@code recordCategoryId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RecordCategoryChildCollection getRecordCategoryChildren(String recordCategoryId, String parameters) | ||||
|     { | ||||
|         mandatoryString("recordCategoryId", recordCategoryId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(RecordCategoryChildCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "record-categories/{recordCategoryId}/children?{parameters}", | ||||
|             recordCategoryId, | ||||
|             parameters | ||||
|         )); | ||||
|                 GET, | ||||
|                 "record-categories/{recordCategoryId}/children?{parameters}", | ||||
|                 recordCategoryId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -212,19 +223,23 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Creates a record category child. Can be a record category or a record folder. | ||||
|      * | ||||
|      * @param recordCategoryChildModel The record category child model which holds the information | ||||
|      * @param recordCategoryId The identifier of a record category | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordCategoryChildModel | ||||
|      *            The record category child model which holds the information | ||||
|      * @param recordCategoryId | ||||
|      *            The identifier of a record category | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The created {@link RecordCategoryChild} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code recordCategoryId} is not a valid format or {@code recordCategoryChildModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to add children to {@code recordCategoryId}</li> | ||||
|      *  <li>{@code recordCategoryId} does not exist</li> | ||||
|      *  <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *  <li>model integrity exception, including node name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordCategoryId} is not a valid format or {@code recordCategoryChildModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to add children to {@code recordCategoryId}</li> | ||||
|      *             <li>{@code recordCategoryId} does not exist</li> | ||||
|      *             <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *             <li>model integrity exception, including node name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RecordCategoryChild createRecordCategoryChild(RecordCategoryChild recordCategoryChildModel, String recordCategoryId, String parameters) | ||||
|     { | ||||
| @@ -236,7 +251,6 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|                 toJson(recordCategoryChildModel), | ||||
|                 "record-categories/{recordCategoryId}/children?{parameters}", | ||||
|                 recordCategoryId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -26,12 +26,6 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentType.CONTENT_TYPE; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.DELETE; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| @@ -39,6 +33,13 @@ import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
| import static org.testng.Assert.fail; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentType.CONTENT_TYPE; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
|  | ||||
| import java.io.File; | ||||
| import java.io.IOException; | ||||
| import java.util.Iterator; | ||||
| @@ -66,7 +67,8 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public RecordFolderAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -76,15 +78,17 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Deletes a record folder. | ||||
|      * | ||||
|      * @param recordFolderId The identifier of a record folder | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code recordFolderId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to delete {@code recordFolderId}</li> | ||||
|      *  <li>{@code recordFolderId} does not exist</li> | ||||
|      *  <li>{@code recordFolderId} is locked and cannot be deleted</li> | ||||
|      * </ul> | ||||
|      * @param recordFolderId | ||||
|      *            The identifier of a record folder | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordFolderId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to delete {@code recordFolderId}</li> | ||||
|      *             <li>{@code recordFolderId} does not exist</li> | ||||
|      *             <li>{@code recordFolderId} is locked and cannot be deleted</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public void deleteRecordFolder(String recordFolderId) | ||||
|     { | ||||
| @@ -93,8 +97,7 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|                 DELETE, | ||||
|                 "record-folders/{recordFolderId}", | ||||
|                 recordFolderId | ||||
|         )); | ||||
|                 recordFolderId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -110,16 +113,19 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets a record folder. | ||||
|      * | ||||
|      * @param recordFolderId The identifier of a record folder | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordFolderId | ||||
|      *            The identifier of a record folder | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link RecordFolder} for the given {@code recordFolderId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code recordFolderId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code recordFolderId}</li> | ||||
|      *  <li>{@code recordFolderId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordFolderId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code recordFolderId}</li> | ||||
|      *             <li>{@code recordFolderId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RecordFolder getRecordFolder(String recordFolderId, String parameters) | ||||
|     { | ||||
| @@ -129,8 +135,7 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "record-folders/{recordFolderId}?{parameters}", | ||||
|                 recordFolderId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -147,19 +152,24 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Updates a record folder. | ||||
|      * | ||||
|      * @param recordFolderModel The record folder model which holds the information | ||||
|      * @param recordFolderId The identifier of a record folder | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param returns The updated {@link RecordFolder} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>the update request is invalid or {@code recordFolderId} is not a valid format or {@code recordFolderModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to update {@code recordFolderId}</li> | ||||
|      *  <li>{@code recordFolderId} does not exist</li> | ||||
|      *  <li>the updated name clashes with an existing record folder in the current parent category</li> | ||||
|      *  <li>model integrity exception, including file name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @param recordFolderModel | ||||
|      *            The record folder model which holds the information | ||||
|      * @param recordFolderId | ||||
|      *            The identifier of a record folder | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @param returns | ||||
|      *            The updated {@link RecordFolder} | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>the update request is invalid or {@code recordFolderId} is not a valid format or {@code recordFolderModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to update {@code recordFolderId}</li> | ||||
|      *             <li>{@code recordFolderId} does not exist</li> | ||||
|      *             <li>the updated name clashes with an existing record folder in the current parent category</li> | ||||
|      *             <li>model integrity exception, including file name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RecordFolder updateRecordFolder(RecordFolder recordFolderModel, String recordFolderId, String parameters) | ||||
|     { | ||||
| @@ -171,8 +181,7 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|                 toJson(recordFolderModel), | ||||
|                 "record-folders/{recordFolderId}?{parameters}", | ||||
|                 recordFolderId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -188,26 +197,28 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the children of a record folder. | ||||
|      * | ||||
|      * @param recordFolderId The identifier of a record folder | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordFolderId | ||||
|      *            The identifier of a record folder | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link RecordFolderCollection} for the given {@code recordFolderId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code recordFolderId}</li> | ||||
|      *  <li>{@code recordFolderId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code recordFolderId}</li> | ||||
|      *             <li>{@code recordFolderId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RecordFolderCollection getRecordFolderChildren(String recordFolderId, String parameters) | ||||
|     { | ||||
|         mandatoryString("recordFolderId", recordFolderId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(RecordFolderCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "record-folders/{recordFolderId}/records?{parameters}", | ||||
|             recordFolderId, | ||||
|             parameters | ||||
|         )); | ||||
|                 GET, | ||||
|                 "record-folders/{recordFolderId}/records?{parameters}", | ||||
|                 recordFolderId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -224,11 +235,15 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Create a record from file resource | ||||
|      * | ||||
|      * @param recordModel {@link Record} for electronic record to be created | ||||
|      * @param recordContent {@link File} pointing to the content of the electronic record to be created | ||||
|      * @param recordFolderId The identifier of a record folder | ||||
|      * @param recordModel | ||||
|      *            {@link Record} for electronic record to be created | ||||
|      * @param recordContent | ||||
|      *            {@link File} pointing to the content of the electronic record to be created | ||||
|      * @param recordFolderId | ||||
|      *            The identifier of a record folder | ||||
|      * @return newly created {@link Record} | ||||
|      * @throws RuntimeException for invalid recordModel JSON strings | ||||
|      * @throws RuntimeException | ||||
|      *             for invalid recordModel JSON strings | ||||
|      */ | ||||
|     public Record createRecord(Record recordModel, String recordFolderId, File recordContent) throws RuntimeException | ||||
|     { | ||||
| @@ -241,10 +256,7 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|             fail("Only electronic records are supported"); | ||||
|         } | ||||
|  | ||||
|         /* | ||||
|          * For file uploads nodeBodyCreate is ignored hence can't be used. Append all Record fields | ||||
|          * to the request. | ||||
|          */ | ||||
|         /* For file uploads nodeBodyCreate is ignored hence can't be used. Append all Record fields to the request. */ | ||||
|         RequestSpecBuilder builder = getRmRestWrapper().configureRequestSpec(); | ||||
|         JsonNode root; | ||||
|         try | ||||
| @@ -271,18 +283,22 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Creates a record in a record folder child, i.e. a record. | ||||
|      * | ||||
|      * @param recordModel The record model which holds the information | ||||
|      * @param recordFolderId The identifier of a record folder | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordModel | ||||
|      *            The record model which holds the information | ||||
|      * @param recordFolderId | ||||
|      *            The identifier of a record folder | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The created {@link Record} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code recordFolderId is not a valid format or {@code recordModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to add children to {@code recordFolderId}</li> | ||||
|      *  <li>{@code recordFolderId} does not exist</li> | ||||
|      *  <li>model integrity exception, including node name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordFolderId is not a valid format or {@code recordModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to add children to {@code recordFolderId}</li> | ||||
|      *             <li>{@code recordFolderId} does not exist</li> | ||||
|      *             <li>model integrity exception, including node name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public Record createRecord(Record recordModel, String recordFolderId, String parameters) | ||||
|     { | ||||
| @@ -294,7 +310,6 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|                 toJson(recordModel), | ||||
|                 "record-folders/{recordFolderId}/records?{parameters}", | ||||
|                 recordFolderId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -26,25 +26,25 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.DELETE; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
|  | ||||
| import io.restassured.response.ResponseBody; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.record.Record; | ||||
| import org.alfresco.rest.rm.community.model.record.RecordBodyFile; | ||||
| import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
|  | ||||
| import io.restassured.response.ResponseBody; | ||||
|  | ||||
| /** | ||||
|  * Records REST API Wrapper | ||||
|  * | ||||
| @@ -54,7 +54,8 @@ import io.restassured.response.ResponseBody; | ||||
| public class RecordsAPI extends RMModelRequest | ||||
| { | ||||
|     /** | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public RecordsAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -64,41 +65,46 @@ public class RecordsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Get the content for the electronic record | ||||
|      * | ||||
|      * @param recordId The id of the electronic record | ||||
|      * @param recordId | ||||
|      *            The id of the electronic record | ||||
|      * @return {@link ResponseBody} representing content for the given record id | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      * <li>{@code recordId} has no content</li> | ||||
|      * <li> {@code recordId} is not a valid format, or is not a record</li> | ||||
|      * <li>authentication fails</li> | ||||
|      * <li>{@code recordId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordId} has no content</li> | ||||
|      *             <li>{@code recordId} is not a valid format, or is not a record</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>{@code recordId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public ResponseBody<?> getRecordContent(String recordId) | ||||
|     { | ||||
|         mandatoryString("recordId", recordId); | ||||
|  | ||||
|         return getRmRestWrapper() | ||||
|             .processHtmlResponse(simpleRequest(GET,"records/{recordId}/content", recordId)) | ||||
|             .getBody(); | ||||
|                 .processHtmlResponse(simpleRequest(GET, "records/{recordId}/content", recordId)) | ||||
|                 .getBody(); | ||||
|  | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * File the record recordId into file plan structure based on the location sent via the request body | ||||
|      * | ||||
|      * @param recordBodyFile The properties where to file the record | ||||
|      * @param recordId       The id of the record to file | ||||
|      * @param recordBodyFile | ||||
|      *            The properties where to file the record | ||||
|      * @param recordId | ||||
|      *            The id of the record to file | ||||
|      * @return The {@link Record} with the given properties | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>Invalid parameter: {@code recordBodyFile} is not a valid format,{@code recordId} is not a record</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to file to {@code fileplanComponentId}</li> | ||||
|      *  <li>{@code recordId} does not exist</li> | ||||
|      *  <li>targetParentId from recordBodyFile does not exist</li> | ||||
|      *  <li>model integrity exception: the action breaks system's integrity restrictions</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>Invalid parameter: {@code recordBodyFile} is not a valid format,{@code recordId} is not a record</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to file to {@code fileplanComponentId}</li> | ||||
|      *             <li>{@code recordId} does not exist</li> | ||||
|      *             <li>targetParentId from recordBodyFile does not exist</li> | ||||
|      *             <li>model integrity exception: the action breaks system's integrity restrictions</li> | ||||
|      *             </ul> | ||||
|      * | ||||
|      */ | ||||
|     public Record fileRecord(RecordBodyFile recordBodyFile, String recordId) | ||||
| @@ -112,18 +118,21 @@ public class RecordsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * File the record recordId into file plan structure based on the location sent via the request body | ||||
|      * | ||||
|      * @param recordBodyFile The properties where to file the record | ||||
|      * @param recordId       The id of the record to file | ||||
|      * @param recordBodyFile | ||||
|      *            The properties where to file the record | ||||
|      * @param recordId | ||||
|      *            The id of the record to file | ||||
|      * @return The {@link Record} with the given properties | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>Invalid parameter: {@code recordBodyFile} is not a valid format,{@code recordId} is not a record</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to file to {@code fileplanComponentId}</li> | ||||
|      *  <li>{@code recordId} does not exist</li> | ||||
|      *  <li>targetParentId from recordBodyFile does not exist</li> | ||||
|      *  <li>model integrity exception: the action breaks system's integrity restrictions</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>Invalid parameter: {@code recordBodyFile} is not a valid format,{@code recordId} is not a record</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to file to {@code fileplanComponentId}</li> | ||||
|      *             <li>{@code recordId} does not exist</li> | ||||
|      *             <li>targetParentId from recordBodyFile does not exist</li> | ||||
|      *             <li>model integrity exception: the action breaks system's integrity restrictions</li> | ||||
|      *             </ul> | ||||
|      * | ||||
|      */ | ||||
|     public Record fileRecord(RecordBodyFile recordBodyFile, String recordId, String parameters) | ||||
| @@ -132,12 +141,11 @@ public class RecordsAPI extends RMModelRequest | ||||
|         mandatoryString("recordId", recordId); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(Record.class, requestWithBody( | ||||
|             POST, | ||||
|             toJson(recordBodyFile), | ||||
|             "/records/{recordId}/file?{parameters}", | ||||
|             recordId, | ||||
|             parameters | ||||
|         )); | ||||
|                 POST, | ||||
|                 toJson(recordBodyFile), | ||||
|                 "/records/{recordId}/file?{parameters}", | ||||
|                 recordId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -153,41 +161,45 @@ public class RecordsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Complete the record recordId | ||||
|      * | ||||
|      * @param recordId The id of the record to complete | ||||
|      * @param recordId | ||||
|      *            The id of the record to complete | ||||
|      * @return The completed {@link Record} with the given properties | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      *                   <ul> | ||||
|      *                   <li>Invalid parameter: {@code recordId} is not a record</li> | ||||
|      *                   <li>authentication fails</li> | ||||
|      *                   <li>current user does not have permission to complete {@code recordId}</li> | ||||
|      *                   <li>{@code recordId} does not exist or is frozen</li> | ||||
|      *                   <li>model integrity exception: the record is already completed</li> | ||||
|      *                   <li>model integrity exception: the record has missing meta-data</li> | ||||
|      *                   </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>Invalid parameter: {@code recordId} is not a record</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to complete {@code recordId}</li> | ||||
|      *             <li>{@code recordId} does not exist or is frozen</li> | ||||
|      *             <li>model integrity exception: the record is already completed</li> | ||||
|      *             <li>model integrity exception: the record has missing meta-data</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public Record completeRecord(String recordId, String parameters) | ||||
|     { | ||||
|         mandatoryString("recordId", recordId); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(Record.class, simpleRequest( | ||||
|             POST, | ||||
|             "/records/{recordId}/complete?{parameters}", | ||||
|             recordId, | ||||
|             parameters | ||||
|         )); | ||||
|                 POST, | ||||
|                 "/records/{recordId}/complete?{parameters}", | ||||
|                 recordId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Deletes a record. | ||||
|      * | ||||
|      * @param recordId The identifier of a record | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code recordId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to delete {@code recordId}</li> | ||||
|      *  <li>{@code recordId} does not exist</li> | ||||
|      *  <li>{@code recordId} is locked and cannot be deleted</li> | ||||
|      * </ul> | ||||
|      * @param recordId | ||||
|      *            The identifier of a record | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to delete {@code recordId}</li> | ||||
|      *             <li>{@code recordId} does not exist</li> | ||||
|      *             <li>{@code recordId} is locked and cannot be deleted</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public void deleteRecord(String recordId) | ||||
|     { | ||||
| @@ -196,8 +208,7 @@ public class RecordsAPI extends RMModelRequest | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|                 DELETE, | ||||
|                 "records/{recordId}", | ||||
|                 recordId | ||||
|         )); | ||||
|                 recordId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -213,16 +224,19 @@ public class RecordsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets a record. | ||||
|      * | ||||
|      * @param recordId The identifier of a record | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordId | ||||
|      *            The identifier of a record | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link Record} for the given {@code recordId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code recordId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code recordId}</li> | ||||
|      *  <li>{@code recordId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code recordId}</li> | ||||
|      *             <li>{@code recordId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public Record getRecord(String recordId, String parameters) | ||||
|     { | ||||
| @@ -232,8 +246,7 @@ public class RecordsAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "records/{recordId}?{parameters}", | ||||
|                 recordId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -250,19 +263,23 @@ public class RecordsAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Updates a record. | ||||
|      * | ||||
|      * @param recordModel The record model which holds the information | ||||
|      * @param recordId The identifier of a record | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordModel | ||||
|      *            The record model which holds the information | ||||
|      * @param recordId | ||||
|      *            The identifier of a record | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The updated {@link Record} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>the update request is invalid or {@code recordId} is not a valid format or {@code recordModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to update {@code recordId}</li> | ||||
|      *  <li>{@code recordId} does not exist</li> | ||||
|      *  <li>the updated name clashes with an existing record in the current parent folder</li> | ||||
|      *  <li>model integrity exception, including file name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>the update request is invalid or {@code recordId} is not a valid format or {@code recordModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to update {@code recordId}</li> | ||||
|      *             <li>{@code recordId} does not exist</li> | ||||
|      *             <li>the updated name clashes with an existing record in the current parent folder</li> | ||||
|      *             <li>model integrity exception, including file name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public Record updateRecord(Record recordModel, String recordId, String parameters) | ||||
|     { | ||||
| @@ -274,7 +291,6 @@ public class RecordsAPI extends RMModelRequest | ||||
|                 toJson(recordModel), | ||||
|                 "records/{recordId}?{parameters}", | ||||
|                 recordId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -26,21 +26,22 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionSchedule; | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionScheduleActionDefinition; | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionScheduleCollection; | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionScheduleStepCollection; | ||||
| import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionSchedule; | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionScheduleActionDefinition; | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionScheduleCollection; | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionScheduleStepCollection; | ||||
| import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
|  | ||||
| public class RetentionScheduleAPI extends RMModelRequest | ||||
| { | ||||
| @@ -53,22 +54,25 @@ public class RetentionScheduleAPI extends RMModelRequest | ||||
|         super(rmRestWrapper); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     /** | ||||
|      * Creates a retention schedule. | ||||
|      * | ||||
|      * @param retentionScheduleModel The retentionSchedule model | ||||
|      * @param recordCategoryId The identifier of a record category | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param retentionScheduleModel | ||||
|      *            The retentionSchedule model | ||||
|      * @param recordCategoryId | ||||
|      *            The identifier of a record category | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The created {@link RetentionSchedule} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code recordCategoryId} is not a valid format or {@code recordCategoryId} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to add children to {@code recordCategoryId}</li> | ||||
|      *  <li>{@code recordCategoryId} does not exist</li> | ||||
|      *  <li>new name clashes with an existing node in the current parent container</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code recordCategoryId} is not a valid format or {@code recordCategoryId} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to add children to {@code recordCategoryId}</li> | ||||
|      *             <li>{@code recordCategoryId} does not exist</li> | ||||
|      *             <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RetentionSchedule createRetentionSchedule(RetentionSchedule retentionScheduleModel, String recordCategoryId, String parameters) | ||||
|     { | ||||
| @@ -76,12 +80,11 @@ public class RetentionScheduleAPI extends RMModelRequest | ||||
|         mandatoryObject("retentionScheduleModel", retentionScheduleModel); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(RetentionSchedule.class, requestWithBody( | ||||
|             POST, | ||||
|             toJson(retentionScheduleModel), | ||||
|             "record-categories/{recordCategoryId}/retention-schedules", | ||||
|             recordCategoryId, | ||||
|             parameters | ||||
|         )); | ||||
|                 POST, | ||||
|                 toJson(retentionScheduleModel), | ||||
|                 "record-categories/{recordCategoryId}/retention-schedules", | ||||
|                 recordCategoryId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -95,26 +98,28 @@ public class RetentionScheduleAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the retentionSchedule of a record category. | ||||
|      * | ||||
|      * @param recordCategoryId The identifier of a record category | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param recordCategoryId | ||||
|      *            The identifier of a record category | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link RetentionSchedule} for the given {@code recordCategoryId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code recordCategoryId}</li> | ||||
|      *  <li>{@code recordCategoryId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code recordCategoryId}</li> | ||||
|      *             <li>{@code recordCategoryId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RetentionScheduleCollection getRetentionSchedule(String recordCategoryId, String parameters) | ||||
|     { | ||||
|         mandatoryString("recordCategoryId", recordCategoryId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(RetentionScheduleCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "record-categories/{recordCategoryId}/retention-schedules?{parameters}", | ||||
|             recordCategoryId, | ||||
|             parameters | ||||
|         )); | ||||
|                 GET, | ||||
|                 "record-categories/{recordCategoryId}/retention-schedules?{parameters}", | ||||
|                 recordCategoryId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -128,18 +133,22 @@ public class RetentionScheduleAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Creates a step in the retention schedule. | ||||
|      * | ||||
|      * @param retentionScheduleActionDefinition The retentionScheduleActionDefinition model | ||||
|      * @param retentionScheduleId The identifier of a retention schedule id | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param retentionScheduleActionDefinition | ||||
|      *            The retentionScheduleActionDefinition model | ||||
|      * @param retentionScheduleId | ||||
|      *            The identifier of a retention schedule id | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The created {@link RetentionScheduleActionDefinition} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code retentionScheduleId} is not a valid format or {@code retentionScheduleId} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to add children to {@code retentionScheduleId}</li> | ||||
|      *  <li>{@code retentionScheduleId} does not exist</li> | ||||
|      *  <li>new name clashes with an existing node in the current parent container</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code retentionScheduleId} is not a valid format or {@code retentionScheduleId} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to add children to {@code retentionScheduleId}</li> | ||||
|      *             <li>{@code retentionScheduleId} does not exist</li> | ||||
|      *             <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RetentionScheduleActionDefinition createRetentionScheduleStep(RetentionScheduleActionDefinition retentionScheduleActionDefinition, String retentionScheduleId, String parameters) | ||||
|     { | ||||
| @@ -147,12 +156,11 @@ public class RetentionScheduleAPI extends RMModelRequest | ||||
|         mandatoryObject("retentionScheduleActionDefinition", retentionScheduleActionDefinition); | ||||
|  | ||||
|         return getRmRestWrapper().processModel(RetentionScheduleActionDefinition.class, requestWithBody( | ||||
|             POST, | ||||
|             toJson(retentionScheduleActionDefinition), | ||||
|             "retention-schedules/{retentionScheduleId}/retention-steps", | ||||
|             retentionScheduleId, | ||||
|             parameters | ||||
|         )); | ||||
|                 POST, | ||||
|                 toJson(retentionScheduleActionDefinition), | ||||
|                 "retention-schedules/{retentionScheduleId}/retention-steps", | ||||
|                 retentionScheduleId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -166,26 +174,28 @@ public class RetentionScheduleAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the retentionSchedule of a record category. | ||||
|      * | ||||
|      * @param retentionScheduleId The identifier of a record category | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param retentionScheduleId | ||||
|      *            The identifier of a record category | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link RetentionScheduleActionDefinition} for the given {@code recordCategoryId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code recordCategoryId}</li> | ||||
|      *  <li>{@code recordCategoryId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code recordCategoryId}</li> | ||||
|      *             <li>{@code recordCategoryId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public RetentionScheduleStepCollection getRetentionScheduleStep(String retentionScheduleId, String parameters) | ||||
|     { | ||||
|         mandatoryString("retentionScheduleId", retentionScheduleId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(RetentionScheduleStepCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "retention-schedules/{retentionScheduleId}/retention-steps?{parameters}", | ||||
|             retentionScheduleId, | ||||
|             parameters | ||||
|         )); | ||||
|                 GET, | ||||
|                 "retention-schedules/{retentionScheduleId}/retention-steps?{parameters}", | ||||
|                 retentionScheduleId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -27,11 +27,12 @@ | ||||
|  | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.transfer.Transfer; | ||||
| import org.alfresco.rest.rm.community.model.transfer.TransferChildCollection; | ||||
| @@ -46,7 +47,8 @@ import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
| public class TransferAPI extends RMModelRequest | ||||
| { | ||||
|     /** | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public TransferAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -66,16 +68,19 @@ public class TransferAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets a transfer. | ||||
|      * | ||||
|      * @param transferId The identifier of a transfer | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param transferId | ||||
|      *            The identifier of a transfer | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link Transfer} for the given {@code transferId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code transferId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code transferId}</li> | ||||
|      *  <li>{@code transferId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code transferId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code transferId}</li> | ||||
|      *             <li>{@code transferId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public Transfer getTransfer(String transferId, String parameters) | ||||
|     { | ||||
| @@ -85,9 +90,9 @@ public class TransferAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "/transfers/{transferId}?{parameters}", | ||||
|                 transferId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * see {@link #getTransfersChildren(String, String)} | ||||
|      */ | ||||
| @@ -101,25 +106,27 @@ public class TransferAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the children (record folder or record) of a transfer. | ||||
|      * | ||||
|      * @param transferId The identifier of a transfer | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param transferId | ||||
|      *            The identifier of a transfer | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link TransferChildCollection} for the given {@code transferId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code transferId}</li> | ||||
|      *  <li>{@code filePlanId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code transferId}</li> | ||||
|      *             <li>{@code filePlanId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public TransferChildCollection getTransfersChildren(String transferId, String parameters) | ||||
|     { | ||||
|         mandatoryString("transferId", transferId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(TransferChildCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "transfers/{filePlanId}/children?{parameters}", | ||||
|             transferId, | ||||
|             parameters | ||||
|         )); | ||||
|                 GET, | ||||
|                 "transfers/{filePlanId}/children?{parameters}", | ||||
|                 transferId, | ||||
|                 parameters)); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -27,14 +27,15 @@ | ||||
|  | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.transfer.TransferCollection; | ||||
| @@ -50,7 +51,8 @@ import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
| public class TransferContainerAPI extends RMModelRequest | ||||
| { | ||||
|     /** | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public TransferContainerAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -70,16 +72,19 @@ public class TransferContainerAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets a transfer container. | ||||
|      * | ||||
|      * @param transferContainerId The identifier of a transfer container | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param transferContainerId | ||||
|      *            The identifier of a transfer container | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link TransferContainer} for the given {@code transferContainerId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code transferContainerId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code transferContainerId}</li> | ||||
|      *  <li>{@code transferContainerId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code transferContainerId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code transferContainerId}</li> | ||||
|      *             <li>{@code transferContainerId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public TransferContainer getTransferContainer(String transferContainerId, String parameters) | ||||
|     { | ||||
| @@ -89,8 +94,7 @@ public class TransferContainerAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "/transfer-containers/{transferContainerId}?{parameters}", | ||||
|                 transferContainerId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -107,19 +111,24 @@ public class TransferContainerAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Updates a transfer container. | ||||
|      * | ||||
|      * @param transferContainerModel The transfer container model which holds the information | ||||
|      * @param transferContainerId The identifier of a transfer container | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param returns The updated {@link TransferContainer} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>the update request is invalid or {@code transferContainerId} is not a valid format or {@code transferContainerModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to update {@code transferContainerId}</li> | ||||
|      *  <li>{@code transferContainerId} does not exist</li> | ||||
|      *  <li>the updated name clashes with an existing transfer container in the current file plan</li> | ||||
|      *  <li>model integrity exception, including transfer container name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @param transferContainerModel | ||||
|      *            The transfer container model which holds the information | ||||
|      * @param transferContainerId | ||||
|      *            The identifier of a transfer container | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @param returns | ||||
|      *            The updated {@link TransferContainer} | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>the update request is invalid or {@code transferContainerId} is not a valid format or {@code transferContainerModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to update {@code transferContainerId}</li> | ||||
|      *             <li>{@code transferContainerId} does not exist</li> | ||||
|      *             <li>the updated name clashes with an existing transfer container in the current file plan</li> | ||||
|      *             <li>model integrity exception, including transfer container name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public TransferContainer updateTransferContainer(TransferContainer transferContainerModel, String transferContainerId, String parameters) | ||||
|     { | ||||
| @@ -131,8 +140,7 @@ public class TransferContainerAPI extends RMModelRequest | ||||
|                 toJson(transferContainerModel), | ||||
|                 "transfer-containers/{transferContainerId}?{parameters}", | ||||
|                 transferContainerId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -148,25 +156,27 @@ public class TransferContainerAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the children (transfers) of a transfer container. | ||||
|      * | ||||
|      * @param transferContainerId The identifier of a transfer container | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param transferContainerId | ||||
|      *            The identifier of a transfer container | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link TransferCollection} for the given {@code transferContainerId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code transferContainerId}</li> | ||||
|      *  <li>{@code filePlanId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code transferContainerId}</li> | ||||
|      *             <li>{@code filePlanId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public TransferCollection getTransfers(String transferContainerId, String parameters) | ||||
|     { | ||||
|         mandatoryString("transferContainerId", transferContainerId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(TransferCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "transfer-containers/{filePlanId}/transfers?{parameters}", | ||||
|             transferContainerId, | ||||
|             parameters | ||||
|         )); | ||||
|                 GET, | ||||
|                 "transfer-containers/{filePlanId}/transfers?{parameters}", | ||||
|                 transferContainerId, | ||||
|                 parameters)); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -26,17 +26,18 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
| import static org.testng.Assert.fail; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentType.CONTENT_TYPE; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
| import static org.testng.Assert.fail; | ||||
|  | ||||
| import java.io.File; | ||||
| import java.io.IOException; | ||||
| @@ -44,7 +45,6 @@ import java.util.Iterator; | ||||
|  | ||||
| import com.fasterxml.jackson.databind.JsonNode; | ||||
| import com.fasterxml.jackson.databind.ObjectMapper; | ||||
|  | ||||
| import io.restassured.builder.RequestSpecBuilder; | ||||
| import io.restassured.http.ContentType; | ||||
|  | ||||
| @@ -65,7 +65,8 @@ import org.alfresco.rest.rm.community.util.UnfiledContainerChildMixin; | ||||
| public class UnfiledContainerAPI extends RMModelRequest | ||||
| { | ||||
|     /** | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public UnfiledContainerAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -85,16 +86,19 @@ public class UnfiledContainerAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets an unfiled record container. | ||||
|      * | ||||
|      * @param unfiledContainerId The identifier of a unfiled record container | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param unfiledContainerId | ||||
|      *            The identifier of a unfiled record container | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link UnfiledContainer} for the given {@code unfiledContainerId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code unfiledContainerId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code unfiledContainerId}</li> | ||||
|      *  <li>{@code unfiledContainerId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code unfiledContainerId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code unfiledContainerId}</li> | ||||
|      *             <li>{@code unfiledContainerId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public UnfiledContainer getUnfiledContainer(String unfiledContainerId, String parameters) | ||||
|     { | ||||
| @@ -104,8 +108,7 @@ public class UnfiledContainerAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "unfiled-containers/{unfiledContainerId}?{parameters}", | ||||
|                 unfiledContainerId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -121,26 +124,28 @@ public class UnfiledContainerAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the children of an unfiled records container | ||||
|      * | ||||
|      * @param unfiledContainerId The identifier of an unfiled records container | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param unfiledContainerId | ||||
|      *            The identifier of an unfiled records container | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link UnfiledContainerChildCollection} for the given {@code unfiledContainerId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code unfiledContainerId}</li> | ||||
|      *  <li>{@code unfiledContainerId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code unfiledContainerId}</li> | ||||
|      *             <li>{@code unfiledContainerId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public UnfiledContainerChildCollection getUnfiledContainerChildren(String unfiledContainerId, String parameters) | ||||
|     { | ||||
|         mandatoryString("unfiledContainerId", unfiledContainerId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(UnfiledContainerChildCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "unfiled-containers/{unfiledContainerId}/children?{parameters}", | ||||
|             unfiledContainerId, | ||||
|             parameters | ||||
|         )); | ||||
|                 GET, | ||||
|                 "unfiled-containers/{unfiledContainerId}/children?{parameters}", | ||||
|                 unfiledContainerId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -157,19 +162,23 @@ public class UnfiledContainerAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Creates an unfiled container child. Can be a record or an unfiled record folder. | ||||
|      * | ||||
|      * @param unfiledContainerChildModel The unfiled container child model which holds the information | ||||
|      * @param unfiledContainerId The identifier of an unfiled container | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param unfiledContainerChildModel | ||||
|      *            The unfiled container child model which holds the information | ||||
|      * @param unfiledContainerId | ||||
|      *            The identifier of an unfiled container | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The created {@link UnfiledContainerChild} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code unfiledContainerId} is not a valid format or {@code unfiledContainerChildModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to add children to {@code unfiledContainerId}</li> | ||||
|      *  <li>{@code unfiledContainerId} does not exist</li> | ||||
|      *  <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *  <li>model integrity exception, including node name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code unfiledContainerId} is not a valid format or {@code unfiledContainerChildModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to add children to {@code unfiledContainerId}</li> | ||||
|      *             <li>{@code unfiledContainerId} does not exist</li> | ||||
|      *             <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *             <li>model integrity exception, including node name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public UnfiledContainerChild createUnfiledContainerChild(UnfiledContainerChild unfiledContainerChildModel, String unfiledContainerId, String parameters) | ||||
|     { | ||||
| @@ -181,18 +190,21 @@ public class UnfiledContainerAPI extends RMModelRequest | ||||
|                 toJson(unfiledContainerChildModel), | ||||
|                 "unfiled-containers/{unfiledContainerId}/children?{parameters}", | ||||
|                 unfiledContainerId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Create a record from file resource | ||||
|      * | ||||
|      * @param unfiledContainerChildModel {@link UnfiledContainerChild} for electronic record to be created | ||||
|      * @param unfiledContainerChildContent {@link File} pointing to the content of the electronic record to be created | ||||
|      * @param unfiledContainerId The identifier of a unfiled container | ||||
|      * @param unfiledContainerChildModel | ||||
|      *            {@link UnfiledContainerChild} for electronic record to be created | ||||
|      * @param unfiledContainerChildContent | ||||
|      *            {@link File} pointing to the content of the electronic record to be created | ||||
|      * @param unfiledContainerId | ||||
|      *            The identifier of a unfiled container | ||||
|      * @return newly created {@link UnfiledContainerChild} | ||||
|      * @throws RuntimeException for invalid recordModel JSON strings | ||||
|      * @throws RuntimeException | ||||
|      *             for invalid recordModel JSON strings | ||||
|      */ | ||||
|     public UnfiledContainerChild uploadRecord(UnfiledContainerChild unfiledContainerChildModel, String unfiledContainerId, File unfiledContainerChildContent) | ||||
|     { | ||||
| @@ -205,10 +217,7 @@ public class UnfiledContainerAPI extends RMModelRequest | ||||
|             fail("Only electronic records are supported"); | ||||
|         } | ||||
|  | ||||
|         /* | ||||
|          * For file uploads nodeBodyCreate is ignored hence can't be used. Append all Record fields | ||||
|          * to the request. | ||||
|          */ | ||||
|         /* For file uploads nodeBodyCreate is ignored hence can't be used. Append all Record fields to the request. */ | ||||
|         RequestSpecBuilder builder = getRmRestWrapper().configureRequestSpec(); | ||||
|         JsonNode root; | ||||
|         try | ||||
| @@ -246,19 +255,24 @@ public class UnfiledContainerAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Updates an unfiled record container | ||||
|      * | ||||
|      * @param unfiledContainerModel The unfiled record container model which holds the information | ||||
|      * @param unfiledContainerId The identifier of an unfiled record container | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param returns The updated {@link UnfiledContainer} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>the update request is invalid or {@code unfiledContainerId} is not a valid format or {@code unfiledContainerModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to update {@code unfiledContainerId}</li> | ||||
|      *  <li>{@code unfiledContainerId} does not exist</li> | ||||
|      *  <li>the updated name clashes with an existing root category of special container in the current fileplan</li> | ||||
|      *  <li>model integrity exception, including file name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @param unfiledContainerModel | ||||
|      *            The unfiled record container model which holds the information | ||||
|      * @param unfiledContainerId | ||||
|      *            The identifier of an unfiled record container | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @param returns | ||||
|      *            The updated {@link UnfiledContainer} | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>the update request is invalid or {@code unfiledContainerId} is not a valid format or {@code unfiledContainerModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to update {@code unfiledContainerId}</li> | ||||
|      *             <li>{@code unfiledContainerId} does not exist</li> | ||||
|      *             <li>the updated name clashes with an existing root category of special container in the current fileplan</li> | ||||
|      *             <li>model integrity exception, including file name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public UnfiledContainer updateUnfiledContainer(UnfiledContainer unfiledContainerModel, String unfiledContainerId, String parameters) | ||||
|     { | ||||
| @@ -270,8 +284,7 @@ public class UnfiledContainerAPI extends RMModelRequest | ||||
|                 toJson(unfiledContainerModel), | ||||
|                 "unfiled-containers/{unfiledContainerId}?{parameters}", | ||||
|                 unfiledContainerId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -26,12 +26,6 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentType.CONTENT_TYPE; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
| import static org.apache.commons.lang3.StringUtils.EMPTY; | ||||
| import static org.springframework.http.HttpMethod.DELETE; | ||||
| import static org.springframework.http.HttpMethod.GET; | ||||
| @@ -39,6 +33,13 @@ import static org.springframework.http.HttpMethod.POST; | ||||
| import static org.springframework.http.HttpMethod.PUT; | ||||
| import static org.testng.Assert.fail; | ||||
|  | ||||
| import static org.alfresco.rest.core.RestRequest.requestWithBody; | ||||
| import static org.alfresco.rest.core.RestRequest.simpleRequest; | ||||
| import static org.alfresco.rest.rm.community.model.fileplancomponents.FilePlanComponentType.CONTENT_TYPE; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryObject; | ||||
| import static org.alfresco.rest.rm.community.util.ParameterCheck.mandatoryString; | ||||
| import static org.alfresco.rest.rm.community.util.PojoUtility.toJson; | ||||
|  | ||||
| import java.io.File; | ||||
| import java.io.IOException; | ||||
| import java.util.Iterator; | ||||
| @@ -64,7 +65,8 @@ import org.alfresco.rest.rm.community.util.UnfiledContainerChildMixin; | ||||
| public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
| { | ||||
|     /** | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      */ | ||||
|     public UnfiledRecordFolderAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -84,16 +86,19 @@ public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets an unfiled record folder. | ||||
|      * | ||||
|      * @param unfiledRecordFolderId The identifier of a unfiled record folder | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param unfiledRecordFolderId | ||||
|      *            The identifier of a unfiled record folder | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link UnfiledRecordFolder} for the given {@code unfiledRecordFolderId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code unfiledRecordFolderId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code unfiledRecordFolderId}</li> | ||||
|      *  <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code unfiledRecordFolderId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code unfiledRecordFolderId}</li> | ||||
|      *             <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public UnfiledRecordFolder getUnfiledRecordFolder(String unfiledRecordFolderId, String parameters) | ||||
|     { | ||||
| @@ -103,8 +108,7 @@ public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "unfiled-record-folders/{unfiledRecordFolderId}?{parameters}", | ||||
|                 unfiledRecordFolderId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -120,26 +124,28 @@ public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Gets the children of an unfiled record folder | ||||
|      * | ||||
|      * @param unfiledRecordFolderId The identifier of an unfiled records folder | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param unfiledRecordFolderId | ||||
|      *            The identifier of an unfiled records folder | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {@link UnfiledRecordFolderChildCollection} for the given {@code unfiledRecordFolderId} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to read {@code unfiledRecordFolderId}</li> | ||||
|      *  <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      *</ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to read {@code unfiledRecordFolderId}</li> | ||||
|      *             <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public UnfiledContainerChildCollection getUnfiledRecordFolderChildren(String unfiledRecordFolderId, String parameters) | ||||
|     { | ||||
|         mandatoryString("unfiledRecordFolderId", unfiledRecordFolderId); | ||||
|  | ||||
|         return getRmRestWrapper().processModels(UnfiledContainerChildCollection.class, simpleRequest( | ||||
|             GET, | ||||
|             "unfiled-record-folders/{unfiledRecordFolderId}/children?{parameters}", | ||||
|             unfiledRecordFolderId, | ||||
|             parameters | ||||
|         )); | ||||
|                 GET, | ||||
|                 "unfiled-record-folders/{unfiledRecordFolderId}/children?{parameters}", | ||||
|                 unfiledRecordFolderId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -156,19 +162,23 @@ public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Creates an unfiled record folder child. Can be a record or an unfiled record folder. | ||||
|      * | ||||
|      * @param unfiledRecordFolderChildModel The unfiled folder child model which holds the information | ||||
|      * @param unfiledRecordFolderId The identifier of an unfiled folder | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param unfiledRecordFolderChildModel | ||||
|      *            The unfiled folder child model which holds the information | ||||
|      * @param unfiledRecordFolderId | ||||
|      *            The identifier of an unfiled folder | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The created {@link UnfiledRecordFolderChild} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code unfiledRecordFolderId} is not a valid format or {@code unfiledRecordFolderChildModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to add children to {@code unfiledRecordFolderId}</li> | ||||
|      *  <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      *  <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *  <li>model integrity exception, including node name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code unfiledRecordFolderId} is not a valid format or {@code unfiledRecordFolderChildModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to add children to {@code unfiledRecordFolderId}</li> | ||||
|      *             <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      *             <li>new name clashes with an existing node in the current parent container</li> | ||||
|      *             <li>model integrity exception, including node name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public UnfiledContainerChild createUnfiledRecordFolderChild(UnfiledContainerChild unfiledRecordFolderChildModel, String unfiledRecordFolderId, String parameters) | ||||
|     { | ||||
| @@ -180,18 +190,21 @@ public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
|                 toJson(unfiledRecordFolderChildModel), | ||||
|                 "unfiled-record-folders/{unfiledRecordFolderId}/children?{parameters}", | ||||
|                 unfiledRecordFolderId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Create a record from file resource | ||||
|      * | ||||
|      * @param unfiledRecordFolderChildModel {@link UnfiledContainerChild} for electronic record to be created | ||||
|      * @param unfiledRecordFolderChildContent {@link File} pointing to the content of the electronic record to be created | ||||
|      * @param unfiledRecordFolderId The identifier of a unfiled record folder | ||||
|      * @param unfiledRecordFolderChildModel | ||||
|      *            {@link UnfiledContainerChild} for electronic record to be created | ||||
|      * @param unfiledRecordFolderChildContent | ||||
|      *            {@link File} pointing to the content of the electronic record to be created | ||||
|      * @param unfiledRecordFolderId | ||||
|      *            The identifier of a unfiled record folder | ||||
|      * @return newly created {@link UnfiledContainerChild} | ||||
|      * @throws RuntimeException for invalid recordModel JSON strings | ||||
|      * @throws RuntimeException | ||||
|      *             for invalid recordModel JSON strings | ||||
|      */ | ||||
|     public UnfiledContainerChild uploadRecord(UnfiledContainerChild unfiledRecordFolderChildModel, String unfiledRecordFolderId, File unfiledRecordFolderChildContent) | ||||
|     { | ||||
| @@ -204,10 +217,7 @@ public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
|             fail("Only electronic records are supported"); | ||||
|         } | ||||
|  | ||||
|         /* | ||||
|          * For file uploads nodeBodyCreate is ignored hence can't be used. Append all Record fields | ||||
|          * to the request. | ||||
|          */ | ||||
|         /* For file uploads nodeBodyCreate is ignored hence can't be used. Append all Record fields to the request. */ | ||||
|         RequestSpecBuilder builder = getRmRestWrapper().configureRequestSpec(); | ||||
|         JsonNode root; | ||||
|         try | ||||
| @@ -245,19 +255,24 @@ public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Updates an unfiled record folder | ||||
|      * | ||||
|      * @param unfiledRecordFolderModel The unfiled record folder model which holds the information | ||||
|      * @param unfiledRecordFolderId The identifier of an unfiled record folder | ||||
|      * @param parameters The URL parameters to add | ||||
|      * @param returns The updated {@link UnfiledRecordFolder} | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>the update request is invalid or {@code unfiledRecordFolderId} is not a valid format or {@code unfiledRecordFolderModel} is invalid</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to update {@code unfiledRecordFolderId}</li> | ||||
|      *  <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      *  <li>the updated name clashes with an existing root category of special container in the current fileplan</li> | ||||
|      *  <li>model integrity exception, including file name with invalid characters</li> | ||||
|      * </ul> | ||||
|      * @param unfiledRecordFolderModel | ||||
|      *            The unfiled record folder model which holds the information | ||||
|      * @param unfiledRecordFolderId | ||||
|      *            The identifier of an unfiled record folder | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @param returns | ||||
|      *            The updated {@link UnfiledRecordFolder} | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>the update request is invalid or {@code unfiledRecordFolderId} is not a valid format or {@code unfiledRecordFolderModel} is invalid</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to update {@code unfiledRecordFolderId}</li> | ||||
|      *             <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      *             <li>the updated name clashes with an existing root category of special container in the current fileplan</li> | ||||
|      *             <li>model integrity exception, including file name with invalid characters</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public UnfiledRecordFolder updateUnfiledRecordFolder(UnfiledRecordFolder unfiledRecordFolderModel, String unfiledRecordFolderId, String parameters) | ||||
|     { | ||||
| @@ -269,22 +284,23 @@ public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
|                 toJson(unfiledRecordFolderModel), | ||||
|                 "unfiled-record-folders/{unfiledRecordFolderId}?{parameters}", | ||||
|                 unfiledRecordFolderId, | ||||
|                 parameters | ||||
|         )); | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Deletes an unfiled record folder. | ||||
|      * | ||||
|      * @param unfiledRecordFolderId The identifier of a unfiled record folder | ||||
|      * @throws RuntimeException for the following cases: | ||||
|      * <ul> | ||||
|      *  <li>{@code unfiledRecordFolderId} is not a valid format</li> | ||||
|      *  <li>authentication fails</li> | ||||
|      *  <li>current user does not have permission to delete {@code unfiledRecordFolderId}</li> | ||||
|      *  <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      *  <li>{@code unfiledRecordFolderId} is locked and cannot be deleted</li> | ||||
|      * </ul> | ||||
|      * @param unfiledRecordFolderId | ||||
|      *            The identifier of a unfiled record folder | ||||
|      * @throws RuntimeException | ||||
|      *             for the following cases: | ||||
|      *             <ul> | ||||
|      *             <li>{@code unfiledRecordFolderId} is not a valid format</li> | ||||
|      *             <li>authentication fails</li> | ||||
|      *             <li>current user does not have permission to delete {@code unfiledRecordFolderId}</li> | ||||
|      *             <li>{@code unfiledRecordFolderId} does not exist</li> | ||||
|      *             <li>{@code unfiledRecordFolderId} is locked and cannot be deleted</li> | ||||
|      *             </ul> | ||||
|      */ | ||||
|     public void deleteUnfiledRecordFolder(String unfiledRecordFolderId) | ||||
|     { | ||||
| @@ -293,8 +309,7 @@ public class UnfiledRecordFolderAPI extends RMModelRequest | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|                 DELETE, | ||||
|                 "unfiled-record-folders/{recordFolderId}", | ||||
|                 unfiledRecordFolderId | ||||
|         )); | ||||
|                 unfiledRecordFolderId)); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -44,12 +44,10 @@ public class CommonTestUtils | ||||
|  | ||||
|     /** Private constructor to prevent instantiation. */ | ||||
|     private CommonTestUtils() | ||||
|     { | ||||
|     } | ||||
|     {} | ||||
|  | ||||
|     /** | ||||
|      * Generate a prefix to namespace the objects in a test class. Note that four random hex digits should be good enough to avoid | ||||
|      * collisions when running locally and should also be short enough to maintain readability. | ||||
|      * Generate a prefix to namespace the objects in a test class. Note that four random hex digits should be good enough to avoid collisions when running locally and should also be short enough to maintain readability. | ||||
|      */ | ||||
|     public static String generateTestPrefix(Class<?> clazz) | ||||
|     { | ||||
|   | ||||
| @@ -41,17 +41,17 @@ import com.github.dockerjava.api.model.Frame; | ||||
| import com.github.dockerjava.core.DockerClientBuilder; | ||||
| import com.github.dockerjava.core.command.LogContainerResultCallback; | ||||
| import com.github.dockerjava.netty.NettyDockerCmdExecFactory; | ||||
|  | ||||
| import lombok.Getter; | ||||
| import lombok.Setter; | ||||
| import org.alfresco.utility.Utility; | ||||
| import org.apache.commons.lang3.SystemUtils; | ||||
| import org.apache.commons.lang.SystemUtils; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.beans.factory.annotation.Value; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import org.alfresco.utility.Utility; | ||||
|  | ||||
| /** | ||||
|  * Helper class for interaction with docker containers | ||||
|  * | ||||
| @@ -68,29 +68,31 @@ public class DockerHelper | ||||
|     private DockerClient dockerClient; | ||||
|  | ||||
|     @Autowired | ||||
|     public DockerHelper(@Value ("${docker.host}") String dockerHost) | ||||
|     public DockerHelper(@Value("${docker.host}") String dockerHost) | ||||
|     { | ||||
|         if (SystemUtils.IS_OS_WINDOWS) | ||||
|         { | ||||
|             this.dockerClient = DockerClientBuilder | ||||
|                 .getInstance(dockerHost) | ||||
|                 .withDockerCmdExecFactory(new NettyDockerCmdExecFactory()) | ||||
|                 .build(); | ||||
|                     .getInstance(dockerHost) | ||||
|                     .withDockerCmdExecFactory(new NettyDockerCmdExecFactory()) | ||||
|                     .build(); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             this.dockerClient = DockerClientBuilder | ||||
|                 .getInstance() | ||||
|                 .withDockerCmdExecFactory(new NettyDockerCmdExecFactory()) | ||||
|                 .build(); | ||||
|                     .getInstance() | ||||
|                     .withDockerCmdExecFactory(new NettyDockerCmdExecFactory()) | ||||
|                     .build(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Method for returning logs of docker container | ||||
|      * | ||||
|      * @param containerId - ID of the container | ||||
|      * @param timeStamp - get the logs since a specific timestamp | ||||
|      * @param containerId | ||||
|      *            - ID of the container | ||||
|      * @param timeStamp | ||||
|      *            - get the logs since a specific timestamp | ||||
|      * @return list of strings, where every string is log line | ||||
|      */ | ||||
|     private List<String> getDockerLogs(String containerId, int timeStamp) | ||||
| @@ -99,14 +101,13 @@ public class DockerHelper | ||||
|  | ||||
|         final LogContainerCmd logContainerCmd = getDockerClient().logContainerCmd(containerId); | ||||
|         logContainerCmd.withStdOut(true) | ||||
|                        .withStdErr(true) | ||||
|                        .withSince(timeStamp) // UNIX timestamp to filter logs. Output log-entries since that timestamp. | ||||
|                        .withTimestamps(true); //print timestamps for every log line | ||||
|                 .withStdErr(true) | ||||
|                 .withSince(timeStamp) // UNIX timestamp to filter logs. Output log-entries since that timestamp. | ||||
|                 .withTimestamps(true); // print timestamps for every log line | ||||
|  | ||||
|         try | ||||
|         { | ||||
|             logContainerCmd.exec(new LogContainerResultCallback() | ||||
|             { | ||||
|             logContainerCmd.exec(new LogContainerResultCallback() { | ||||
|                 @Override | ||||
|                 public void onNext(Frame item) | ||||
|                 { | ||||
| @@ -116,7 +117,7 @@ public class DockerHelper | ||||
|         } | ||||
|         catch (InterruptedException e) | ||||
|         { | ||||
|             Thread.currentThread().interrupt();  // set interrupt flag | ||||
|             Thread.currentThread().interrupt(); // set interrupt flag | ||||
|             LOGGER.error("Failed to retrieve logs of container " + containerId, e); | ||||
|         } | ||||
|  | ||||
| @@ -148,14 +149,14 @@ public class DockerHelper | ||||
|     /** | ||||
|      * Helper method to check if the specified exception is thrown in alfresco logs | ||||
|      * | ||||
|      * @param expectedException the expected exception to be thrown | ||||
|      * @param expectedException | ||||
|      *            the expected exception to be thrown | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public void checkExceptionIsInAlfrescoLogs(String expectedException) throws Exception | ||||
|     { | ||||
|         //Retry the operation because sometimes it takes few seconds to throw the exception | ||||
|         Utility.sleep(6000, 30000, () -> | ||||
|         { | ||||
|         // Retry the operation because sometimes it takes few seconds to throw the exception | ||||
|         Utility.sleep(6000, 30000, () -> { | ||||
|             List<String> alfrescoLogs = getAlfrescoLogs(); | ||||
|             assertTrue(alfrescoLogs.stream().anyMatch(logLine -> logLine.contains(expectedException))); | ||||
|         }); | ||||
| @@ -164,7 +165,8 @@ public class DockerHelper | ||||
|     /** | ||||
|      * Method for finding docker containers after the image name | ||||
|      * | ||||
|      * @param imageName - the name of the image used by container | ||||
|      * @param imageName | ||||
|      *            - the name of the image used by container | ||||
|      * @return the containers | ||||
|      */ | ||||
|     private List<Container> findContainersByImageName(String imageName) | ||||
| @@ -172,7 +174,7 @@ public class DockerHelper | ||||
|         final List<Container> containers = getDockerClient().listContainersCmd().withShowAll(true).exec(); | ||||
|  | ||||
|         return containers.stream() | ||||
|                          .filter(container -> container.getImage().contains(imageName)) | ||||
|                          .collect(Collectors.toList()); | ||||
|                 .filter(container -> container.getImage().contains(imageName)) | ||||
|                 .collect(Collectors.toList()); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -31,9 +31,7 @@ import com.fasterxml.jackson.annotation.JsonUnwrapped; | ||||
| import org.alfresco.rest.rm.community.model.record.RecordProperties; | ||||
|  | ||||
| /** | ||||
|  * Mix class for Record POJO class | ||||
|  * Mix-in annotations are: a way to associate annotations with classes | ||||
|  * without modifying (target) classes themselves. | ||||
|  * Mix class for Record POJO class Mix-in annotations are: a way to associate annotations with classes without modifying (target) classes themselves. | ||||
|  * | ||||
|  * @author Rodica Sutu | ||||
|  * @since 2.6 | ||||
| @@ -41,8 +39,7 @@ import org.alfresco.rest.rm.community.model.record.RecordProperties; | ||||
| public abstract class FilePlanComponentMixIn | ||||
| { | ||||
|     /** | ||||
|      * Annotation used to indicate that a property should be serialized "unwrapped" | ||||
|      * Its properties are instead included as properties of its containing Object | ||||
|      * Annotation used to indicate that a property should be serialized "unwrapped" Its properties are instead included as properties of its containing Object | ||||
|      */ | ||||
|     @JsonUnwrapped | ||||
|     abstract RecordProperties getProperties(); | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user