mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	Compare commits
	
		
			191 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 8cd46d4585 | ||
|  | 11d71e1941 | ||
|  | 353d50a35c | ||
|  | 2daafc711d | ||
|  | dfa94fbe21 | ||
|  | 4a93aec66b | ||
|  | 3f0bbc9844 | ||
|  | cb9ad42101 | ||
|  | ca385b3bbc | ||
|  | 19c1582f1e | ||
|  | 06a918b082 | ||
|  | f543de9959 | ||
|  | 8124279e6a | ||
|  | 4281fd5b2d | ||
|  | d10d88306b | ||
|  | 1d7a37cd8c | ||
|  | 4bcb795452 | ||
|  | 393b064918 | ||
|  | f741f2ca45 | ||
|  | ef676f11e4 | ||
|  | 478c81fee3 | ||
|  | cf9cc8042d | ||
|  | 8d790ed1cb | ||
|  | 87c7bd2877 | ||
|  | 9125f889b0 | ||
|  | 2fb74d2691 | ||
|  | d671162dae | ||
|  | bfaa629da7 | ||
|  | 719d73a558 | ||
|  | a2aa867f3f | ||
|  | 8d745c536a | ||
|  | b0f4c21ae3 | ||
|  | 72494e34fa | ||
|  | 792b7024ea | ||
|  | 40a1371f0d | ||
|  | c22c47e63f | ||
|  | 232299d42d | ||
|  | aca7969849 | ||
|  | 4ab2bbd3d6 | ||
|  | f68f02372d | ||
|  | 9b0eedc8c1 | ||
|  | f164dedcee | ||
|  | 9cdaa0a265 | ||
|  | ef034e596b | ||
|  | 1251081a69 | ||
|  | 2d16eb6f42 | ||
|  | e577134875 | ||
|  | 510eadd565 | ||
|  | 187646895c | ||
|  | f9515e336f | ||
|  | 828dd20576 | ||
|  | 3372e20c35 | ||
|  | 64b5cace27 | ||
|  | 83acf26cf4 | ||
|  | b3be0f2b7f | ||
|  | 7a6ebb9a05 | ||
|  | fa0f239618 | ||
|  | 43799408a8 | ||
|  | e7305006f0 | ||
|  | 40c30411af | ||
|  | 91f8b43237 | ||
|  | 6fccf828e1 | ||
|  | 3fac3373c9 | ||
|  | ee857ce1de | ||
|  | 483d7fab21 | ||
|  | 590209b299 | ||
|  | 376514df67 | ||
|  | 7144a2dd94 | ||
|  | b4da3d8c20 | ||
|  | 62de9ff0c0 | ||
|  | a11acce720 | ||
|  | 1128011e15 | ||
|  | d0cb45de0d | ||
|  | 2b48195896 | ||
|  | fbb95d6a7f | ||
|  | 502427e852 | ||
|  | 3ff2d79641 | ||
|  | f274b88ece | ||
|  | 21550ec30b | ||
|  | 8665267225 | ||
|  | 984b0bc719 | ||
|  | 5b89fc0be7 | ||
|  | bf3a3382fd | ||
|  | 14d007fae8 | ||
|  | 79317ddc9d | ||
|  | c0e762fe5e | ||
|  | 5109b99520 | ||
|  | dfc6306331 | ||
|  | 731f98921f | ||
|  | 0b21dbdc0a | ||
|  | dd928356b8 | ||
|  | 1844d8bdb9 | ||
|  | 17eef66f5c | ||
|  | 1d1f269a70 | ||
|  | 2ccf6044b8 | ||
|  | bdd09784e1 | ||
|  | de5d70be46 | ||
|  | 8cacba0988 | ||
|  | 60187bf9a2 | ||
|  | ff4634be19 | ||
|  | 9c64b45908 | ||
|  | d97d8fba04 | ||
|  | 368b571d9c | ||
|  | e9da7d222b | ||
|  | 8c059460f9 | ||
|  | bd0aaa08b3 | ||
|  | 93d678dc30 | ||
|  | 9648189827 | ||
|  | 9bfd274127 | ||
|  | dcf9f65f6b | ||
|  | 784fae5834 | ||
|  | eddd8a1065 | ||
|  | 0941746518 | ||
|  | a1f0f35f60 | ||
|  | 25d96a50cd | ||
|  | 3c7f024fed | ||
|  | 6a1a197701 | ||
|  | 5cff5092a0 | ||
|  | b50f912df2 | ||
|  | b4f00dddb8 | ||
|  | 02c103f39a | ||
|  | 3c23fa20c5 | ||
|  | 576b6faac9 | ||
|  | d86415401d | ||
|  | 460cc1f2cd | ||
|  | 370fef10fd | ||
|  | efadc239d4 | ||
|  | de90e37578 | ||
|  | 6e438d2e4f | ||
|  | a86fa21880 | ||
|  | db74a6e7f2 | ||
|  | 8c773ac97c | ||
|  | 5a2b3cf64d | ||
|  | 8ab910d2b1 | ||
|  | fa70f1cd45 | ||
|  | 75a2e0f901 | ||
|  | 84997bcf86 | ||
|  | 536b3ddd6d | ||
|  | bb86c97b11 | ||
|  | 558f117f24 | ||
|  | bbae71658d | ||
|  | 9ee9653463 | ||
|  | 44570cec8a | ||
|  | 33eb0354fa | ||
|  | 0d3e2dc8bb | ||
|  | ac62c52a33 | ||
|  | 0d30d40d8f | ||
|  | 87e365df7e | ||
|  | 6ee01e808b | ||
|  | 57427f4765 | ||
|  | f6a12760c9 | ||
|  | 560a050af3 | ||
|  | 5ed82930d2 | ||
|  | f8a32022c3 | ||
|  | 137df0ff4c | ||
|  | 23bd8c064c | ||
|  | e3384eaee4 | ||
|  | c7e5716a4a | ||
|  | 7fa0d30100 | ||
|  | 6d33e57d05 | ||
|  | f0bfc647e4 | ||
|  | 757dbbbb1f | ||
|  | 8c555b62d4 | ||
|  | d0138c9702 | ||
|  | 71849cd4ac | ||
|  | dba27bb86c | ||
|  | 6a37bc93c0 | ||
|  | 686ffcb19c | ||
|  | b36a1a9364 | ||
|  | a12a31120d | ||
|  | bf2e53344d | ||
|  | aa4570c895 | ||
|  | 6e2e3f705f | ||
|  | 462625165f | ||
|  | d341a3bab8 | ||
|  | ecf658dd82 | ||
|  | feba13d274 | ||
|  | b2023bed63 | ||
|  | 2c1203f1f5 | ||
|  | 0edebd7df1 | ||
|  | e059aa060a | ||
|  | bd92569cec | ||
|  | 2b521fd5a7 | ||
|  | 1ecfa6c18e | ||
|  | 60eb7d2630 | ||
|  | 65a70c64c5 | ||
|  | d23279227a | ||
|  | 117462a480 | ||
|  | be47b189dc | ||
|  | 7ccc2f02f5 | ||
|  | 456fa58c11 | 
							
								
								
									
										685
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										685
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							| @@ -29,6 +29,9 @@ env: | ||||
|   AUTH0_CLIENT_ID: ${{ secrets.AUTH0_OIDC_ADMIN_CLIENT_ID }} | ||||
|   AUTH0_CLIENT_SECRET: ${{ secrets.AUTH0_OIDC_CLIENT_SECRET }} | ||||
|   AUTH0_ADMIN_PASSWORD: ${{ secrets.AUTH0_OIDC_ADMIN_PASSWORD }} | ||||
|   # Report Portal settings | ||||
|   RP_LAUNCH_PREFIX: "${{ github.workflow }} - ${{ github.job }}" | ||||
|   RP_PROJECT: alfresco-backend | ||||
|  | ||||
| jobs: | ||||
|   prepare: | ||||
| @@ -44,6 +47,10 @@ 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 | ||||
|       - id: changed-files | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/github-list-changes@v8.16.0 | ||||
|         with: | ||||
|           write-list-to-env: true | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/pre-commit@v8.16.0 | ||||
|       - name: "Init" | ||||
|         run: bash ./scripts/ci/init.sh | ||||
| @@ -99,16 +106,12 @@ jobs: | ||||
|         run: | | ||||
|           bash ./scripts/ci/init.sh | ||||
|           bash ./scripts/ci/build.sh | ||||
|       - name: "Remove excluded files" | ||||
|         run: | | ||||
|           mkdir temp-dir-for-sast | ||||
|           bash ./scripts/ci/remove-sast-exclusions.sh ./packaging/war/target/alfresco.war temp-dir-for-sast/reduced.war | ||||
|       - name: "Run SAST Scan" | ||||
|         uses: veracode/Veracode-pipeline-scan-action@v1.0.16 | ||||
|         with: | ||||
|           vid: ${{ secrets.VERACODE_API_ID }} | ||||
|           vkey: ${{ secrets.VERACODE_API_KEY }} | ||||
|           file: "temp-dir-for-sast/reduced.war" | ||||
|           file: "packaging/war/target/alfresco.war" | ||||
|           fail_build: true | ||||
|           project_name: alfresco-community-repo | ||||
|           issue_details: true | ||||
| @@ -126,8 +129,6 @@ jobs: | ||||
|         with: | ||||
|           name: Veracode Pipeline-Scan Results (Human Readable) | ||||
|           path: readable_output.zip | ||||
|       - name: "Remove temporary directory" | ||||
|         run: rm -rfv temp-dir-for-sast | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -179,9 +180,52 @@ jobs: | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/setup-java-build@v8.16.0 | ||||
|       - name: "Init" | ||||
|         run: bash ./scripts/ci/init.sh | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} - ${{ matrix.testModule }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl ${{ matrix.testModule }} -am ${{ matrix.testAttributes }} -DfailIfNoTests=false "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -224,8 +268,52 @@ jobs: | ||||
|       - 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' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} - ${{ matrix.testSuite }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl remote-api -Dtest=${{ matrix.testSuite }} -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco  # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl remote-api -Dtest=${{ matrix.testSuite }} -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|             echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -243,7 +331,7 @@ jobs: | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         version: ['10.5', '10.6'] | ||||
|         version: ['10.2.18', '10.4', '10.5'] | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/get-build-info@v8.16.0 | ||||
| @@ -255,13 +343,57 @@ jobs: | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose-db.yaml --profile mariadb up -d | ||||
|         env: | ||||
|           MARIADB_VERSION: ${{ matrix.version }} | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} - ${{ matrix.version }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.name=alfresco -Ddb.url=jdbc:mariadb://localhost:3307/alfresco?useUnicode=yes\&characterEncoding=UTF-8 -Ddb.username=alfresco -Ddb.password=alfresco -Ddb.driver=org.mariadb.jdbc.Driver # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.name=alfresco -Ddb.url=jdbc:mariadb://localhost:3307/alfresco?useUnicode=yes\&characterEncoding=UTF-8 -Ddb.username=alfresco -Ddb.password=alfresco -Ddb.driver=org.mariadb.jdbc.Driver "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
|   repository_mariadb_10_11_tests: | ||||
|     name: "Repository - MariaDB 10.11 tests" | ||||
|   repository_mariadb_10_6_tests: | ||||
|     name: "Repository - MariaDB 10.6 tests" | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: [prepare] | ||||
|     if: > | ||||
| @@ -278,12 +410,56 @@ jobs: | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/setup-java-build@v8.16.0 | ||||
|       - name: "Init" | ||||
|         run: bash ./scripts/ci/init.sh | ||||
|       - name: "Run MariaDB 10.11 database" | ||||
|       - name: "Run MariaDB 10.6 database" | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose-db.yaml --profile mariadb up -d | ||||
|         env: | ||||
|           MARIADB_VERSION: 10.11 | ||||
|           MARIADB_VERSION: 10.6 | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.name=alfresco -Ddb.url=jdbc:mariadb://localhost:3307/alfresco?useUnicode=yes\&characterEncoding=UTF-8 -Ddb.username=alfresco -Ddb.password=alfresco -Ddb.driver=org.mariadb.jdbc.Driver # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.name=alfresco -Ddb.url=jdbc:mariadb://localhost:3307/alfresco?useUnicode=yes\&characterEncoding=UTF-8 -Ddb.username=alfresco -Ddb.password=alfresco -Ddb.driver=org.mariadb.jdbc.Driver "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -309,13 +485,57 @@ jobs: | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose-db.yaml --profile mysql up -d | ||||
|         env: | ||||
|           MYSQL_VERSION: 8 | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.driver=com.mysql.jdbc.Driver -Ddb.name=alfresco -Ddb.url=jdbc:mysql://localhost:3307/alfresco -Ddb.username=alfresco -Ddb.password=alfresco # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.driver=com.mysql.jdbc.Driver -Ddb.name=alfresco -Ddb.url=jdbc:mysql://localhost:3307/alfresco -Ddb.username=alfresco -Ddb.password=alfresco "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
|   repository_postgresql_14_15_tests: | ||||
|     name: "Repository - PostgreSQL 14.15 tests" | ||||
|   repository_postgresql_13_12_tests: | ||||
|     name: "Repository - PostgreSQL 13.12 tests" | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: [prepare] | ||||
|     if: > | ||||
| @@ -331,25 +551,69 @@ jobs: | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/setup-java-build@v8.16.0 | ||||
|       - name: "Init" | ||||
|         run: bash ./scripts/ci/init.sh | ||||
|       - name: "Run PostgreSQL 14.15 database" | ||||
|       - name: "Run PostgreSQL 13.12 database" | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose-db.yaml --profile postgres up -d | ||||
|         env: | ||||
|           POSTGRES_VERSION: 14.15 | ||||
|           POSTGRES_VERSION: 13.12 | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
|   repository_postgresql_15_10_tests: | ||||
|     name: "Repository - PostgreSQL 15.10 tests" | ||||
|   repository_postgresql_14_9_tests: | ||||
|     name: "Repository - PostgreSQL 14.9 tests" | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: [prepare] | ||||
|     if: > | ||||
|       (((github.ref_name == 'master' || startsWith(github.ref_name, 'release/')) && github.event_name != 'pull_request' && | ||||
|             !contains(github.event.head_commit.message, '[skip db]')) || | ||||
|             contains(github.event.head_commit.message, '[db]')) && | ||||
|             !contains(github.event.head_commit.message, '[skip tests]') && | ||||
|             !contains(github.event.head_commit.message, '[force') | ||||
|       !contains(github.event.head_commit.message, '[skip db]')) || | ||||
|       contains(github.event.head_commit.message, '[db]')) && | ||||
|       !contains(github.event.head_commit.message, '[skip tests]') && | ||||
|       !contains(github.event.head_commit.message, '[force') | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/get-build-info@v8.16.0 | ||||
| @@ -357,17 +621,61 @@ jobs: | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/setup-java-build@v8.16.0 | ||||
|       - name: "Init" | ||||
|         run: bash ./scripts/ci/init.sh | ||||
|       - name: "Run PostgreSQL 15.10 database" | ||||
|       - name: "Run PostgreSQL 14.9 database" | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose-db.yaml --profile postgres up -d | ||||
|         env: | ||||
|           POSTGRES_VERSION: 15.10 | ||||
|           POSTGRES_VERSION: 14.9 | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
|   repository_postgresql_16_6_tests: | ||||
|     name: "Repository - PostgreSQL 16.6 tests" | ||||
|   repository_postgresql_15_4_tests: | ||||
|     name: "Repository - PostgreSQL 15.4 tests" | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: [prepare] | ||||
|     if: > | ||||
| @@ -383,12 +691,56 @@ jobs: | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/setup-java-build@v8.16.0 | ||||
|       - name: "Init" | ||||
|         run: bash ./scripts/ci/init.sh | ||||
|       - name: "Run PostgreSQL 16.6 database" | ||||
|       - name: "Run PostgreSQL 15.4 database" | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose-db.yaml --profile postgres up -d | ||||
|         env: | ||||
|           POSTGRES_VERSION: 16.6 | ||||
|           POSTGRES_VERSION: 15.4 | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl repository -am -Dtest=AllDBTestsTestSuite -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -409,8 +761,52 @@ jobs: | ||||
|         run: bash ./scripts/ci/init.sh | ||||
|       - name: "Run ActiveMQ" | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose.yaml --profile activemq up -d | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl repository -am -Dtest=CamelRoutesTest,CamelComponentsTest -DfailIfNoTests=false # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl repository -am -Dtest=MessagingUnitTestSuite -DfailIfNoTests=false "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -481,8 +877,52 @@ jobs: | ||||
|       - 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' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} - ${{ matrix.testSuite }} ${{ matrix.idp }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl repository -am -Dtest=${{ matrix.testSuite }} -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco ${{ matrix.mvn-options }} # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl repository -am -Dtest=${{ matrix.testSuite }} -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco ${{ matrix.mvn-options }} "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -544,16 +984,59 @@ jobs: | ||||
|       - name: "Build TAS integration tests" | ||||
|         if: ${{ matrix.test-name }} == 'Integration TAS tests' | ||||
|         run: mvn install -pl :alfresco-community-repo-integration-test -am -DskipTests -Pall-tas-tests | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} - ${{ matrix.test-name }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         id: tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         timeout-minutes: ${{ fromJSON(env.GITHUB_ACTIONS_DEPLOY_TIMEOUT) }} | ||||
|         run: mvn -B verify -f packaging/tests/${{ matrix.pom-dir }}/pom.xml -Pall-tas-tests,${{ matrix.test-profile }} -Denvironment=default -DrunBugs=false | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B verify -f packaging/tests/${{ matrix.pom-dir }}/pom.xml -Pall-tas-tests,${{ matrix.test-profile }} -Denvironment=default -DrunBugs=false "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Print output after success" | ||||
|         if: ${{ always() && steps.tests.outcome == 'success' }} | ||||
|         run: ${TAS_SCRIPTS}/output_tests_run.sh "packaging/tests/${{ matrix.pom-dir }}" | ||||
|       - name: "Print output after failure" | ||||
|         if: ${{ always() && steps.tests.outcome == 'failure' }} | ||||
|         run: ${TAS_SCRIPTS}/output_logs_for_failures.sh "packaging/tests/${{ matrix.pom-dir }}" | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -572,10 +1055,54 @@ jobs: | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/setup-java-build@v8.16.0 | ||||
|       - name: "Init" | ||||
|         run: bash ./scripts/ci/init.sh | ||||
|       - name: "Run Postgres 16.6 database" | ||||
|       - name: "Run Postgres 15.4 database" | ||||
|         run: docker compose -f ./scripts/ci/docker-compose/docker-compose.yaml --profile postgres up -d | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Run tests" | ||||
|         run: mvn -B test -pl :alfresco-share-services -am -Dtest=ShareServicesTestSuite -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco # pragma: allowlist secret | ||||
|         id: run-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl :alfresco-share-services -am -Dtest=ShareServicesTestSuite -DfailIfNoTests=false -Ddb.driver=org.postgresql.Driver -Ddb.name=alfresco -Ddb.url=jdbc:postgresql://localhost:5433/alfresco -Ddb.username=alfresco -Ddb.password=alfresco "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -605,9 +1132,23 @@ jobs: | ||||
|         run: | | ||||
|           bash ./scripts/ci/init.sh | ||||
|           bash ./scripts/ci/build.sh | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} 0${{ matrix.part }} - (PostgreSQL) ${{ matrix.test-name }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Verify" | ||||
|         timeout-minutes: ${{ fromJSON(env.GITHUB_ACTIONS_DEPLOY_TIMEOUT) }} | ||||
|         run: mvn --file amps/ags/pom.xml -B verify -Dmaven.javadoc.skip=true -Dmaven.source.skip=true -Pags -Pstart-postgres -PagsAllTestSuitePt${{ matrix.part }} ${{ env.LOG_WARN }} | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn --file amps/ags/pom.xml -B verify -Dmaven.javadoc.skip=true -Dmaven.source.skip=true -Pags -Pstart-postgres -PagsAllTestSuitePt${{ matrix.part }} ${{ env.LOG_WARN }} "${args[@]}" | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -637,9 +1178,23 @@ jobs: | ||||
|         run: | | ||||
|           bash ./scripts/ci/init.sh | ||||
|           bash ./scripts/ci/build.sh | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} 0${{ matrix.part }} - (MySQL) ${{ matrix.test-name }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Verify" | ||||
|         timeout-minutes: ${{ fromJSON(env.GITHUB_ACTIONS_DEPLOY_TIMEOUT) }} | ||||
|         run: mvn --file amps/ags/pom.xml -B verify -Dmaven.javadoc.skip=true -Dmaven.source.skip=true -Pags -Pstart-mysql -PagsAllTestSuitePt${{ matrix.part }} ${{ env.LOG_WARN }} | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn --file amps/ags/pom.xml -B verify -Dmaven.javadoc.skip=true -Dmaven.source.skip=true -Pags -Pstart-mysql -PagsAllTestSuitePt${{ matrix.part }} ${{ env.LOG_WARN }} "${args[@]}" | ||||
|       - name: "Clean Maven cache" | ||||
|         run: bash ./scripts/ci/cleanup_cache.sh | ||||
|  | ||||
| @@ -671,9 +1226,53 @@ jobs: | ||||
|           ${{ env.TAS_SCRIPTS }}/start-compose.sh ./amps/ags/rm-community/rm-community-repo/docker-compose.yml | ||||
|           ${{ env.TAS_SCRIPTS }}/wait-for-alfresco-start.sh "http://localhost:8080/alfresco" | ||||
|           mvn -B install -pl :alfresco-governance-services-automation-community-rest-api -am -Pags -Pall-tas-tests -DskipTests | ||||
|       - name: "Prepare Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-prepare@v8.16.0 | ||||
|         id: rp-prepare | ||||
|         with: | ||||
|           rp-launch-prefix: ${{ env.RP_LAUNCH_PREFIX }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-use-static-launch-name: true | ||||
|         continue-on-error: true | ||||
|       - name: "Add GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         env: | ||||
|           RP_ENABLED: ${{ steps.rp-prepare.outputs.enabled }} | ||||
|           RP_KEY: ${{ steps.rp-prepare.outputs.key }} | ||||
|           RP_URL: ${{ steps.rp-prepare.outputs.url }} | ||||
|         run: bash scripts/ci/add_step_summary.sh | ||||
|         continue-on-error: true | ||||
|       - name: "Test" | ||||
|         id: run-tests | ||||
|         timeout-minutes: ${{ fromJSON(env.GITHUB_ACTIONS_DEPLOY_TIMEOUT) }} | ||||
|         run: mvn -B test -pl :alfresco-governance-services-automation-community-rest-api -Dskip.automationtests=false -Pags -Pall-tas-tests | ||||
|         env: | ||||
|           RP_OPTS: ${{ github.ref_name == 'master' && steps.rp-prepare.outputs.mvn-opts || '' }} | ||||
|         run: | | ||||
|           eval "args=($RP_OPTS)" | ||||
|           mvn -B test -pl :alfresco-governance-services-automation-community-rest-api -Dskip.automationtests=false -Pags -Pall-tas-tests "${args[@]}" | ||||
|         continue-on-error: true | ||||
|       - name: "Update GitHub Step Summary" | ||||
|         if: github.ref_name == 'master' | ||||
|         run: | | ||||
|           echo "#### ⏱ After Tests: $(date -u +'%Y-%m-%d %H:%M:%S%:z')" >> $GITHUB_STEP_SUMMARY | ||||
|         continue-on-error: true | ||||
|       - name: "Summarize Report Portal" | ||||
|         if: github.ref_name == 'master' | ||||
|         uses: Alfresco/alfresco-build-tools/.github/actions/reportportal-summarize@v8.16.0 | ||||
|         id: rp-summarize | ||||
|         with: | ||||
|           tests-outcome: ${{ steps.run-tests.outcome }} | ||||
|           rp-launch-key: ${{ steps.rp-prepare.outputs.key }} | ||||
|           rp-project: ${{ env.RP_PROJECT }} | ||||
|           rp-token: ${{ secrets.REPORT_PORTAL_TOKEN }} | ||||
|         continue-on-error: true | ||||
|       - name: "Exit on failure" | ||||
|         if: steps.run-tests.outcome != 'success' | ||||
|         run: | | ||||
|           echo "::error title=run-tests::Tests failed: re-throwing on error." | ||||
|           exit 1 | ||||
|       - name: "Configure AWS credentials" | ||||
|         if: ${{ always() }} | ||||
|         uses: aws-actions/configure-aws-credentials@v4 | ||||
|   | ||||
							
								
								
									
										32
									
								
								.github/workflows/precommit_formatter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										32
									
								
								.github/workflows/precommit_formatter.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,32 +0,0 @@ | ||||
| name: Pre-Commit formatter | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - precommit/** | ||||
|  | ||||
| jobs: | ||||
|   format-code: | ||||
|     name: "Reformat code" | ||||
|     runs-on: ubuntu-latest | ||||
|     if: contains(github.event.head_commit.message, '[reformat code]') | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - name: Set up Python ${{ inputs.python-version }} | ||||
|         uses: actions/setup-python@42375524e23c412d93fb67b49958b491fce71c38 # v5.4.0 | ||||
|         with: | ||||
|           python-version: "3.9" | ||||
|       - uses: pre-commit/action@2c7b3805fd2a0fd8c1884dcaebf91fc102a13ecd # v3.0.1 | ||||
|         continue-on-error: true | ||||
|         with: | ||||
|           extra_args: --all-files | ||||
|       - name: Update secrets baseline | ||||
|         run: pip install detect-secrets && detect-secrets scan --baseline .secrets.baseline | ||||
|       - uses: Alfresco/alfresco-build-tools/.github/actions/git-commit-changes@v8.16.0 | ||||
|         with: | ||||
|           username: ${{ secrets.BOT_GITHUB_USERNAME }} | ||||
|           add-options: -u | ||||
|           commit-message: "Apply Pre-Commit code formatting" | ||||
|           skip-if-no-changes: true | ||||
|       - name: Push changes | ||||
|         run: git push | ||||
| @@ -127,6 +127,29 @@ | ||||
|     } | ||||
|   ], | ||||
|   "results": { | ||||
|     ".github/workflows/ci.yml": [ | ||||
|       { | ||||
|         "type": "Secret Keyword", | ||||
|         "filename": ".github/workflows/ci.yml", | ||||
|         "hashed_secret": "b86dc2f033a63f2b7b9e7d270ab806d2910d7572", | ||||
|         "is_verified": false, | ||||
|         "line_number": 293 | ||||
|       }, | ||||
|       { | ||||
|         "type": "Secret Keyword", | ||||
|         "filename": ".github/workflows/ci.yml", | ||||
|         "hashed_secret": "1bfb0e20f886150ba59b853bcd49dea893e00966", | ||||
|         "is_verified": false, | ||||
|         "line_number": 368 | ||||
|       }, | ||||
|       { | ||||
|         "type": "Secret Keyword", | ||||
|         "filename": ".github/workflows/ci.yml", | ||||
|         "hashed_secret": "128f14373ccfaff49e3664045d3a11b50cbb7b39", | ||||
|         "is_verified": false, | ||||
|         "line_number": 902 | ||||
|       } | ||||
|     ], | ||||
|     ".github/workflows/master_release.yml": [ | ||||
|       { | ||||
|         "type": "Secret Keyword", | ||||
| @@ -143,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": 58, | ||||
|         "line_number": 57, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -153,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": 85, | ||||
|         "line_number": 83, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -224,7 +247,7 @@ | ||||
|         "filename": "core/src/main/java/org/alfresco/encryption/AlfrescoKeyStore.java", | ||||
|         "hashed_secret": "a718763bca0f328b0e7ce2a98d9e79fc271bf827", | ||||
|         "is_verified": false, | ||||
|         "line_number": 34, | ||||
|         "line_number": 35, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -234,7 +257,7 @@ | ||||
|         "filename": "core/src/main/java/org/alfresco/httpclient/HttpClientFactory.java", | ||||
|         "hashed_secret": "5d3c708390e5f51413e414393d4ad2a6d0e59a45", | ||||
|         "is_verified": false, | ||||
|         "line_number": 128, | ||||
|         "line_number": 126, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -400,7 +423,7 @@ | ||||
|         "filename": "packaging/tests/tas-cmis/src/main/java/org/alfresco/cmis/AuthParameterProviderFactory.java", | ||||
|         "hashed_secret": "a28cecdb5056cf30135809b921e38a84deb6c345", | ||||
|         "is_verified": false, | ||||
|         "line_number": 100, | ||||
|         "line_number": 102, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -408,7 +431,7 @@ | ||||
|         "filename": "packaging/tests/tas-cmis/src/main/java/org/alfresco/cmis/AuthParameterProviderFactory.java", | ||||
|         "hashed_secret": "5e39d8e2991ef9705998de26b33f11be0f3cdcde", | ||||
|         "is_verified": false, | ||||
|         "line_number": 101, | ||||
|         "line_number": 103, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -516,7 +539,7 @@ | ||||
|         "filename": "packaging/tests/tas-restapi/src/main/java/org/alfresco/rest/model/RestSitePersonMembershipRequestModelsCollection.java", | ||||
|         "hashed_secret": "8b30a14989d7b8093ac29462fe29423d836625b4", | ||||
|         "is_verified": false, | ||||
|         "line_number": 33, | ||||
|         "line_number": 39, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -600,7 +623,7 @@ | ||||
|         "filename": "remote-api/src/main/java/org/alfresco/repo/web/scripts/tenant/AbstractTenantAdminWebScript.java", | ||||
|         "hashed_secret": "889d2688743fdce6115117a5ba7dbc5f33e0ce03", | ||||
|         "is_verified": false, | ||||
|         "line_number": 39, | ||||
|         "line_number": 38, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -610,7 +633,7 @@ | ||||
|         "filename": "remote-api/src/main/java/org/alfresco/web/app/servlet/AlfrescoX509ServletFilter.java", | ||||
|         "hashed_secret": "43d52295ed5cb7e2b772f2b8be9695ddde971c49", | ||||
|         "is_verified": false, | ||||
|         "line_number": 60, | ||||
|         "line_number": 62, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -618,7 +641,7 @@ | ||||
|         "filename": "remote-api/src/main/java/org/alfresco/web/app/servlet/AlfrescoX509ServletFilter.java", | ||||
|         "hashed_secret": "1bd5147ff91b8b1220d2f1ffde850ebabbc5ec8c", | ||||
|         "is_verified": false, | ||||
|         "line_number": 61, | ||||
|         "line_number": 63, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -648,7 +671,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/repo/remoteticket/RemoteAlfrescoTicketServiceTest.java", | ||||
|         "hashed_secret": "a926a50b320cea0d6c008a04322627400fe33f55", | ||||
|         "is_verified": false, | ||||
|         "line_number": 73, | ||||
|         "line_number": 74, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -658,7 +681,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/repo/web/scripts/node/NodeWebScripTest.java", | ||||
|         "hashed_secret": "a926a50b320cea0d6c008a04322627400fe33f55", | ||||
|         "is_verified": false, | ||||
|         "line_number": 96, | ||||
|         "line_number": 95, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -668,7 +691,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/repo/web/scripts/servlet/RemoteAuthenticatorFactoryAdminConsoleAccessTest.java", | ||||
|         "hashed_secret": "4ffa743f28fc949c19e65ab045d7906d0609a2c2", | ||||
|         "is_verified": false, | ||||
|         "line_number": 268, | ||||
|         "line_number": 269, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -678,7 +701,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/repo/web/scripts/solr/SOLRAuthenticationFilterTest.java", | ||||
|         "hashed_secret": "76ed0a056aa77060de25754586440cff390791d0", | ||||
|         "is_verified": false, | ||||
|         "line_number": 59, | ||||
|         "line_number": 63, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -688,7 +711,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/repo/webdav/LockMethodTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 108, | ||||
|         "line_number": 109, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -718,7 +741,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/rest/api/tests/RepoService.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 412, | ||||
|         "line_number": 418, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -728,7 +751,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/rest/api/tests/TestCMIS.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 175, | ||||
|         "line_number": 182, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -738,7 +761,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/rest/api/tests/TestPeople.java", | ||||
|         "hashed_secret": "e5e9fa1ba31ecd1ae84f75caaa474f3a663f05f4", | ||||
|         "is_verified": false, | ||||
|         "line_number": 595, | ||||
|         "line_number": 592, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -746,7 +769,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/rest/api/tests/TestPeople.java", | ||||
|         "hashed_secret": "53dad674827218e94c8fe9c1984c8dd9db512a17", | ||||
|         "is_verified": false, | ||||
|         "line_number": 731, | ||||
|         "line_number": 728, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -754,7 +777,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/rest/api/tests/TestPeople.java", | ||||
|         "hashed_secret": "be66cf01c56d963de61462f37a43df2305367216", | ||||
|         "is_verified": false, | ||||
|         "line_number": 1434, | ||||
|         "line_number": 1429, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -762,7 +785,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/rest/api/tests/TestPeople.java", | ||||
|         "hashed_secret": "283d47a9338ed1100b5fe2a5aff2d1f7c799bfd0", | ||||
|         "is_verified": false, | ||||
|         "line_number": 1435, | ||||
|         "line_number": 1430, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -770,7 +793,7 @@ | ||||
|         "filename": "remote-api/src/test/java/org/alfresco/rest/api/tests/TestPeople.java", | ||||
|         "hashed_secret": "425a715491af2bbec1eef2def6fa8d79c3050401", | ||||
|         "is_verified": false, | ||||
|         "line_number": 1457, | ||||
|         "line_number": 1452, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -860,7 +883,7 @@ | ||||
|         "filename": "repository/src/main/java/org/alfresco/heartbeat/jobs/LockingJob.java", | ||||
|         "hashed_secret": "b003370e1497c5003e21f1ec5da89e3d2d819506", | ||||
|         "is_verified": false, | ||||
|         "line_number": 59, | ||||
|         "line_number": 60, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -868,7 +891,7 @@ | ||||
|         "filename": "repository/src/main/java/org/alfresco/heartbeat/jobs/LockingJob.java", | ||||
|         "hashed_secret": "fc99e6a90240c45f46ed33a4d96a3dbecef41c60", | ||||
|         "is_verified": false, | ||||
|         "line_number": 60, | ||||
|         "line_number": 61, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -878,7 +901,7 @@ | ||||
|         "filename": "repository/src/main/java/org/alfresco/heartbeat/jobs/NonLockingJob.java", | ||||
|         "hashed_secret": "b003370e1497c5003e21f1ec5da89e3d2d819506", | ||||
|         "is_verified": false, | ||||
|         "line_number": 54, | ||||
|         "line_number": 52, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -888,7 +911,7 @@ | ||||
|         "filename": "repository/src/main/java/org/alfresco/repo/admin/patch/impl/AdminUserPatch.java", | ||||
|         "hashed_secret": "87a754b00f7ee047d496808125d6259104e9382a", | ||||
|         "is_verified": false, | ||||
|         "line_number": 62, | ||||
|         "line_number": 60, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -908,7 +931,7 @@ | ||||
|         "filename": "repository/src/main/java/org/alfresco/repo/remoteconnector/RemoteConnectorServiceImpl.java", | ||||
|         "hashed_secret": "a172ffc990129fe6f68b50f6037c54a1894ee3fd", | ||||
|         "is_verified": false, | ||||
|         "line_number": 205, | ||||
|         "line_number": 204, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -916,7 +939,7 @@ | ||||
|         "filename": "repository/src/main/java/org/alfresco/repo/remoteconnector/RemoteConnectorServiceImpl.java", | ||||
|         "hashed_secret": "a172ffc990129fe6f68b50f6037c54a1894ee3fd", | ||||
|         "is_verified": false, | ||||
|         "line_number": 205, | ||||
|         "line_number": 204, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -926,7 +949,7 @@ | ||||
|         "filename": "repository/src/main/java/org/alfresco/repo/security/authentication/ResetPasswordServiceImpl.java", | ||||
|         "hashed_secret": "e25df0eeed8d8eb4e198c3464c7bf747bc26eff8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 91, | ||||
|         "line_number": 92, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -936,7 +959,7 @@ | ||||
|         "filename": "repository/src/main/java/org/alfresco/repo/security/authentication/SimpleAcceptOrRejectAllAuthenticationComponentImpl.java", | ||||
|         "hashed_secret": "304de25a3d73b68ad408ca3843356b5cf67f6f14", | ||||
|         "is_verified": false, | ||||
|         "line_number": 89, | ||||
|         "line_number": 93, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -946,7 +969,7 @@ | ||||
|         "filename": "repository/src/main/java/org/alfresco/repo/transfer/TransferServiceImpl2.java", | ||||
|         "hashed_secret": "9ae9f2be7702b726809545808a8a9ba2e5a38410", | ||||
|         "is_verified": false, | ||||
|         "line_number": 129, | ||||
|         "line_number": 130, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1280,7 +1303,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/filesys/FTPServerTest.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 86, | ||||
|         "line_number": 88, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -1288,7 +1311,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/filesys/FTPServerTest.java", | ||||
|         "hashed_secret": "c464af817287343305cbd6493c593885695df531", | ||||
|         "is_verified": false, | ||||
|         "line_number": 90, | ||||
|         "line_number": 92, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -1296,7 +1319,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/filesys/FTPServerTest.java", | ||||
|         "hashed_secret": "8ad8572a0b3fc4cb3afc1baaebc97a2cae58eb8c", | ||||
|         "is_verified": false, | ||||
|         "line_number": 91, | ||||
|         "line_number": 93, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -1304,7 +1327,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/filesys/FTPServerTest.java", | ||||
|         "hashed_secret": "915692b4d7465b0084354173d552ac90145dc315", | ||||
|         "is_verified": false, | ||||
|         "line_number": 92, | ||||
|         "line_number": 94, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1314,7 +1337,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/filesys/repo/ContentDiskDriverTest.java", | ||||
|         "hashed_secret": "8c85434f6f339a24b808810bd95629d0f5856355", | ||||
|         "is_verified": false, | ||||
|         "line_number": 1257, | ||||
|         "line_number": 1280, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1324,7 +1347,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/opencmis/CMISTest.java", | ||||
|         "hashed_secret": "9d4e1e23bd5b727046a9e3b4b7db57bd8d6ee684", | ||||
|         "is_verified": false, | ||||
|         "line_number": 4001, | ||||
|         "line_number": 4134, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1334,7 +1357,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/coci/CheckOutCheckInServiceImplTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 141, | ||||
|         "line_number": 140, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1344,7 +1367,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/i18n/MessageServiceImplTest.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 101, | ||||
|         "line_number": 102, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1354,7 +1377,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/imap/ImapMessageTest.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 116, | ||||
|         "line_number": 118, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1364,7 +1387,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/imap/ImapServiceImplCacheTest.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 66, | ||||
|         "line_number": 68, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1374,7 +1397,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/imap/ImapServiceImplTest.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 111, | ||||
|         "line_number": 116, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1384,7 +1407,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/imap/LoadTester.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 79, | ||||
|         "line_number": 80, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1394,7 +1417,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/imap/RemoteLoadTester.java", | ||||
|         "hashed_secret": "678721c0433c8cf5c9069a0e70784cf1839e866b", | ||||
|         "is_verified": false, | ||||
|         "line_number": 55, | ||||
|         "line_number": 58, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1404,7 +1427,27 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/invitation/site/InviteSenderTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 108, | ||||
|         "line_number": 109, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
|     "repository/src/test/java/org/alfresco/repo/lock/LockBehaviourImplTest.java": [ | ||||
|       { | ||||
|         "type": "Secret Keyword", | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/lock/LockBehaviourImplTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 112, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
|     "repository/src/test/java/org/alfresco/repo/lock/LockServiceImplTest.java": [ | ||||
|       { | ||||
|         "type": "Secret Keyword", | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/lock/LockServiceImplTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 103, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1440,7 +1483,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/model/filefolder/FileFolderServiceImplTest.java", | ||||
|         "hashed_secret": "9e10e28cb9c3e381c13d13fa97dd97148982cdaa", | ||||
|         "is_verified": false, | ||||
|         "line_number": 590, | ||||
|         "line_number": 595, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1450,7 +1493,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/notification/NotificationServiceImplSystemTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 75, | ||||
|         "line_number": 74, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1460,7 +1503,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/oauth1/OAuth1CredentialsStoreServiceTest.java", | ||||
|         "hashed_secret": "c60646de4c4893cf860a12ecb7ba4f5317b1a1d0", | ||||
|         "is_verified": false, | ||||
|         "line_number": 62, | ||||
|         "line_number": 61, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -1468,7 +1511,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/oauth1/OAuth1CredentialsStoreServiceTest.java", | ||||
|         "hashed_secret": "c60646de4c4893cf860a12ecb7ba4f5317b1a1d0", | ||||
|         "is_verified": false, | ||||
|         "line_number": 62, | ||||
|         "line_number": 61, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -1476,7 +1519,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/oauth1/OAuth1CredentialsStoreServiceTest.java", | ||||
|         "hashed_secret": "ad8a621976e9a19cc78af501a84638a04fca9b83", | ||||
|         "is_verified": false, | ||||
|         "line_number": 66, | ||||
|         "line_number": 65, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1486,7 +1529,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/oauth2/OAuth2CredentialsStoreServiceTest.java", | ||||
|         "hashed_secret": "c60646de4c4893cf860a12ecb7ba4f5317b1a1d0", | ||||
|         "is_verified": false, | ||||
|         "line_number": 64, | ||||
|         "line_number": 70, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1506,7 +1549,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/replication/ReplicationServiceIntegrationTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 1317, | ||||
|         "line_number": 1328, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1516,7 +1559,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/security/authentication/AuthenticationServiceImplTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 69, | ||||
|         "line_number": 68, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1526,7 +1569,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/security/authentication/AuthenticationTest.java", | ||||
|         "hashed_secret": "607e729c2f77c4e821e68e26b4c1f5a4398624e9", | ||||
|         "is_verified": false, | ||||
|         "line_number": 2121, | ||||
|         "line_number": 2129, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1536,7 +1579,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/security/authentication/AuthorizationTest.java", | ||||
|         "hashed_secret": "9d4e1e23bd5b727046a9e3b4b7db57bd8d6ee684", | ||||
|         "is_verified": false, | ||||
|         "line_number": 36, | ||||
|         "line_number": 37, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1546,7 +1589,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/security/authentication/CompositePasswordEncoderTest.java", | ||||
|         "hashed_secret": "4360136f24381dcec1d35d79fbf7dac4b54dfe97", | ||||
|         "is_verified": false, | ||||
|         "line_number": 310, | ||||
|         "line_number": 301, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1556,7 +1599,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/security/authentication/identityservice/IdentityServiceFacadeFactoryBeanTest.java", | ||||
|         "hashed_secret": "c4b66dbe168ad1d2b19119494a0da063801bc3bb", | ||||
|         "is_verified": false, | ||||
|         "line_number": 82, | ||||
|         "line_number": 83, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -1564,7 +1607,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/security/authentication/identityservice/IdentityServiceFacadeFactoryBeanTest.java", | ||||
|         "hashed_secret": "c5aad1895e1dcff195992938f1bcc9954d575ac9", | ||||
|         "is_verified": false, | ||||
|         "line_number": 91, | ||||
|         "line_number": 92, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1574,7 +1617,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/security/authentication/identityservice/LazyInstantiatingIdentityServiceFacadeUnitTest.java", | ||||
|         "hashed_secret": "12e59296b0d17c1ceb345a7adca98574c835ba24", | ||||
|         "is_verified": false, | ||||
|         "line_number": 46, | ||||
|         "line_number": 45, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1604,7 +1647,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/transfer/HttpClientTransmitterImplTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 73, | ||||
|         "line_number": 75, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1614,7 +1657,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/transfer/TransferServiceCallbackTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 658, | ||||
|         "line_number": 664, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1624,7 +1667,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/transfer/TransferServiceImplTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 202, | ||||
|         "line_number": 203, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -1632,7 +1675,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/transfer/TransferServiceImplTest.java", | ||||
|         "hashed_secret": "ad782ecdac770fc6eb9a62e44f90873fb97fb26b", | ||||
|         "is_verified": false, | ||||
|         "line_number": 512, | ||||
|         "line_number": 513, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -1640,7 +1683,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/transfer/TransferServiceImplTest.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 3593, | ||||
|         "line_number": 3687, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1650,7 +1693,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/transfer/TransferServiceToBeRefactoredTest.java", | ||||
|         "hashed_secret": "8be3c943b1609fffbfc51aad666d0a04adf83c9d", | ||||
|         "is_verified": false, | ||||
|         "line_number": 2510, | ||||
|         "line_number": 2682, | ||||
|         "is_secret": false | ||||
|       }, | ||||
|       { | ||||
| @@ -1658,7 +1701,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/transfer/TransferServiceToBeRefactoredTest.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 3517, | ||||
|         "line_number": 3772, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1668,7 +1711,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/transfer/manifest/ManifestIntegrationTest.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 114, | ||||
|         "line_number": 115, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1678,7 +1721,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/transfer/manifest/TransferManifestTest.java", | ||||
|         "hashed_secret": "5395ebfd174b0a5617e6f409dfbb3e064e3fdf0a", | ||||
|         "is_verified": false, | ||||
|         "line_number": 126, | ||||
|         "line_number": 127, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1688,7 +1731,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/version/BaseVersionStoreTest.java", | ||||
|         "hashed_secret": "d033e22ae348aeb5660fc2140aec35850c4da997", | ||||
|         "is_verified": false, | ||||
|         "line_number": 144, | ||||
|         "line_number": 149, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1708,7 +1751,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/repo/version/VersionServiceImplTest.java", | ||||
|         "hashed_secret": "dee17075a8c96d9c57c15d56b1f64e5abc1caf0b", | ||||
|         "is_verified": false, | ||||
|         "line_number": 121, | ||||
|         "line_number": 122, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1718,7 +1761,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/util/test/junitrules/AlfrescoTenant.java", | ||||
|         "hashed_secret": "5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8", | ||||
|         "is_verified": false, | ||||
|         "line_number": 73, | ||||
|         "line_number": 67, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1728,7 +1771,7 @@ | ||||
|         "filename": "repository/src/test/java/org/alfresco/util/test/testusers/TestUserComponentImpl.java", | ||||
|         "hashed_secret": "f73e110427648014568f7144031a6d48060eab0a", | ||||
|         "is_verified": false, | ||||
|         "line_number": 63, | ||||
|         "line_number": 55, | ||||
|         "is_secret": false | ||||
|       } | ||||
|     ], | ||||
| @@ -1845,5 +1888,5 @@ | ||||
|       } | ||||
|     ] | ||||
|   }, | ||||
|   "generated_at": "2025-06-09T16:43:14Z" | ||||
|   "generated_at": "2025-05-15T21:47:13Z" | ||||
| } | ||||
|   | ||||
| @@ -10,9 +10,7 @@ pre-commit install | ||||
| When you make a commit then these hooks will run and check the modified files. If it makes changes then you can review them and then `git commit` again to accept the changes. | ||||
|  | ||||
| #### Code Quality | ||||
| This project uses `spotless` that enforces `alfresco-formatter.xml` to ensure code quality.  | ||||
| The code style definition file is taken always form the `master` branch of `alfresco-community-repo`.  | ||||
| All downstream projects use this code style definition file as well.  | ||||
| This project uses `spotless` that enforces `alfresco-formatter.xml` to ensure code quality. | ||||
|  | ||||
| To check code-style violations you can use: | ||||
| ```bash | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-community-repo-amps</artifactId> | ||||
|       <version>25.2.0.52</version> | ||||
|       <version>23.7.0.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-community-parent</artifactId> | ||||
|       <version>25.2.0.52</version> | ||||
|       <version>23.7.0.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <modules> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|    <parent> | ||||
|       <groupId>org.alfresco</groupId> | ||||
|       <artifactId>alfresco-governance-services-automation-community-repo</artifactId> | ||||
|       <version>25.2.0.52</version> | ||||
|       <version>23.7.0.2</version> | ||||
|    </parent> | ||||
|  | ||||
|    <build> | ||||
| @@ -74,6 +74,16 @@ | ||||
|          <artifactId>alfresco-testng</artifactId> | ||||
|          <version>1.1</version> | ||||
|       </dependency> | ||||
|       <dependency> | ||||
|          <groupId>com.epam.reportportal</groupId> | ||||
|          <artifactId>agent-java-testng</artifactId> | ||||
|          <scope>test</scope> | ||||
|       </dependency> | ||||
|       <dependency> | ||||
|          <groupId>com.squareup.okhttp3</groupId> | ||||
|          <artifactId>okhttp</artifactId> | ||||
|          <scope>test</scope> | ||||
|       </dependency> | ||||
|       <dependency> | ||||
|          <groupId>org.awaitility</groupId> | ||||
|          <artifactId>awaitility</artifactId> | ||||
|   | ||||
| @@ -26,11 +26,12 @@ | ||||
|  */ | ||||
| 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 | ||||
|  * | ||||
| @@ -44,18 +45,18 @@ import org.springframework.context.annotation.PropertySource; | ||||
| @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,11 +27,6 @@ | ||||
| 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; | ||||
| @@ -43,6 +38,12 @@ 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 | ||||
| @@ -152,18 +153,15 @@ 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() | ||||
|     { | ||||
| @@ -173,8 +171,7 @@ 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,10 +32,6 @@ 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; | ||||
| @@ -49,14 +45,17 @@ 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 | ||||
| @@ -69,7 +68,7 @@ import org.alfresco.utility.model.UserModel; | ||||
| public class RestAPIFactory | ||||
| { | ||||
|     @Autowired | ||||
|     @Getter(value = PROTECTED) | ||||
|     @Getter (value = PROTECTED) | ||||
|     private DataUserAIS dataUser; | ||||
|  | ||||
|     @Resource(name = "RMRestWrapper") | ||||
|   | ||||
| @@ -44,13 +44,11 @@ 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) | ||||
|     { | ||||
| @@ -61,8 +59,7 @@ 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) | ||||
| @@ -85,8 +82,7 @@ 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,8 +86,7 @@ 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,6 +39,9 @@ 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; | ||||
| @@ -61,10 +64,6 @@ 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 | ||||
|  * | ||||
| @@ -99,11 +98,9 @@ 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) | ||||
|     { | ||||
| @@ -142,7 +139,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); | ||||
|                 } | ||||
| @@ -159,11 +156,9 @@ 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) | ||||
|     { | ||||
| @@ -194,12 +189,11 @@ 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) | ||||
| @@ -210,12 +204,9 @@ 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) | ||||
| @@ -224,8 +215,7 @@ public abstract class BaseAPI | ||||
|         try | ||||
|         { | ||||
|             object = contentService.getCMISSession(username, password).getObjectByPath(path); | ||||
|         } | ||||
|         catch (CmisObjectNotFoundException notFoundError) | ||||
|         } catch (CmisObjectNotFoundException notFoundError) | ||||
|         { | ||||
|             return null; | ||||
|         } | ||||
| @@ -235,12 +225,9 @@ 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) | ||||
| @@ -250,13 +237,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")); | ||||
| @@ -268,26 +255,21 @@ 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 | ||||
| @@ -302,26 +284,21 @@ 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 | ||||
| @@ -336,29 +313,23 @@ 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 | ||||
| @@ -374,25 +345,19 @@ 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); | ||||
| @@ -401,30 +366,22 @@ 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 | ||||
| @@ -442,12 +399,9 @@ 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) | ||||
| @@ -462,29 +416,23 @@ 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 | ||||
| @@ -500,25 +448,19 @@ 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); | ||||
| @@ -527,25 +469,19 @@ 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); | ||||
| @@ -554,30 +490,22 @@ 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); | ||||
| @@ -601,8 +529,7 @@ 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) | ||||
| @@ -627,29 +554,21 @@ 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(); | ||||
| @@ -674,34 +593,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) | ||||
| @@ -767,16 +686,40 @@ 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 | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -784,8 +727,14 @@ 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) | ||||
| @@ -801,16 +750,17 @@ 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) | ||||
| @@ -826,14 +776,10 @@ 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 | ||||
| @@ -850,14 +796,12 @@ 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,8 +28,13 @@ 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) | ||||
|   | ||||
| @@ -1,30 +0,0 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model; | ||||
|  | ||||
| public record CapabilityModel(String name, String title, String description, GroupModel group, int index) | ||||
| {} | ||||
| @@ -1,30 +0,0 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model; | ||||
|  | ||||
| public record GroupModel(String id, String title) | ||||
| {} | ||||
| @@ -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,13 +29,24 @@ 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,6 +29,7 @@ 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; | ||||
| @@ -46,15 +47,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,14 +29,15 @@ 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 | ||||
|  * | ||||
| @@ -50,12 +51,12 @@ import org.alfresco.utility.model.TestModel; | ||||
| @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,6 +27,7 @@ | ||||
| package org.alfresco.rest.rm.community.model.common; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| @@ -44,9 +45,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,8 +34,10 @@ 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,16 +29,17 @@ 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 | ||||
|  * | ||||
| @@ -57,34 +58,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,14 +34,15 @@ 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 | ||||
|  * | ||||
| @@ -58,24 +59,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,15 +36,16 @@ 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,6 +26,8 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model.hold; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
|   | ||||
| @@ -30,7 +30,6 @@ import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -34,4 +34,5 @@ import org.alfresco.rest.core.RestModels; | ||||
|  * @author Damian Ujma | ||||
|  */ | ||||
| public class HoldBulkStatusCollection extends RestModels<HoldBulkStatusEntry, HoldBulkStatusCollection> | ||||
| {} | ||||
| { | ||||
| } | ||||
|   | ||||
| @@ -26,12 +26,13 @@ | ||||
|  */ | ||||
| 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,4 +34,5 @@ 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,4 +34,5 @@ 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,11 +29,6 @@ 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; | ||||
| @@ -42,6 +37,12 @@ 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 | ||||
|  * | ||||
| @@ -60,28 +61,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; | ||||
|  | ||||
|     /************************/ | ||||
| @@ -117,7 +118,7 @@ public class Record extends TestModel implements IRestModel<RestNodeModel> | ||||
|         return assertThat(); | ||||
|     } | ||||
|  | ||||
|     @JsonProperty(value = "entry") | ||||
|     @JsonProperty (value = "entry") | ||||
|     RestNodeModel model; | ||||
|  | ||||
|     @Override | ||||
|   | ||||
| @@ -27,14 +27,15 @@ | ||||
| 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,14 +27,15 @@ | ||||
| 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 | ||||
|  * | ||||
| @@ -49,15 +50,15 @@ import org.alfresco.utility.model.TestModel; | ||||
| @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,6 +64,7 @@ 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; | ||||
| @@ -84,12 +85,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; | ||||
|  | ||||
| @@ -110,160 +111,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,16 +29,17 @@ 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 | ||||
|  * | ||||
| @@ -58,34 +59,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,16 +29,17 @@ 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 | ||||
|  * | ||||
| @@ -57,28 +58,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,11 +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 lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| /** | ||||
|  * 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_ACTION_AS_OF; | ||||
| 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_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_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,17 +51,18 @@ import java.util.List; | ||||
|  | ||||
| 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; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category child properties | ||||
|  * | ||||
| @@ -78,65 +79,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,12 +27,13 @@ | ||||
| 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,22 +35,24 @@ 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 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; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category properties | ||||
|  * | ||||
| @@ -62,37 +64,37 @@ import org.alfresco.utility.model.TestModel; | ||||
| @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,16 +29,17 @@ 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 | ||||
|  * | ||||
| @@ -55,34 +56,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,15 +27,16 @@ | ||||
| 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,8 +33,10 @@ 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; | ||||
| @@ -48,17 +50,18 @@ import java.util.List; | ||||
| import com.fasterxml.jackson.annotation.JsonIgnoreProperties; | ||||
| 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; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Builder; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| /** | ||||
|  * POJO for record folder properties | ||||
|  * | ||||
| @@ -70,62 +73,62 @@ import org.alfresco.utility.model.TestModel; | ||||
| @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,11 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model.retentionschedule; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| import org.alfresco.utility.model.TestModel; | ||||
| import lombok.Data; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * retention schedule | ||||
| @@ -40,7 +39,7 @@ import org.alfresco.utility.model.TestModel; | ||||
| @Data | ||||
| public class RetentionSchedule extends TestModel | ||||
| { | ||||
|     private String id; | ||||
|     private String id ; | ||||
|     private String parentId; | ||||
|     private String authority; | ||||
|     private String instructions; | ||||
| @@ -53,8 +52,7 @@ public class RetentionSchedule extends TestModel | ||||
|         return isRecordLevel; | ||||
|     } | ||||
|  | ||||
|     public void setIsRecordLevel(boolean recordLevel) | ||||
|     { | ||||
|     public void setIsRecordLevel(boolean recordLevel) { | ||||
|         isRecordLevel = recordLevel; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -27,7 +27,6 @@ | ||||
| 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,9 +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 | ||||
| public class RetentionScheduleEntry extends RestModels<RetentionSchedule, RetentionScheduleEntry> | ||||
| { | ||||
|   | ||||
| @@ -29,4 +29,5 @@ package org.alfresco.rest.rm.community.model.retentionschedule; | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| public class RetentionScheduleStepCollection extends RestModels<RetentionScheduleStepEntry, RetentionScheduleStepCollection> | ||||
| {} | ||||
| { | ||||
| } | ||||
|   | ||||
| @@ -28,7 +28,6 @@ package org.alfresco.rest.rm.community.model.retentionschedule; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import lombok.Data; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| @Data | ||||
|   | ||||
| @@ -1,91 +0,0 @@ | ||||
| /*- | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model.role; | ||||
|  | ||||
| import java.util.List; | ||||
| 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.rest.rm.community.model.CapabilityModel; | ||||
| import org.alfresco.utility.model.TestModel; | ||||
|  | ||||
| /** | ||||
|  * POJO for role | ||||
|  */ | ||||
| @Builder | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| public class Role extends TestModel | ||||
| { | ||||
|  | ||||
|     @JsonProperty(required = true) | ||||
|     private String name; | ||||
|  | ||||
|     @JsonProperty(required = true) | ||||
|     private List<CapabilityModel> capabilities; | ||||
|  | ||||
|     @JsonProperty(required = true) | ||||
|     private String displayLabel; | ||||
|  | ||||
|     @JsonProperty(required = true) | ||||
|     private String groupShortName; | ||||
|  | ||||
|     private List<String> assignedUsers; | ||||
|  | ||||
|     private List<String> assignedGroups; | ||||
|  | ||||
|     private String roleGroupName; | ||||
|  | ||||
|     @Override | ||||
|     public boolean equals(Object o) | ||||
|     { | ||||
|         if (this == o) | ||||
|         { | ||||
|             return true; | ||||
|         } | ||||
|         if (o == null || getClass() != o.getClass()) | ||||
|         { | ||||
|             return false; | ||||
|         } | ||||
|         Role role = (Role) o; | ||||
|         return Objects.equals(name, role.name) && Objects.equals(capabilities, role.capabilities) | ||||
|                 && Objects.equals(displayLabel, role.displayLabel) && Objects.equals(groupShortName, role.groupShortName) && Objects.equals(assignedUsers, role.assignedUsers) | ||||
|                 && Objects.equals(assignedGroups, role.assignedGroups) && Objects.equals(roleGroupName, role.roleGroupName); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public int hashCode() | ||||
|     { | ||||
|         return Objects.hash(name, capabilities, displayLabel, groupShortName, assignedUsers, assignedGroups, roleGroupName); | ||||
|     } | ||||
| } | ||||
| @@ -1,32 +0,0 @@ | ||||
| /*- | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model.role; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| public class RoleCollection extends RestModels<RoleEntry, RoleCollection> | ||||
| {} | ||||
| @@ -1,47 +0,0 @@ | ||||
| /*- | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2025 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.model.role; | ||||
|  | ||||
| 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 | ||||
| @Data | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| public class RoleEntry extends RestModels<Role, RoleEntry> | ||||
| { | ||||
|     @JsonProperty | ||||
|     private Role entry; | ||||
| } | ||||
| @@ -31,7 +31,26 @@ 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,17 +31,18 @@ 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,3 +200,4 @@ public class RuleDefinition | ||||
|         return this; | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -27,14 +27,15 @@ | ||||
| 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 | ||||
|  * | ||||
| @@ -47,7 +48,7 @@ import org.alfresco.rest.model.RestSiteModel; | ||||
| @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,5 +34,6 @@ package org.alfresco.rest.rm.community.model.site; | ||||
|  */ | ||||
| public enum RMSiteCompliance | ||||
| { | ||||
|     STANDARD, DOD5015 | ||||
|     STANDARD, | ||||
|     DOD5015 | ||||
| } | ||||
|   | ||||
| @@ -27,8 +27,16 @@ | ||||
| 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 | ||||
| @@ -39,6 +47,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,15 +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.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 | ||||
|  * | ||||
| @@ -55,28 +56,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,16 +30,17 @@ 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 | ||||
|  * | ||||
| @@ -56,28 +57,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,7 +31,6 @@ import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|  * Handle collection of {@link TransferChildEntry} | ||||
|  *  | ||||
|  * @author Silviu Dinuta | ||||
|  * @since 2.6 | ||||
|  */ | ||||
|   | ||||
| @@ -27,15 +27,16 @@ | ||||
|  | ||||
| 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,19 +64,20 @@ 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 | ||||
|  * | ||||
| @@ -91,127 +92,128 @@ import org.alfresco.utility.model.TestModel; | ||||
| 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,7 +31,6 @@ import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| /** | ||||
|  * Handle collection of {@link TransferEntry} | ||||
|  *  | ||||
|  * @author Silviu Dinuta | ||||
|  * @since 2.6 | ||||
|  */ | ||||
|   | ||||
| @@ -27,16 +27,17 @@ | ||||
|  | ||||
| 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,23 +27,24 @@ | ||||
|  | ||||
| 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_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_PDF_INDICATOR; | ||||
| 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 | ||||
|  * | ||||
| @@ -60,24 +61,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,15 +30,16 @@ 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 | ||||
|  * | ||||
| @@ -55,34 +56,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,15 +31,16 @@ 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 | ||||
|  * | ||||
| @@ -56,16 +57,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,17 +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.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 | ||||
|  * | ||||
| @@ -55,34 +56,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,19 +28,20 @@ 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 | ||||
|  * | ||||
| @@ -52,40 +53,40 @@ import org.alfresco.utility.model.TestModel; | ||||
| @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,11 +27,12 @@ | ||||
| package org.alfresco.rest.rm.community.model.unfiledcontainer; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| import org.alfresco.rest.core.RestModels; | ||||
|  | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
|  | ||||
| /** | ||||
|  * POJO for record category child entry | ||||
|  * | ||||
|   | ||||
| @@ -61,15 +61,16 @@ 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 | ||||
|  * | ||||
| @@ -82,112 +83,112 @@ import org.alfresco.utility.model.TestModel; | ||||
| @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,14 +31,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.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 | ||||
|  * | ||||
| @@ -50,15 +51,15 @@ import org.alfresco.utility.model.TestModel; | ||||
| @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,18 +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.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 | ||||
|  * | ||||
| @@ -56,28 +57,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,7 +34,9 @@ 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,7 +35,12 @@ 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_READERS("ExtendedReaders", "In-Place Readers"); | ||||
|     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; | ||||
| @@ -46,4 +51,5 @@ 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 lombok.Getter; | ||||
| import lombok.Setter; | ||||
|  | ||||
| import org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.requests.ModelRequest; | ||||
|  | ||||
| import lombok.Getter; | ||||
| import lombok.Setter; | ||||
|  | ||||
| /** | ||||
|  * Extends {@link ModelRequest} to set {@link RMRestWrapper} | ||||
|  * | ||||
| @@ -43,8 +43,8 @@ import org.alfresco.rest.requests.ModelRequest; | ||||
|  */ | ||||
| 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.RMModelRequest; | ||||
| 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.FilePlanAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.FilesAPI; | ||||
| import org.alfresco.rest.rm.community.requests.gscore.api.HoldsAPI; | ||||
| @@ -43,14 +43,15 @@ 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 | ||||
| @@ -60,10 +61,8 @@ 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) | ||||
|     { | ||||
| @@ -81,7 +80,7 @@ public class GSCoreAPI extends RMModelRequest | ||||
|      */ | ||||
|     public RMSiteAPI usingRMSite() | ||||
|     { | ||||
|         return new RMSiteAPI(getRmRestWrapper()); | ||||
|       return new RMSiteAPI(getRmRestWrapper()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -194,10 +193,7 @@ 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 lombok.SneakyThrows; | ||||
| 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,8 +44,7 @@ import org.alfresco.utility.model.RepoTestModel; | ||||
| public class ActionsExecutionAPI extends RMModelRequest | ||||
| { | ||||
|     /** | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      */ | ||||
|     public ActionsExecutionAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -55,89 +54,81 @@ 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,16 +26,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.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; | ||||
| @@ -43,7 +42,6 @@ import org.alfresco.rest.rm.community.model.hold.Hold; | ||||
| import org.alfresco.rest.rm.community.model.hold.HoldCollection; | ||||
| import org.alfresco.rest.rm.community.model.recordcategory.RecordCategory; | ||||
| import org.alfresco.rest.rm.community.model.recordcategory.RecordCategoryCollection; | ||||
| import org.alfresco.rest.rm.community.model.role.RoleCollection; | ||||
| import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
|  | ||||
| /** | ||||
| @@ -58,8 +56,7 @@ public class FilePlanAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      */ | ||||
|     public FilePlanAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -79,19 +76,16 @@ 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) | ||||
|     { | ||||
| @@ -101,7 +95,8 @@ public class FilePlanAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "/file-plans/{filePlanId}?{parameters}", | ||||
|                 filePlanId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -117,28 +112,26 @@ 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 | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -155,23 +148,19 @@ 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) | ||||
|     { | ||||
| @@ -183,7 +172,8 @@ public class FilePlanAPI extends RMModelRequest | ||||
|                 toJson(recordCategoryModel), | ||||
|                 "file-plans/{filePlanId}/categories?{parameters}", | ||||
|                 filePlanId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -200,21 +190,17 @@ 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) | ||||
|     { | ||||
| @@ -232,22 +218,18 @@ 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) | ||||
|     { | ||||
| @@ -255,11 +237,12 @@ 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 | ||||
|                                                                           )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -273,28 +256,26 @@ 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 | ||||
|                                                                                    )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -304,39 +285,4 @@ public class FilePlanAPI extends RMModelRequest | ||||
|     { | ||||
|         return getHolds(filePlanId, EMPTY); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the roles of a file plan. | ||||
|      * | ||||
|      * @param filePlanId | ||||
|      *            The identifier of a file plan | ||||
|      * @param parameters | ||||
|      *            The URL parameters to add | ||||
|      * @return The {Pagination and RoleModel Entries} 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> | ||||
|      */ | ||||
|     public RoleCollection getFilePlanRoles(String filePlanId, String parameters) | ||||
|     { | ||||
|         mandatoryString("filePlanId", filePlanId); | ||||
|         return getRmRestWrapper().processModels(RoleCollection.class, simpleRequest( | ||||
|                 GET, | ||||
|                 "file-plans/{filePlanId}/roles?{parameters}", | ||||
|                 filePlanId, | ||||
|                 parameters)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * See {@link #getFilePlanRoles(String, String)} | ||||
|      */ | ||||
|     public RoleCollection getFilePlanRoles(String filePlanId) | ||||
|     { | ||||
|         return getFilePlanRoles(filePlanId, EMPTY); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -26,10 +26,9 @@ | ||||
|  */ | ||||
| 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; | ||||
| @@ -46,8 +45,7 @@ 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) | ||||
|     { | ||||
| @@ -57,20 +55,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,16 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| 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 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 org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.hold.BulkBodyCancel; | ||||
| @@ -69,29 +68,27 @@ 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 | ||||
|                                                                         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -107,20 +104,16 @@ 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) | ||||
|     { | ||||
| @@ -128,11 +121,12 @@ 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 | ||||
|                                                                             )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -149,42 +143,38 @@ 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) | ||||
|     { | ||||
| @@ -192,41 +182,38 @@ 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)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -240,28 +227,26 @@ 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 | ||||
|                                                                                    )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -275,20 +260,16 @@ 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) | ||||
|     { | ||||
| @@ -296,11 +277,12 @@ 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 | ||||
|                                                           )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -314,21 +296,17 @@ 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) | ||||
|     { | ||||
| @@ -336,11 +314,12 @@ 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 | ||||
|                                                                                           )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -354,21 +333,17 @@ 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) | ||||
|     { | ||||
| @@ -376,11 +351,12 @@ 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 | ||||
|                                                                                    )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -394,29 +370,27 @@ 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 | ||||
|                                                                                              )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -430,22 +404,17 @@ 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) | ||||
|     { | ||||
| @@ -454,12 +423,13 @@ 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,17 +26,16 @@ | ||||
|  */ | ||||
| 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; | ||||
| @@ -52,8 +51,7 @@ public class RMSiteAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Constructor | ||||
|      * | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      */ | ||||
|     public RMSiteAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -64,35 +62,34 @@ 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) | ||||
|     { | ||||
| @@ -101,43 +98,42 @@ 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) | ||||
|     { | ||||
| @@ -146,21 +142,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,16 +26,17 @@ | ||||
|  */ | ||||
| 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; | ||||
| @@ -58,8 +59,7 @@ 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,7 +68,6 @@ public class RMUserAPI extends RMModelRequest | ||||
|  | ||||
|     /** | ||||
|      * Helper method to obtain {@link AlfrescoHttpClient} | ||||
|      *  | ||||
|      * @return Initialized {@link AlfrescoHttpClient} instance | ||||
|      */ | ||||
|     private AlfrescoHttpClient getAlfrescoHttpClient() | ||||
| @@ -86,12 +85,9 @@ 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) | ||||
|     { | ||||
| @@ -122,13 +118,9 @@ 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) | ||||
|     { | ||||
| @@ -169,10 +161,9 @@ 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) | ||||
|     { | ||||
| @@ -208,15 +199,13 @@ 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) | ||||
| @@ -225,29 +214,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,16 @@ | ||||
|  */ | ||||
| package org.alfresco.rest.rm.community.requests.gscore.api; | ||||
|  | ||||
| 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 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 org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.recordcategory.RecordCategory; | ||||
| @@ -55,8 +54,7 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      */ | ||||
|     public RecordCategoryAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -66,17 +64,15 @@ 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) | ||||
|     { | ||||
| @@ -85,7 +81,8 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|                 DELETE, | ||||
|                 "record-categories/{recordCategoryId}", | ||||
|                 recordCategoryId)); | ||||
|                 recordCategoryId | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -101,19 +98,16 @@ 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) | ||||
|     { | ||||
| @@ -123,7 +117,8 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "record-categories/{recordCategoryId}?{parameters}", | ||||
|                 recordCategoryId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -140,24 +135,19 @@ 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) | ||||
|     { | ||||
| @@ -169,7 +159,8 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|                 toJson(recordCategoryModel), | ||||
|                 "record-categories/{recordCategoryId}?{parameters}", | ||||
|                 recordCategoryId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -185,28 +176,26 @@ 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 | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -223,23 +212,19 @@ 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) | ||||
|     { | ||||
| @@ -251,6 +236,7 @@ public class RecordCategoryAPI extends RMModelRequest | ||||
|                 toJson(recordCategoryChildModel), | ||||
|                 "record-categories/{recordCategoryId}/children?{parameters}", | ||||
|                 recordCategoryId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -26,19 +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.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.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.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.testng.Assert.fail; | ||||
|  | ||||
| import java.io.File; | ||||
| import java.io.IOException; | ||||
| @@ -67,8 +66,7 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      */ | ||||
|     public RecordFolderAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -78,17 +76,15 @@ 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) | ||||
|     { | ||||
| @@ -97,7 +93,8 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|                 DELETE, | ||||
|                 "record-folders/{recordFolderId}", | ||||
|                 recordFolderId)); | ||||
|                 recordFolderId | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -113,19 +110,16 @@ 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) | ||||
|     { | ||||
| @@ -135,7 +129,8 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "record-folders/{recordFolderId}?{parameters}", | ||||
|                 recordFolderId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -152,24 +147,19 @@ 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) | ||||
|     { | ||||
| @@ -181,7 +171,8 @@ public class RecordFolderAPI extends RMModelRequest | ||||
|                 toJson(recordFolderModel), | ||||
|                 "record-folders/{recordFolderId}?{parameters}", | ||||
|                 recordFolderId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -197,28 +188,26 @@ 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 | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -235,15 +224,11 @@ 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 | ||||
|     { | ||||
| @@ -256,7 +241,10 @@ 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 | ||||
| @@ -283,22 +271,18 @@ 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) | ||||
|     { | ||||
| @@ -310,6 +294,7 @@ 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,8 +54,7 @@ import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
| public class RecordsAPI extends RMModelRequest | ||||
| { | ||||
|     /** | ||||
|      * @param rmRestWrapper | ||||
|      *            RM REST Wrapper | ||||
|      * @param rmRestWrapper RM REST Wrapper | ||||
|      */ | ||||
|     public RecordsAPI(RMRestWrapper rmRestWrapper) | ||||
|     { | ||||
| @@ -65,46 +64,41 @@ 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) | ||||
| @@ -118,21 +112,18 @@ 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) | ||||
| @@ -141,11 +132,12 @@ 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 | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -161,45 +153,41 @@ 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) | ||||
|     { | ||||
| @@ -208,7 +196,8 @@ public class RecordsAPI extends RMModelRequest | ||||
|         getRmRestWrapper().processEmptyModel(simpleRequest( | ||||
|                 DELETE, | ||||
|                 "records/{recordId}", | ||||
|                 recordId)); | ||||
|                 recordId | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -224,19 +213,16 @@ 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) | ||||
|     { | ||||
| @@ -246,7 +232,8 @@ public class RecordsAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "records/{recordId}?{parameters}", | ||||
|                 recordId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -263,23 +250,19 @@ 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) | ||||
|     { | ||||
| @@ -291,6 +274,7 @@ public class RecordsAPI extends RMModelRequest | ||||
|                 toJson(recordModel), | ||||
|                 "records/{recordId}?{parameters}", | ||||
|                 recordId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -26,16 +26,6 @@ | ||||
|  */ | ||||
| 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.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.retentionschedule.RetentionSchedule; | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionScheduleActionDefinition; | ||||
| @@ -43,6 +33,15 @@ import org.alfresco.rest.rm.community.model.retentionschedule.RetentionScheduleC | ||||
| import org.alfresco.rest.rm.community.model.retentionschedule.RetentionScheduleStepCollection; | ||||
| import org.alfresco.rest.rm.community.requests.RMModelRequest; | ||||
|  | ||||
| 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; | ||||
|  | ||||
| public class RetentionScheduleAPI extends RMModelRequest | ||||
| { | ||||
|  | ||||
| @@ -54,25 +53,22 @@ 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) | ||||
|     { | ||||
| @@ -80,11 +76,12 @@ 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 | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -98,28 +95,26 @@ 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 | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -133,22 +128,18 @@ 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) | ||||
|     { | ||||
| @@ -156,11 +147,12 @@ 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 | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -174,28 +166,26 @@ 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,10 @@ | ||||
|  | ||||
| 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.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 org.alfresco.rest.core.RMRestWrapper; | ||||
| import org.alfresco.rest.rm.community.model.transfer.Transfer; | ||||
| @@ -47,8 +46,7 @@ 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) | ||||
|     { | ||||
| @@ -68,19 +66,16 @@ 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) | ||||
|     { | ||||
| @@ -90,9 +85,9 @@ public class TransferAPI extends RMModelRequest | ||||
|                 GET, | ||||
|                 "/transfers/{transferId}?{parameters}", | ||||
|                 transferId, | ||||
|                 parameters)); | ||||
|                 parameters | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * see {@link #getTransfersChildren(String, String)} | ||||
|      */ | ||||
| @@ -106,27 +101,25 @@ 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 | ||||
|         )); | ||||
|     } | ||||
| } | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user