From 50f38f574fe41097ff9f52265dd4d31a3038c8b1 Mon Sep 17 00:00:00 2001 From: contentstack-admin <52040860+contentstack-admin@users.noreply.github.com> Date: Mon, 30 May 2022 17:41:43 +0530 Subject: [PATCH 001/104] Snyk integration --- .github/workflows/codeql-analysis.yml | 72 +++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 .github/workflows/codeql-analysis.yml diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml new file mode 100644 index 00000000..9a8aaa96 --- /dev/null +++ b/.github/workflows/codeql-analysis.yml @@ -0,0 +1,72 @@ +# For most projects, this workflow file will not need changing; you simply need +# to commit it to your repository. +# +# You may wish to alter this file to override the set of languages analyzed, +# or to provide custom queries or build logic. +# +# ******** NOTE ******** +# We have attempted to detect the languages in your repository. Please check +# the `language` matrix defined below to confirm you have the correct set of +# supported CodeQL languages. +# +name: "CodeQL" + +on: + push: + branches: '*' + pull_request: + # The branches below must be a subset of the branches above + branches: '*' + schedule: + - cron: '41 14 * * 6' + +jobs: + analyze: + name: Analyze + runs-on: ubuntu-latest + permissions: + actions: read + contents: read + security-events: write + + strategy: + fail-fast: false + matrix: + language: [ 'java' ] + # CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python', 'ruby' ] + # Learn more about CodeQL language support at https://aka.ms/codeql-docs/language-support + + steps: + - name: Checkout repository + uses: actions/checkout@v3 + + # Initializes the CodeQL tools for scanning. + - name: Initialize CodeQL + uses: github/codeql-action/init@v2 + with: + languages: ${{ matrix.language }} + # If you wish to specify custom queries, you can do so here or in a config file. + # By default, queries listed here will override any specified in a config file. + # Prefix the list here with "+" to use these queries and those in the config file. + + # Details on CodeQL's query packs refer to : https://docs.github.com/en/code-security/code-scanning/automatically-scanning-your-code-for-vulnerabilities-and-errors/configuring-code-scanning#using-queries-in-ql-packs + # queries: security-extended,security-and-quality + + + # Autobuild attempts to build any compiled languages (C/C++, C#, or Java). + # If this step fails, then you should remove it and run the build manually (see below) + - name: Autobuild + uses: github/codeql-action/autobuild@v2 + + # ℹ️ Command-line programs to run using the OS shell. + # 📚 See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun + + # If the Autobuild fails above, remove it and uncomment the following three lines. + # modify them (or add more) to build your code if your project, please refer to the EXAMPLE below for guidance. + + # - run: | + # echo "Run, Build Application using script" + # ./location_of_script_within_repo/buildscript.sh + + - name: Perform CodeQL Analysis + uses: github/codeql-action/analyze@v2 From ed7f57a48a237413f2bee711ab0b0aaa04366029 Mon Sep 17 00:00:00 2001 From: contentstack-admin <52040860+contentstack-admin@users.noreply.github.com> Date: Mon, 30 May 2022 18:20:17 +0530 Subject: [PATCH 002/104] adding snyk secrets --- .github/workflows/secrets-scan.yml | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 .github/workflows/secrets-scan.yml diff --git a/.github/workflows/secrets-scan.yml b/.github/workflows/secrets-scan.yml new file mode 100644 index 00000000..71d65037 --- /dev/null +++ b/.github/workflows/secrets-scan.yml @@ -0,0 +1,14 @@ +name: Secrets Scan +on: + push: + branches: + - '*' + pull_request: + types: [opened, synchronize, reopened] +jobs: + security: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - name: Gittyleaks + uses: gupy-io/gittyleaks-action@v0.1 From b8085e6b94b8b522cdb9212b2c8d95b1ae2fba60 Mon Sep 17 00:00:00 2001 From: contentstack-admin <52040860+contentstack-admin@users.noreply.github.com> Date: Mon, 30 May 2022 18:21:33 +0530 Subject: [PATCH 003/104] adding sca-monitor --- .github/workflows/sca-monitor.yml | 13 +++++++++++++ 1 file changed, 13 insertions(+) create mode 100644 .github/workflows/sca-monitor.yml diff --git a/.github/workflows/sca-monitor.yml b/.github/workflows/sca-monitor.yml new file mode 100644 index 00000000..294eab3e --- /dev/null +++ b/.github/workflows/sca-monitor.yml @@ -0,0 +1,13 @@ +name: Source Composition Analysis Monitor +on: push +jobs: + security: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@master + - name: Run Snyk to check for vulnerabilities + uses: snyk/actions/node@master + env: + SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} + with: + command: monitor From 5c5082bbed9ac08b19499c0d83cdf9f5557470b5 Mon Sep 17 00:00:00 2001 From: contentstack-admin <52040860+contentstack-admin@users.noreply.github.com> Date: Mon, 30 May 2022 18:22:49 +0530 Subject: [PATCH 004/104] create sca-scan --- .github/workflows/sca-scan.yml | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) create mode 100644 .github/workflows/sca-scan.yml diff --git a/.github/workflows/sca-scan.yml b/.github/workflows/sca-scan.yml new file mode 100644 index 00000000..525e2860 --- /dev/null +++ b/.github/workflows/sca-scan.yml @@ -0,0 +1,16 @@ +name: Source Composition Analysis Scan +on: + push: + branches: + - master + pull_request: + types: [opened, synchronize, reopened] +jobs: + security: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@master + - name: Run Snyk to check for vulnerabilities + uses: snyk/actions/node@master + env: + SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} From a31e6d4ef35d0b7fefca34fe29484dad1fdc6c02 Mon Sep 17 00:00:00 2001 From: contentstack-admin <52040860+contentstack-admin@users.noreply.github.com> Date: Mon, 30 May 2022 18:23:59 +0530 Subject: [PATCH 005/104] create sast-scan --- .github/workflows/sast-scan.yml | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 .github/workflows/sast-scan.yml diff --git a/.github/workflows/sast-scan.yml b/.github/workflows/sast-scan.yml new file mode 100644 index 00000000..21f14859 --- /dev/null +++ b/.github/workflows/sast-scan.yml @@ -0,0 +1,14 @@ +name: SAST Scan +on: + push: + branches: + - '*' + pull_request: + types: [opened, synchronize, reopened] +jobs: + security: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - name: Horusec Scan + run: docker run -v /var/run/docker.sock:/var/run/docker.sock -v $(pwd):/src horuszup/horusec-cli:latest horusec start -p /src -P $(pwd) From 024daf0a20ec0674c03db1508beaffd6d880d15d Mon Sep 17 00:00:00 2001 From: contentstack-admin <52040860+contentstack-admin@users.noreply.github.com> Date: Wed, 15 Jun 2022 01:12:20 +0530 Subject: [PATCH 006/104] Update codeql-analysis.yml --- .github/workflows/codeql-analysis.yml | 2 -- 1 file changed, 2 deletions(-) diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index 9a8aaa96..f33722d9 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -17,8 +17,6 @@ on: pull_request: # The branches below must be a subset of the branches above branches: '*' - schedule: - - cron: '41 14 * * 6' jobs: analyze: From a27707164e8c83b2bcd4fda68765574207602145 Mon Sep 17 00:00:00 2001 From: snyk-bot Date: Thu, 16 Jun 2022 12:15:24 +0000 Subject: [PATCH 007/104] fix: pom.xml to reduce vulnerabilities The following vulnerabilities are fixed with an upgrade: - https://snyk.io/vuln/SNYK-JAVA-ORGJETBRAINSKOTLIN-2628385 --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index 305e0905..2535a446 100644 --- a/pom.xml +++ b/pom.xml @@ -24,7 +24,7 @@ 3.1.5 2.9.0 2.9.0 - 4.9.3 + 4.10.0 0.8.5 1.18.24 5.8.2 From f45e7d7e8f379956c1a2e819c4f050967863e7d9 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Mon, 1 Aug 2022 17:12:54 +0530 Subject: [PATCH 008/104] Update codeql-analysis.yml --- .github/workflows/codeql-analysis.yml | 2 -- 1 file changed, 2 deletions(-) diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index f33722d9..4218585c 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -12,8 +12,6 @@ name: "CodeQL" on: - push: - branches: '*' pull_request: # The branches below must be a subset of the branches above branches: '*' From 2019d2fbb13a44662bb49e09c0f933e8a4a06c42 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Mon, 1 Aug 2022 17:13:08 +0530 Subject: [PATCH 009/104] Delete sca-monitor.yml --- .github/workflows/sca-monitor.yml | 13 ------------- 1 file changed, 13 deletions(-) delete mode 100644 .github/workflows/sca-monitor.yml diff --git a/.github/workflows/sca-monitor.yml b/.github/workflows/sca-monitor.yml deleted file mode 100644 index 294eab3e..00000000 --- a/.github/workflows/sca-monitor.yml +++ /dev/null @@ -1,13 +0,0 @@ -name: Source Composition Analysis Monitor -on: push -jobs: - security: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@master - - name: Run Snyk to check for vulnerabilities - uses: snyk/actions/node@master - env: - SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} - with: - command: monitor From f66ddd920e517562a567d3e4e612d545866c5166 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Mon, 1 Aug 2022 17:13:25 +0530 Subject: [PATCH 010/104] Update sast-scan.yml --- .github/workflows/sast-scan.yml | 3 --- 1 file changed, 3 deletions(-) diff --git a/.github/workflows/sast-scan.yml b/.github/workflows/sast-scan.yml index 21f14859..ed714ef8 100644 --- a/.github/workflows/sast-scan.yml +++ b/.github/workflows/sast-scan.yml @@ -1,8 +1,5 @@ name: SAST Scan on: - push: - branches: - - '*' pull_request: types: [opened, synchronize, reopened] jobs: From 9c52cfff53d5d4f0c1860e760b70ca1a5028ccb7 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Mon, 1 Aug 2022 17:13:49 +0530 Subject: [PATCH 011/104] Update sca-scan.yml --- .github/workflows/sca-scan.yml | 3 --- 1 file changed, 3 deletions(-) diff --git a/.github/workflows/sca-scan.yml b/.github/workflows/sca-scan.yml index 525e2860..3963efde 100644 --- a/.github/workflows/sca-scan.yml +++ b/.github/workflows/sca-scan.yml @@ -1,8 +1,5 @@ name: Source Composition Analysis Scan on: - push: - branches: - - master pull_request: types: [opened, synchronize, reopened] jobs: From bbce574ff59980be1926398cf52759eb163e6846 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Mon, 1 Aug 2022 17:14:04 +0530 Subject: [PATCH 012/104] Update secrets-scan.yml --- .github/workflows/secrets-scan.yml | 3 --- 1 file changed, 3 deletions(-) diff --git a/.github/workflows/secrets-scan.yml b/.github/workflows/secrets-scan.yml index 71d65037..0fc4fbbe 100644 --- a/.github/workflows/secrets-scan.yml +++ b/.github/workflows/secrets-scan.yml @@ -1,8 +1,5 @@ name: Secrets Scan on: - push: - branches: - - '*' pull_request: types: [opened, synchronize, reopened] jobs: From 74f796cd394cb6fa61d6ff239cbf8af5f1e348d3 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Thu, 15 Sep 2022 10:34:26 +0530 Subject: [PATCH 013/104] codeql-analysis.yml From f2c336819e4ffa05295e5a68a97e9576518e4bc2 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Thu, 15 Sep 2022 10:34:26 +0530 Subject: [PATCH 014/104] sast-scan.yml --- .github/workflows/sast-scan.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/sast-scan.yml b/.github/workflows/sast-scan.yml index ed714ef8..f9316303 100644 --- a/.github/workflows/sast-scan.yml +++ b/.github/workflows/sast-scan.yml @@ -8,4 +8,4 @@ jobs: steps: - uses: actions/checkout@v2 - name: Horusec Scan - run: docker run -v /var/run/docker.sock:/var/run/docker.sock -v $(pwd):/src horuszup/horusec-cli:latest horusec start -p /src -P $(pwd) + run: docker run -v /var/run/docker.sock:/var/run/docker.sock -v $(pwd):/src horuszup/horusec-cli:latest horusec start -p /src -P $(pwd) \ No newline at end of file From abbf664f8bb146c3b1dc560d41aa4e8a73fda54d Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Thu, 15 Sep 2022 10:34:27 +0530 Subject: [PATCH 015/104] sca-scan.yml --- .github/workflows/sca-scan.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/sca-scan.yml b/.github/workflows/sca-scan.yml index 3963efde..7275b417 100644 --- a/.github/workflows/sca-scan.yml +++ b/.github/workflows/sca-scan.yml @@ -10,4 +10,4 @@ jobs: - name: Run Snyk to check for vulnerabilities uses: snyk/actions/node@master env: - SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} + SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} \ No newline at end of file From a407d9197aa86b9fc1dff97382d052f05b47f4cd Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Thu, 15 Sep 2022 10:34:28 +0530 Subject: [PATCH 016/104] secrets-scan.yml --- .github/workflows/secrets-scan.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/secrets-scan.yml b/.github/workflows/secrets-scan.yml index 0fc4fbbe..1e8f1761 100644 --- a/.github/workflows/secrets-scan.yml +++ b/.github/workflows/secrets-scan.yml @@ -8,4 +8,4 @@ jobs: steps: - uses: actions/checkout@v2 - name: Gittyleaks - uses: gupy-io/gittyleaks-action@v0.1 + uses: gupy-io/gittyleaks-action@v0.1 \ No newline at end of file From a8cb70f8c43b53a4c0751e56f5fac505e7b61490 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Wed, 21 Sep 2022 09:45:29 +0530 Subject: [PATCH 017/104] codeql-analysis.yml From 76b30bb4d85b596e50320702f5c8c77a1e56a51b Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Wed, 21 Sep 2022 09:45:30 +0530 Subject: [PATCH 018/104] sast-scan.yml From bcec2c50c312c64ec97487200bc3819e2aab2733 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Wed, 21 Sep 2022 09:45:31 +0530 Subject: [PATCH 019/104] sca-scan.yml --- .github/workflows/sca-scan.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/sca-scan.yml b/.github/workflows/sca-scan.yml index 7275b417..8485c342 100644 --- a/.github/workflows/sca-scan.yml +++ b/.github/workflows/sca-scan.yml @@ -8,6 +8,6 @@ jobs: steps: - uses: actions/checkout@master - name: Run Snyk to check for vulnerabilities - uses: snyk/actions/node@master + uses: snyk/actions/maven@master env: - SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} \ No newline at end of file + SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} From b9ac217c0f6dbe2ed5c91291a4c22298e01ea547 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Wed, 21 Sep 2022 09:45:32 +0530 Subject: [PATCH 020/104] secrets-scan.yml From 84ee49d22f0a6ef7c8a9a7cb1eb74becbe0ade24 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Mon, 3 Oct 2022 17:16:28 +0530 Subject: [PATCH 021/104] jira.yml --- .github/workflows/jira.yml | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 .github/workflows/jira.yml diff --git a/.github/workflows/jira.yml b/.github/workflows/jira.yml new file mode 100644 index 00000000..2e12145a --- /dev/null +++ b/.github/workflows/jira.yml @@ -0,0 +1,29 @@ +name: Create JIRA ISSUE +on: + pull_request: + types: [opened] +jobs: + security: + if: ${{ github.actor == 'dependabot[bot]' || github.actor == 'snyk-bot' || contains(github.event.pull_request.head.ref, 'snyk-fix-') || contains(github.event.pull_request.head.ref, 'snyk-upgrade-')}} + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - name: Login into JIRA + uses: atlassian/gajira-login@master + env: + JIRA_BASE_URL: ${{ secrets.JIRA_BASE_URL }} + JIRA_USER_EMAIL: ${{ secrets.JIRA_USER_EMAIL }} + JIRA_API_TOKEN: ${{ secrets.JIRA_API_TOKEN }} + - name: Create a JIRA Issue + id: create + uses: atlassian/gajira-create@master + with: + project: ${{ secrets.JIRA_PROJECT }} + issuetype: ${{ secrets.JIRA_ISSUE_TYPE }} + summary: | + ${{ github.event.pull_request.title }} + description: | + PR: ${{ github.event.pull_request.html_url }} + + ${{ github.event.pull_request.body }} + fields: "${{ secrets.JIRA_FIELDS }}" From 728247fcf6b9daa116d6dd9e47af7f0af221ea5c Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Tue, 4 Oct 2022 09:44:29 +0530 Subject: [PATCH 022/104] jira.yml --- .github/workflows/jira.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/jira.yml b/.github/workflows/jira.yml index 2e12145a..5ddf87a6 100644 --- a/.github/workflows/jira.yml +++ b/.github/workflows/jira.yml @@ -25,5 +25,4 @@ jobs: description: | PR: ${{ github.event.pull_request.html_url }} - ${{ github.event.pull_request.body }} fields: "${{ secrets.JIRA_FIELDS }}" From 3087b34611bd74f222a02a349db56fd2482a3835 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Mon, 31 Oct 2022 15:41:44 +0530 Subject: [PATCH 023/104] Live Preview --- .../contentstack/sdk/CSHttpConnection.java | 71 ++++++----------- .../com/contentstack/sdk/Contentstack.java | 79 ++++++++++--------- src/main/java/com/contentstack/sdk/Query.java | 1 + src/main/java/com/contentstack/sdk/Stack.java | 25 +++--- .../java/com/contentstack/sdk/SuperEntry.java | 57 +++++++++++++ .../com/contentstack/sdk/TestLivePreview.java | 19 +++++ src/test/resources/assets/live_preview.json | 60 ++++++++++++++ 7 files changed, 213 insertions(+), 99 deletions(-) create mode 100644 src/main/java/com/contentstack/sdk/SuperEntry.java diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java index b5fd59f0..2586832a 100644 --- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java +++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java @@ -190,9 +190,8 @@ private void getService(String requestUrl) throws IOException { if (response.isSuccessful()) { assert response.body() != null; responseJSON = new JSONObject(response.body().string()); - // LivePreviewAgent to validate If LivePreview Response is there for mapping if (this.config.livePreviewEntry != null && !this.config.livePreviewEntry.isEmpty()) { - livePreviewAgent(); + handleJSONArray(); } connectionRequest.onRequestFinished(CSHttpConnection.this); } else { @@ -202,54 +201,32 @@ private void getService(String requestUrl) throws IOException { } - private void livePreviewAgent() { - if (!responseJSON.isEmpty() && responseJSON.has("entries")) { - mapLPreviewToQuery(responseJSON.optJSONArray("entries")); - } - if (responseJSON.has("entry")) { - mapLPreviewToEntry(responseJSON.optJSONObject("entry"), 0); - } - } - private void mapLPreviewToEntry(JSONObject entry, int idx) { - if (entry.opt("uid").equals(this.config.livePreviewEntry.opt("uid"))) { - filterToUpdate(entry, idx); + void handleJSONArray() { + JSONArray entries = new JSONArray(); + if (responseJSON.has("entries") && !responseJSON.optJSONArray("entries").isEmpty()) { + entries = responseJSON.optJSONArray("entries"); } - } - - // How to merge the JSONObject key value to another key? - // JSONObject a = new JSONObject("{\"data\": [ {\"empId\": 1,\"deptId\": - // 2},{\"empId\": 3,\"deptId\": 4}]}"); - // JSONObject b = new JSONObject("{\"data\": [ {\"empId\": 7,\"deptId\": - // 8},{\"empId\": 9,\"deptId\": 10}]}"); - - // JSONArray jArr_A= a.getJSONArray("data"); - - // JSONArray jArr= new JSONArray(); - // for(int i=0;i { + JSONObject objJSON = (JSONObject) finalEntries.get(idx); + handleJSONObject(finalEntries, objJSON, idx); + }); + } + + void handleJSONObject(JSONArray arrayEntry, JSONObject jsonObj, int idx) { + if (!jsonObj.isEmpty()) { + if (jsonObj.has("uid") && jsonObj.opt("uid").equals(this.config.livePreviewEntry.opt("uid"))) { + arrayEntry.put(idx, this.config.livePreviewEntry); + } else { + Iterator unmachedKeys = jsonObj.keys(); + unmachedKeys.forEachRemaining(key -> { + JSONObject jsonBYKey = (JSONObject) jsonObj.opt(key); + handleJSONObject(arrayEntry, jsonBYKey, idx); + }); + } } - } - - private void mapLPreviewToQuery(JSONArray entries) { - IntStream.range(0, entries.length()).forEach(idx -> mapLPreviewToEntry((JSONObject) entries.get(idx), idx)); + responseJSON = new JSONObject().put("entries", arrayEntry); } void setError(String errResp) { diff --git a/src/main/java/com/contentstack/sdk/Contentstack.java b/src/main/java/com/contentstack/sdk/Contentstack.java index 443cec45..3693fe68 100644 --- a/src/main/java/com/contentstack/sdk/Contentstack.java +++ b/src/main/java/com/contentstack/sdk/Contentstack.java @@ -3,15 +3,12 @@ import java.util.Objects; /** - * The Content Delivery API is used to retrieve content from your Contentstack - * account and deliver it to your web or mobile properties. If you are looking - * for APIs to manage content, you should use the Content Management API + * The Content Delivery API is used to retrieve content from your Contentstack account and deliver it to your web or + * mobile properties. If you are looking for APIs to manage content, you should use the Content Management API *

- * Our APIs serve content via a powerful and robust content delivery network - * (CDN). Multiple datacenters around the world store a cached copy of your - * content. When a page request is made, the content is delivered to the user - * from the nearest server. This greatly accelerates content delivery and - * reduces latency. + * Our APIs serve content via a powerful and robust content delivery network (CDN). Multiple datacenters around the + * world store a cached copy of your content. When a page request is made, the content is delivered to the user from the + * nearest server. This greatly accelerates content delivery and reduces latency. */ public class Contentstack { @@ -21,28 +18,30 @@ protected Contentstack() throws IllegalAccessException { } /** - * A stack is a space that stores the content of a project (a web or mobile - * property). Within a stack, you can create content structures, content - * entries, users, etc. related to the project.
- * Authenticates the stack api key of your stack.
- * Find Your Stack Credentials from Contentstack . + * A stack is a space that stores the content of a project (a web or mobile property). Within a stack, you can + * create content structures, content entries, users, etc. related to the project.
Authenticates the stack api + * key of your stack.
Find Your Stack Credentials from Contentstack . * - * @param stackApiKey The API Key is a unique key assigned to each stack. - * @param deliveryToken The Delivery Token is a read-only credential that you - * can create for different environments of your stack - * @param environment the environment for the stack + * @param stackApiKey + * The API Key is a unique key assigned to each stack. + * @param deliveryToken + * The Delivery Token is a read-only credential that you can create for different environments of your + * stack + * @param environment + * the environment for the stack * @return the stack - * @throws IllegalAccessException the illegal access exception + * @throws IllegalAccessException + * the illegal access exception + *

+ * Example * - * Example - * - *

-     *                                {
-     *                                    @Code
-     *                                    Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                }
+     *         
+     *                   {
+     *                     @Code
+     *                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
+     *                   }
      *
-     *                                
+ *
*/ public static Stack stack(String stackApiKey, String deliveryToken, String environment) throws IllegalAccessException { @@ -52,21 +51,23 @@ public static Stack stack(String stackApiKey, String deliveryToken, String envir } /** - * A stack is a space that stores the content of a project (a web or mobile - * property). Within a stack, you can create content structures, content - * entries, users, etc. related to the project. + * A stack is a space that stores the content of a project (a web or mobile property). Within a stack, you can + * create content structures, content entries, users, etc. related to the project. * - * @param stackApiKey The API Key is a unique key assigned to each stack. - * @param deliveryToken The Delivery Token is a read-only credential that you - * can create for different environments of your stack - * @param environment the environment for the stack - * @param config the config + * @param stackApiKey + * The API Key is a unique key assigned to each stack. + * @param deliveryToken + * The Delivery Token is a read-only credential that you can create for different environments of your + * stack + * @param environment + * the environment for the stack + * @param config + * the config * @return the stack - * @throws IllegalAccessException the illegal access exception Example - * - * { @Code Stack stack = - * contentstack.Stack("apiKey", "deliveryToken", - * "environment"); } + * @throws IllegalAccessException + * the illegal access exception Example + *

+ * { @Code Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); } */ public static Stack stack(String stackApiKey, String deliveryToken, String environment, Config config) throws IllegalAccessException { diff --git a/src/main/java/com/contentstack/sdk/Query.java b/src/main/java/com/contentstack/sdk/Query.java index c9a1df2f..b6496ebc 100644 --- a/src/main/java/com/contentstack/sdk/Query.java +++ b/src/main/java/com/contentstack/sdk/Query.java @@ -1342,6 +1342,7 @@ private LinkedHashMap getUrlParams(JSONObject jsonMain) { @Override public void getResult(Object object, String controller) { // It would not be called. + //System.out.println(object); } @Override diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java index e4680e45..8e7ee04c 100644 --- a/src/main/java/com/contentstack/sdk/Stack.java +++ b/src/main/java/com/contentstack/sdk/Stack.java @@ -372,10 +372,10 @@ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallB *
* Example :
*

-     *                                                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                     stack.syncToken("syncToken")
-     *                                                                                                                                                                                                                                                                                                                                                                             stack.syncToken(sync_token, new SyncResultCallBack()                                                                                                                                                                                                               ){ }
-     *                                                                                                                                                                                                                                                                                                                                                                             
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncToken("syncToken") + * stack.syncToken(sync_token, new SyncResultCallBack() ){ } + * */ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { this.sync(null); @@ -477,10 +477,10 @@ public void syncLocale(String localeCode, SyncResultCallBack syncCallBack) { *
* Example :
*
-     *                                                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                     stack.syncPublishType(PublishType)
-     *                                                                                                                                                                                                                                                                                                                                                                             stackInstance.syncPublishType(Stack.PublishType.entry_published, new SyncResultCallBack()) { }
-     *                                                                                                                                                                                                                                                                                                                                                                             
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncPublishType(PublishType) + * stackInstance.syncPublishType(Stack.PublishType.entry_published, new SyncResultCallBack()) { } + * */ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCallBack) { this.sync(null); @@ -508,9 +508,8 @@ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCall *
* Example :
*/ - public void sync( - String contentType, Date fromDate, String localeCode, PublishType publishType, SyncResultCallBack - syncCallBack) { + public void sync(String contentType, Date fromDate, String localeCode, + PublishType publishType, SyncResultCallBack syncCallBack) { String newDate = convertUTCToISO(fromDate); this.sync(null); syncParams.put("start_from", newDate); @@ -538,8 +537,8 @@ private void fetchContentTypes(String urlString, JSONObject } } - private void fetchFromNetwork(String urlString, JSONObject urlQueries, HashMap headers, - SyncResultCallBack callback) { + private void fetchFromNetwork(String urlString, JSONObject urlQueries, + HashMap headers, SyncResultCallBack callback) { if (callback != null) { HashMap urlParams = getUrlParams(urlQueries); String requestInfo = REQUEST_CONTROLLER.SYNC.toString(); diff --git a/src/main/java/com/contentstack/sdk/SuperEntry.java b/src/main/java/com/contentstack/sdk/SuperEntry.java new file mode 100644 index 00000000..088318cb --- /dev/null +++ b/src/main/java/com/contentstack/sdk/SuperEntry.java @@ -0,0 +1,57 @@ +package com.contentstack.sdk; + +import com.google.gson.JsonElement; +import com.google.gson.JsonObject; +import com.google.gson.JsonParser; + +import java.util.Map; + +// SuperEntry is used as the common class that caould be consumed by Entry and Query +public class SuperEntry { + + + /** + * Merge "source" into "target". If fields have equal name, merge them recursively. Null values in source will + * remove the field from the target. Override target values with source values Keys not supplied in source will + * remain unchanged in target + * + * @return the merged object (target). + */ + public static JsonObject deepMerge(JsonObject source, JsonObject target) { + + for (Map.Entry sourceEntry : source.entrySet()) { + String key = sourceEntry.getKey(); + JsonElement value = sourceEntry.getValue(); + if (!target.has(key)) { + //target does not have the same key, so perhaps it should be added to target + if (!value.isJsonNull()) //well, only add if the source value is not null + target.add(key, value); + } else { + if (!value.isJsonNull()) { + if (value.isJsonObject()) { + //source value is json object, start deep merge + deepMerge(value.getAsJsonObject(), target.get(key).getAsJsonObject()); + } else { + target.add(key, value); + } + } else { + target.remove(key); + } + } + } + return target; + } + + + /** + * simple test + */ + public static void main(String[] args) { + JsonParser parser = new JsonParser(); + JsonObject sourse = parser.parse("{offer: {issue1: null, issue2: null}, accept: true, reject: null}").getAsJsonObject(); + JsonObject target = parser.parse("{offer: {issue2: value2}, reject: false}").getAsJsonObject(); + System.out.println(deepMerge(sourse, target)); + } + + +} diff --git a/src/test/java/com/contentstack/sdk/TestLivePreview.java b/src/test/java/com/contentstack/sdk/TestLivePreview.java index 04d58815..6eb26257 100644 --- a/src/test/java/com/contentstack/sdk/TestLivePreview.java +++ b/src/test/java/com/contentstack/sdk/TestLivePreview.java @@ -156,4 +156,23 @@ void testCompleteLivePreviewInQuery() throws Exception { Assertions.assertNotNull(entry); } + @Test() + void testUpdatedLivePreviewQuery() throws Exception { + Config livePreviewEnablerConfig = new Config().enableLivePreview(true) + .setLivePreviewHost("api.contentstack.io") + .setManagementToken("csbfda4612ff5324f18854554b"); + Stack stack = Contentstack.stack("blte00eab6e0747e802", "cs8d948d26c781ddb4144210e1", "development", livePreviewEnablerConfig); + HashMap hashMap = new HashMap<>(); + hashMap.put("content_type_uid", "bugfixes"); + hashMap.put("entry_uid", "blt009591baa60f3f3b"); + stack.livePreviewQuery(hashMap); + Query entry = stack.contentType("bugfixes").query(); + entry.find(new QueryResultsCallBack() { + @Override + public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { + Assertions.assertNotNull(entry); + } + }); + Assertions.assertNotNull(entry); + } } diff --git a/src/test/resources/assets/live_preview.json b/src/test/resources/assets/live_preview.json index e69de29b..940d36bb 100644 --- a/src/test/resources/assets/live_preview.json +++ b/src/test/resources/assets/live_preview.json @@ -0,0 +1,60 @@ +{ + "entries": [ + { + "publish_details": { + "environment": "blt232b9b5897933fb4", + "time": "2022-09-23T11:13:39.756Z", + "locale": "en-us", + "user": "bltc11e668e0295477f" + }, + "link": { + "href": "/data_structure_is_storage", + "title": "A data structure is a storage" + }, + "created_at": "2022-09-23T11:12:55.694Z", + "ACL": {}, + "locale": "en-us", + "title": "A data structure is a storage that is used to store and organize data", + "created_by": "bltc11e668e0295477f", + "rich_text_editor": "

A data structure is a storage that is used to store and organize data. It is a way of arranging data on a computer so that it can be accessed and updated efficiently.

A data structure is a storage that is used to store and organize data. It is a way of arranging data on a computer so that it can be accessed and updated efficiently.A data structure is a storage that is used to store and organize data. It is a way of arranging data on a computer so that it can be accessed and updated efficiently.









", + "url": "/data_structure", + "tags": [ + "data structure" + ], + "uid": "bltc365833e25e676f3", + "updated_at": "2022-09-23T11:13:38.080Z", + "updated_by": "bltc11e668e0295477f", + "_version": 2 + }, + { + "publish_details": { + "environment": "blt232b9b5897933fb4", + "time": "2022-09-22T11:55:20.616Z", + "locale": "en-us", + "user": "bltc11e668e0295477f" + }, + "link": { + "href": "https://images.pexels.com/photos/7276703/pexels-photo-7276703.jpeg?cs=srgb&dl=pexels-alejandro-peralta-7276703.jpg&fm=jpg", + "title": " What is Lorem Ipsum" + }, + "created_at": "2021-04-15T10:51:10.292Z", + "ACL": {}, + "locale": "en-us", + "title": "What is Lorem Ipsum", + "created_by": "bltc11e668e0295477f", + "rich_text_editor": "

Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.

Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old. Richard McClintock, a Latin professor at Hampden-Sydney College in Virginia, looked up one of the more obscure Latin words, consectetur, from a Lorem Ipsum passage, and going through the cites of the word in classical literature, discovered the undoubtable source. Lorem Ipsum comes from sections 1.10.32 and 1.10.33 of \"de Finibus Bonorum et Malorum\" (The Extremes of Good and Evil) by Cicero, written in 45 BC. This book is a treatise on the theory of ethics, very popular during the Renaissance. The first line of Lorem Ipsum, \"Lorem ipsum dolor sit amet..\", comes from a line in section 1.10.32.


There are many variations of passages of Lorem Ipsum available, but the majority have suffered alteration in some form, by injected humour, or randomised words which don't look even slightly believable. If you are going to use a passage of Lorem Ipsum, you need to be sure there isn't anything embarrassing hidden in the middle of text. All the Lorem Ipsum generators on the Internet tend to repeat predefined chunks as necessary, making this the first true generator on the Internet. It uses a dictionary of over 200 Latin words, combined with a handful of model sentence structures, to generate Lorem Ipsum which looks reasonable. The generated Lorem Ipsum is therefore always free from repetition, injected humour, or non-characteristic words etc.


  1. camera.




", + "url": "/hey-this-is-the-sample", + "tags": [ + "abdn", + "shailesh", + "ishaileshmishra", + "nature", + "loves" + ], + "uid": "blt009591baa60f3f3b", + "updated_at": "2022-09-22T11:55:15.103Z", + "updated_by": "bltc11e668e0295477f", + "_version": 3 + } + ] +} \ No newline at end of file From 7b35deb4b748e91bd956a3fa44caf1c1991cf4ad Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Mon, 31 Oct 2022 16:19:50 +0530 Subject: [PATCH 024/104] Live Preview --- pom.xml | 7 +++--- .../contentstack/sdk/CSHttpConnection.java | 24 ++++++++++++++----- .../java/com/contentstack/sdk/TestConfig.java | 3 ++- .../com/contentstack/sdk/TestContentType.java | 2 -- .../java/com/contentstack/sdk/TestEntry.java | 6 ++--- .../com/contentstack/sdk/TestQueryCase.java | 18 +++++++------- 6 files changed, 36 insertions(+), 24 deletions(-) diff --git a/pom.xml b/pom.xml index 3c7e83b5..bf4aabb7 100644 --- a/pom.xml +++ b/pom.xml @@ -1,5 +1,6 @@ - + 4.0.0 com.contentstack.sdk @@ -26,9 +27,9 @@ 4.10.0 0.8.5 1.18.24 - 5.9.0 + 5.9.1 5.8.0-M1 - 5.9.0 + 5.9.1 2.8.8 1.1.1 3.3 diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java index 2586832a..145a46fa 100644 --- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java +++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java @@ -218,17 +218,29 @@ void handleJSONObject(JSONArray arrayEntry, JSONObject jsonObj, int idx) { if (!jsonObj.isEmpty()) { if (jsonObj.has("uid") && jsonObj.opt("uid").equals(this.config.livePreviewEntry.opt("uid"))) { arrayEntry.put(idx, this.config.livePreviewEntry); - } else { - Iterator unmachedKeys = jsonObj.keys(); - unmachedKeys.forEachRemaining(key -> { - JSONObject jsonBYKey = (JSONObject) jsonObj.opt(key); - handleJSONObject(arrayEntry, jsonBYKey, idx); - }); } } responseJSON = new JSONObject().put("entries", arrayEntry); } + private void deepMergeElse(JSONArray arrayEntry, JSONObject jsonObj, int idx) { + + do { + String k = jsonObj.keySet().iterator().next(); + if (jsonObj.opt(k) instanceof JSONArray) { + JSONArray subArray = (JSONArray) jsonObj.opt(k); + IntStream.range(0, subArray.length()).forEach(pos -> { + JSONObject objJSON = (JSONObject) subArray.get(pos); + handleJSONObject(subArray, objJSON, pos); + }); + } + if (jsonObj.opt(k) instanceof JSONObject) { + handleJSONObject(arrayEntry, ((JSONObject) jsonObj.opt(k)), idx); + } + } while (jsonObj.keySet().iterator().hasNext()); + } + + void setError(String errResp) { logger.info(errResp); responseJSON = new JSONObject(errResp); // Parse error string to JSONObject diff --git a/src/test/java/com/contentstack/sdk/TestConfig.java b/src/test/java/com/contentstack/sdk/TestConfig.java index 62e66907..59bcd122 100644 --- a/src/test/java/com/contentstack/sdk/TestConfig.java +++ b/src/test/java/com/contentstack/sdk/TestConfig.java @@ -43,7 +43,8 @@ void testsSetProxy() { void testsConnectionPool() { ConnectionPool pool = config.connectionPool; pool.connectionCount(); - pool.idleConnectionCount();; + pool.idleConnectionCount(); + ; Assertions.assertNotNull(pool); } diff --git a/src/test/java/com/contentstack/sdk/TestContentType.java b/src/test/java/com/contentstack/sdk/TestContentType.java index 892353e9..1a3af487 100644 --- a/src/test/java/com/contentstack/sdk/TestContentType.java +++ b/src/test/java/com/contentstack/sdk/TestContentType.java @@ -5,8 +5,6 @@ import org.json.JSONObject; import org.junit.jupiter.api.*; -import java.util.HashMap; -import java.util.Map; import java.util.logging.Logger; @TestInstance(TestInstance.Lifecycle.PER_CLASS) diff --git a/src/test/java/com/contentstack/sdk/TestEntry.java b/src/test/java/com/contentstack/sdk/TestEntry.java index c95662d6..4a90428b 100644 --- a/src/test/java/com/contentstack/sdk/TestEntry.java +++ b/src/test/java/com/contentstack/sdk/TestEntry.java @@ -393,7 +393,7 @@ void entryGetAsset() { @Test @Order(42) void entryExcept() { - String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; + String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; Entry initEntry = stack.contentType("product").entry(entryUid); initEntry.except(arrField); Assertions.assertEquals(3, initEntry.exceptFieldArray.length()); @@ -413,7 +413,7 @@ void entryIncludeReference() { @Test @Order(44) void entryIncludeReferenceList() { - String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; + String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; Entry initEntry = stack.contentType("product").entry(entryUid); initEntry.includeReference(arrField); Assertions.assertEquals(3, initEntry.referenceArray.length()); @@ -424,7 +424,7 @@ void entryIncludeReferenceList() { @Test @Order(45) void entryOnlyList() { - String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; + String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; Entry initEntry = stack.contentType("product").entry(entryUid); initEntry.only(arrField); Assertions.assertEquals(3, initEntry.objectUidForOnly.length()); diff --git a/src/test/java/com/contentstack/sdk/TestQueryCase.java b/src/test/java/com/contentstack/sdk/TestQueryCase.java index 654090ae..57c9bf76 100644 --- a/src/test/java/com/contentstack/sdk/TestQueryCase.java +++ b/src/test/java/com/contentstack/sdk/TestQueryCase.java @@ -133,7 +133,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(5) void testNotContainedInField() { - String[] containArray = new String[] { "Roti Maker", "kids dress" }; + String[] containArray = new String[]{"Roti Maker", "kids dress"}; query.notContainedIn("title", containArray); query.find(new QueryResultsCallBack() { @Override @@ -151,7 +151,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(6) void testContainedInField() { - String[] containArray = new String[] { "Roti Maker", "kids dress" }; + String[] containArray = new String[]{"Roti Maker", "kids dress"}; query.containedIn("title", containArray); query.find(new QueryResultsCallBack() { @Override @@ -262,7 +262,7 @@ void testEntriesWithOr() { query.lessThan("price", 90); Query subQuery = ct.query(); - subQuery.containedIn("discount", new Integer[] { 20, 45 }); + subQuery.containedIn("discount", new Integer[]{20, 45}); ArrayList array = new ArrayList<>(); array.add(query); @@ -294,7 +294,7 @@ void testEntriesWithAnd() { query.lessThan("price", 90); Query subQuery = ct.query(); - subQuery.containedIn("discount", new Integer[] { 20, 45 }); + subQuery.containedIn("discount", new Integer[]{20, 45}); ArrayList array = new ArrayList<>(); array.add(query); @@ -404,7 +404,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else - // descending + // descending Assertions.assertTrue(true); } else { Assertions.fail("expected descending, found ascending"); @@ -430,7 +430,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else - // descending + // descending Assertions.fail("expected descending, found ascending"); } else { Assertions.assertTrue(true); @@ -480,7 +480,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(22) void testOnly() { - query.only(new String[] { "price" }); + query.only(new String[]{"price"}); query.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -497,7 +497,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(23) void testExcept() { - query.except(new String[] { "price" }); + query.except(new String[]{"price"}); query.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -612,7 +612,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(28) void testTags() { - query.tags(new String[] { "pink" }); + query.tags(new String[]{"pink"}); query.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { From 8896b6ccecc1ef7d95e09c961fd68650301aa420 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Mon, 31 Oct 2022 16:22:48 +0530 Subject: [PATCH 025/104] Live Preview --- .../sdk/{SuperEntry.java => Utils.java} | 35 +++++++++++-------- 1 file changed, 21 insertions(+), 14 deletions(-) rename src/main/java/com/contentstack/sdk/{SuperEntry.java => Utils.java} (62%) diff --git a/src/main/java/com/contentstack/sdk/SuperEntry.java b/src/main/java/com/contentstack/sdk/Utils.java similarity index 62% rename from src/main/java/com/contentstack/sdk/SuperEntry.java rename to src/main/java/com/contentstack/sdk/Utils.java index 088318cb..4f25538a 100644 --- a/src/main/java/com/contentstack/sdk/SuperEntry.java +++ b/src/main/java/com/contentstack/sdk/Utils.java @@ -2,13 +2,11 @@ import com.google.gson.JsonElement; import com.google.gson.JsonObject; -import com.google.gson.JsonParser; +import java.lang.reflect.Field; import java.util.Map; -// SuperEntry is used as the common class that caould be consumed by Entry and Query -public class SuperEntry { - +public class Utils { /** * Merge "source" into "target". If fields have equal name, merge them recursively. Null values in source will @@ -43,15 +41,24 @@ public static JsonObject deepMerge(JsonObject source, JsonObject target) { } - /** - * simple test - */ - public static void main(String[] args) { - JsonParser parser = new JsonParser(); - JsonObject sourse = parser.parse("{offer: {issue1: null, issue2: null}, accept: true, reject: null}").getAsJsonObject(); - JsonObject target = parser.parse("{offer: {issue2: value2}, reject: false}").getAsJsonObject(); - System.out.println(deepMerge(sourse, target)); + public T merge(T local, T remote) throws IllegalAccessException, InstantiationException { + Class clazz = local.getClass(); + Object merged = clazz.newInstance(); + for (Field field : clazz.getDeclaredFields()) { + field.setAccessible(true); + Object localValue = field.get(local); + Object remoteValue = field.get(remote); + if (localValue != null) { + switch (localValue.getClass().getSimpleName()) { + case "Default": + case "Detail": + field.set(merged, this.merge(localValue, remoteValue)); + break; + default: + field.set(merged, (remoteValue != null) ? remoteValue : localValue); + } + } + } + return (T) merged; } - - } From eae094f48530d798abe797085bbf39d51ed39c2c Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Mon, 31 Oct 2022 16:31:39 +0530 Subject: [PATCH 026/104] Live Preview --- .../contentstack/sdk/CSHttpConnection.java | 38 +++++++------------ src/main/java/com/contentstack/sdk/Utils.java | 3 ++ 2 files changed, 17 insertions(+), 24 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java index 145a46fa..2d48c21c 100644 --- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java +++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java @@ -203,15 +203,22 @@ private void getService(String requestUrl) throws IOException { void handleJSONArray() { - JSONArray entries = new JSONArray(); if (responseJSON.has("entries") && !responseJSON.optJSONArray("entries").isEmpty()) { - entries = responseJSON.optJSONArray("entries"); + JSONArray finalEntries = responseJSON.optJSONArray("entries"); + IntStream.range(0, finalEntries.length()).forEach(idx -> { + JSONObject objJSON = (JSONObject) finalEntries.get(idx); + handleJSONObject(finalEntries, objJSON, idx); + }); } - JSONArray finalEntries = entries; - IntStream.range(0, entries.length()).forEach(idx -> { - JSONObject objJSON = (JSONObject) finalEntries.get(idx); - handleJSONObject(finalEntries, objJSON, idx); - }); + if (responseJSON.has("entry") && !responseJSON.optJSONObject("entry").isEmpty()) { + JSONObject entry = responseJSON.optJSONObject("entry"); + if (!entry.isEmpty()) { + if (entry.has("uid") && entry.opt("uid").equals(this.config.livePreviewEntry.opt("uid"))) { + responseJSON = new JSONObject().put("entry", this.config.livePreviewEntry); + } + } + } + } void handleJSONObject(JSONArray arrayEntry, JSONObject jsonObj, int idx) { @@ -223,23 +230,6 @@ void handleJSONObject(JSONArray arrayEntry, JSONObject jsonObj, int idx) { responseJSON = new JSONObject().put("entries", arrayEntry); } - private void deepMergeElse(JSONArray arrayEntry, JSONObject jsonObj, int idx) { - - do { - String k = jsonObj.keySet().iterator().next(); - if (jsonObj.opt(k) instanceof JSONArray) { - JSONArray subArray = (JSONArray) jsonObj.opt(k); - IntStream.range(0, subArray.length()).forEach(pos -> { - JSONObject objJSON = (JSONObject) subArray.get(pos); - handleJSONObject(subArray, objJSON, pos); - }); - } - if (jsonObj.opt(k) instanceof JSONObject) { - handleJSONObject(arrayEntry, ((JSONObject) jsonObj.opt(k)), idx); - } - } while (jsonObj.keySet().iterator().hasNext()); - } - void setError(String errResp) { logger.info(errResp); diff --git a/src/main/java/com/contentstack/sdk/Utils.java b/src/main/java/com/contentstack/sdk/Utils.java index 4f25538a..742da8a0 100644 --- a/src/main/java/com/contentstack/sdk/Utils.java +++ b/src/main/java/com/contentstack/sdk/Utils.java @@ -61,4 +61,7 @@ public T merge(T local, T remote) throws IllegalAccessException, Instantiati } return (T) merged; } + + + } From ac25c8e8fe91ec37e0b30dae7a697a1c440bfccb Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Mon, 31 Oct 2022 16:32:20 +0530 Subject: [PATCH 027/104] Live Preview --- .../com/contentstack/sdk/TestLivePreview.java | 20 +------------------ 1 file changed, 1 insertion(+), 19 deletions(-) diff --git a/src/test/java/com/contentstack/sdk/TestLivePreview.java b/src/test/java/com/contentstack/sdk/TestLivePreview.java index 6eb26257..c26b3fc0 100644 --- a/src/test/java/com/contentstack/sdk/TestLivePreview.java +++ b/src/test/java/com/contentstack/sdk/TestLivePreview.java @@ -156,23 +156,5 @@ void testCompleteLivePreviewInQuery() throws Exception { Assertions.assertNotNull(entry); } - @Test() - void testUpdatedLivePreviewQuery() throws Exception { - Config livePreviewEnablerConfig = new Config().enableLivePreview(true) - .setLivePreviewHost("api.contentstack.io") - .setManagementToken("csbfda4612ff5324f18854554b"); - Stack stack = Contentstack.stack("blte00eab6e0747e802", "cs8d948d26c781ddb4144210e1", "development", livePreviewEnablerConfig); - HashMap hashMap = new HashMap<>(); - hashMap.put("content_type_uid", "bugfixes"); - hashMap.put("entry_uid", "blt009591baa60f3f3b"); - stack.livePreviewQuery(hashMap); - Query entry = stack.contentType("bugfixes").query(); - entry.find(new QueryResultsCallBack() { - @Override - public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { - Assertions.assertNotNull(entry); - } - }); - Assertions.assertNotNull(entry); - } + } From 4459dfe0bf72821825046f27a7dc77ae91de8562 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Fri, 4 Nov 2022 16:29:54 +0530 Subject: [PATCH 028/104] jira.yml From 9766476d35f70c3731929b3c5abe61bfb1a912e6 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 8 Dec 2022 18:49:16 +0530 Subject: [PATCH 029/104] :potted_plant: plugins support --- src/main/java/com/contentstack/sdk/Asset.java | 17 ++-- .../contentstack/sdk/CSBackgroundTask.java | 12 +-- .../contentstack/sdk/CSConnectionRequest.java | 4 +- .../contentstack/sdk/CSHttpConnection.java | 25 ++++++ .../java/com/contentstack/sdk/Config.java | 7 ++ .../com/contentstack/sdk/Contentstack.java | 13 +-- .../contentstack/sdk/ContentstackPlugin.java | 11 +++ src/main/java/com/contentstack/sdk/Stack.java | 16 ++-- .../sdk/TestContentstackPlugin.java | 82 +++++++++++++++++++ 9 files changed, 158 insertions(+), 29 deletions(-) create mode 100644 src/main/java/com/contentstack/sdk/ContentstackPlugin.java create mode 100644 src/test/java/com/contentstack/sdk/TestContentstackPlugin.java diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index 5c022f2d..cce87ead 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -87,10 +87,10 @@ public Asset configure(JSONObject jsonObject) { * Example :
* *
-     *                                            Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                            Asset asset = stack.asset(asset_uid);
-     *                                            asset.setHeader();
-     *                                            
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Asset asset = stack.asset(asset_uid); + * asset.setHeader(); + * */ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { headers.put(headerKey, headerValue); @@ -108,11 +108,10 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * Example :
* *
-     *                                          Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                          Asset asset = stack.asset(asset_uid);
-     *                                          asset.removeHeader();
-     *
-     *                                          
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Asset asset = stack.asset(asset_uid); + * asset.removeHeader(); + * */ public void removeHeader(@NotNull String headerKey) { headers.remove(headerKey); diff --git a/src/main/java/com/contentstack/sdk/CSBackgroundTask.java b/src/main/java/com/contentstack/sdk/CSBackgroundTask.java index 52673d43..1cdae42b 100644 --- a/src/main/java/com/contentstack/sdk/CSBackgroundTask.java +++ b/src/main/java/com/contentstack/sdk/CSBackgroundTask.java @@ -23,7 +23,7 @@ protected CSBackgroundTask(Stack stackInstance, String controller, String url, H csConnectionRequest.setStackInstance(stackInstance); csConnectionRequest.setURLQueries(urlParams); this.service = stackInstance.service; - csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callback, this.service); + csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callback, this.service, stackInstance); } @@ -37,7 +37,7 @@ protected CSBackgroundTask(Query queryInstance, Stack stackInstance, String cont csConnectionRequest.setURLQueries(urlQueries); this.service = stackInstance.service; csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callback, this.service, - stackInstance.config); + stackInstance); } @@ -49,7 +49,7 @@ protected CSBackgroundTask(Entry entryInstance, Stack stackInstance, String cont CSConnectionRequest csConnectionRequest = new CSConnectionRequest(entryInstance); csConnectionRequest.setURLQueries(urlQueries); this.service = stackInstance.service; - csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callBack, this.service); + csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callBack, this.service, stackInstance); } protected CSBackgroundTask(AssetLibrary assetLibrary, Stack stackInstance, String controller, String url, @@ -60,7 +60,7 @@ protected CSBackgroundTask(AssetLibrary assetLibrary, Stack stackInstance, Strin CSConnectionRequest csConnectionRequest = new CSConnectionRequest(assetLibrary); csConnectionRequest.setURLQueries(urlQueries); this.service = stackInstance.service; - csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callback, this.service); + csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callback, this.service, stackInstance); } @@ -72,7 +72,7 @@ protected CSBackgroundTask(Asset asset, Stack stackInstance, String controller, CSConnectionRequest csConnectionRequest = new CSConnectionRequest(asset); csConnectionRequest.setURLQueries(urlQueries); this.service = stackInstance.service; - csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callback, this.service); + csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callback, this.service, stackInstance); } protected CSBackgroundTask(ContentType contentType, Stack stackInstance, String controller, String url, @@ -83,7 +83,7 @@ protected CSBackgroundTask(ContentType contentType, Stack stackInstance, String CSConnectionRequest csConnectionRequest = new CSConnectionRequest(contentType); csConnectionRequest.setURLQueries(urlParams); this.service = stackInstance.service; - csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callback, this.service); + csConnectionRequest.setParams(completeUrl, headers, controller, requestInfo, callback, this.service, stackInstance); } protected void checkHeader(@NotNull Map headers) { diff --git a/src/main/java/com/contentstack/sdk/CSConnectionRequest.java b/src/main/java/com/contentstack/sdk/CSConnectionRequest.java index e58bc9a3..ab1a5f67 100644 --- a/src/main/java/com/contentstack/sdk/CSConnectionRequest.java +++ b/src/main/java/com/contentstack/sdk/CSConnectionRequest.java @@ -76,7 +76,8 @@ public void setParams(Object... objects) { } this.service = (APIService) objects[5]; if (objects.length > 6) { - this.config = (Config) objects[6]; + this.stackInstance = (Stack) objects[6]; + this.config = this.stackInstance.config; } sendRequest(); } @@ -89,6 +90,7 @@ public void sendRequest() { connection.setInfo(requestInfo); connection.setAPIService(this.service); connection.setConfig(this.config); + connection.setStack(this.stackInstance); connection.setCallBackObject(resultCallBack); if (urlQueries != null && urlQueries.size() > 0) { connection.setFormParams(urlQueries); diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java index 2d48c21c..648760e2 100644 --- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java +++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java @@ -1,9 +1,11 @@ package com.contentstack.sdk; +import okhttp3.Request; import okhttp3.ResponseBody; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; +import retrofit2.Call; import retrofit2.Response; import java.io.IOException; @@ -30,6 +32,7 @@ public class CSHttpConnection implements IURLRequestHTTP { private String info; private APIService service; private Config config; + private Stack stackInstance; private ResultCallBack callBackObject; private JSONObject responseJSON; private HashMap formParams; @@ -186,9 +189,15 @@ private void getService(String requestUrl) throws IOException { this.headers.put(X_USER_AGENT_KEY, "contentstack-java/" + SDK_VERSION); this.headers.put(USER_AGENT_KEY, USER_AGENT); this.headers.put(CONTENT_TYPE, APPLICATION_JSON); + + Request request = pluginRequestImp(requestUrl); + + //Call call = client.newCall(request); Response response = this.service.getRequest(requestUrl, this.headers).execute(); if (response.isSuccessful()) { assert response.body() != null; + // TODO: On Response result + response = pluginResponseImp(request, response); responseJSON = new JSONObject(response.body().string()); if (this.config.livePreviewEntry != null && !this.config.livePreviewEntry.isEmpty()) { handleJSONArray(); @@ -201,6 +210,18 @@ private void getService(String requestUrl) throws IOException { } + private Request pluginRequestImp(String requestUrl) { + Call call = this.service.getRequest(requestUrl, this.headers); + Request request = call.request(); + this.config.plugins.forEach(plugin -> plugin.onRequest(this.stackInstance, request)); + return request; + } + + private Response pluginResponseImp(Request request, Response response) { + this.config.plugins.forEach(plugin -> plugin.onResponse(this.stackInstance, request, response)); + return response; + } + void handleJSONArray() { if (responseJSON.has("entries") && !responseJSON.optJSONArray("entries").isEmpty()) { @@ -248,4 +269,8 @@ public void setAPIService(APIService service) { public void setConfig(Config config) { this.config = config; } + + public void setStack(Stack stackInstance) { + this.stackInstance = stackInstance; + } } \ No newline at end of file diff --git a/src/main/java/com/contentstack/sdk/Config.java b/src/main/java/com/contentstack/sdk/Config.java index ba4b0bfc..fd07e0af 100644 --- a/src/main/java/com/contentstack/sdk/Config.java +++ b/src/main/java/com/contentstack/sdk/Config.java @@ -5,6 +5,7 @@ import org.json.JSONObject; import java.net.Proxy; +import java.util.ArrayList; import java.util.concurrent.TimeUnit; @@ -29,6 +30,8 @@ public class Config { protected Proxy proxy = null; protected ConnectionPool connectionPool = new ConnectionPool(); + protected ArrayList plugins; + public String getBranch() { return branch; } @@ -112,6 +115,10 @@ protected String setEndpoint(@NotNull String endpoint) { return this.endpoint; } + public void setPlugins(ArrayList plugins) { + this.plugins = plugins; + } + /** * Gets host. * diff --git a/src/main/java/com/contentstack/sdk/Contentstack.java b/src/main/java/com/contentstack/sdk/Contentstack.java index 3693fe68..2b07f9ac 100644 --- a/src/main/java/com/contentstack/sdk/Contentstack.java +++ b/src/main/java/com/contentstack/sdk/Contentstack.java @@ -36,12 +36,12 @@ protected Contentstack() throws IllegalAccessException { * Example * *
-     *                   {
-     *                     @Code
-     *                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                   }
+     *                                                   {
+     *                                                     @Code
+     *                                                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
+     *                                                   }
      *
-     *                   
+ * */ public static Stack stack(String stackApiKey, String deliveryToken, String environment) throws IllegalAccessException { @@ -75,6 +75,7 @@ public static Stack stack(String stackApiKey, String deliveryToken, String envir return initializeStack(stackApiKey, deliveryToken, environment, config); } + private static void validateCredentials(String stackApiKey, String deliveryToken, String environment) throws IllegalAccessException { Objects.requireNonNull(stackApiKey, "API Key can not be null"); @@ -92,6 +93,7 @@ private static void validateCredentials(String stackApiKey, String deliveryToken } } + private static Stack initializeStack(String stackApiKey, String deliveryToken, String environment, Config config) { Stack stack = new Stack(stackApiKey.trim()); stack.setHeader("api_key", stackApiKey); @@ -100,6 +102,7 @@ private static Stack initializeStack(String stackApiKey, String deliveryToken, S if (config.getBranch() != null && !config.getBranch().isEmpty()) { stack.setHeader("branch", config.getBranch()); } + // TODO: implement plugins stack.setConfig(config); return stack; } diff --git a/src/main/java/com/contentstack/sdk/ContentstackPlugin.java b/src/main/java/com/contentstack/sdk/ContentstackPlugin.java new file mode 100644 index 00000000..04524958 --- /dev/null +++ b/src/main/java/com/contentstack/sdk/ContentstackPlugin.java @@ -0,0 +1,11 @@ +package com.contentstack.sdk; + +import okhttp3.Request; +import retrofit2.Response; + +public interface ContentstackPlugin { + + void onRequest(Stack stack, Request request); + + Response onResponse(Stack stack, Request request, Response response); +} diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java index 8e7ee04c..69f0b593 100644 --- a/src/main/java/com/contentstack/sdk/Stack.java +++ b/src/main/java/com/contentstack/sdk/Stack.java @@ -372,10 +372,10 @@ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallB *
* Example :
*
-     *                                                                                             Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                             stack.syncToken("syncToken")
-     *                                                                                                                                                                                                                                                                                                                                                                                                                     stack.syncToken(sync_token, new SyncResultCallBack()                                                                                                                                                                                                               ){ }
-     *                                                                                                                                                                                                                                                                                                                                                                                                                     
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncToken("syncToken") + * stack.syncToken(sync_token, new SyncResultCallBack() ){ } + * */ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { this.sync(null); @@ -477,10 +477,10 @@ public void syncLocale(String localeCode, SyncResultCallBack syncCallBack) { *
* Example :
*
-     *                                                                                             Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                             stack.syncPublishType(PublishType)
-     *                                                                                                                                                                                                                                                                                                                                                                                                                     stackInstance.syncPublishType(Stack.PublishType.entry_published, new SyncResultCallBack()) { }
-     *                                                                                                                                                                                                                                                                                                                                                                                                                     
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncPublishType(PublishType) + * stackInstance.syncPublishType(Stack.PublishType.entry_published, new SyncResultCallBack()) { } + * */ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCallBack) { this.sync(null); diff --git a/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java new file mode 100644 index 00000000..5d008bf4 --- /dev/null +++ b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java @@ -0,0 +1,82 @@ +package com.contentstack.sdk; + +import io.github.cdimascio.dotenv.Dotenv; +import okhttp3.Request; +import org.junit.jupiter.api.*; +import retrofit2.Response; + +import java.util.ArrayList; +import java.util.logging.Logger; + +@TestInstance(TestInstance.Lifecycle.PER_CLASS) +@TestMethodOrder(MethodOrderer.OrderAnnotation.class) +class TestContentstackPlugin { + + protected String API_KEY, DELIVERY_TOKEN, ENV; + private final Logger logger = Logger.getLogger(TestContentstackPlugin.class.getName()); + + @BeforeAll + public void initBeforeTests() { + Dotenv dotenv = Dotenv.load(); + API_KEY = dotenv.get("API_KEY"); + DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); + ENV = dotenv.get("ENVIRONMENT"); + } + + class Plugin1 implements ContentstackPlugin { + + + @Override + public void onRequest(Stack stack, Request request) { + + } + + @Override + public Response onResponse(Stack stack, Request request, retrofit2.Response response) { + return null; + } + } + + + class Plugin2 implements ContentstackPlugin { + + + @Override + public void onRequest(Stack stack, Request request) { + + } + + @Override + public Response onResponse(Stack stack, Request request, Response response) { + return response; + } + } + + + @Test + @Order(1) + void testContentstackPlugin() { + try { + + ArrayList plugins = new ArrayList<>(); + Plugin1 plugin1 = new Plugin1(); + Plugin2 plugin2 = new Plugin2(); + + plugins.add(plugin1); + plugins.add(plugin2); + + + // Create a config instance: + Config config = new Config(); + config.setPlugins(plugins); + + Stack stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); + ContentType contentType = stack.contentType("fakeCT"); + Entry entry = contentType.entry(); + + } catch (IllegalAccessException e) { + throw new RuntimeException(e); + } + } + +} From 324ad8c9f29258bfa3104d9d69357a03f769b5bc Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 8 Dec 2022 19:03:48 +0530 Subject: [PATCH 030/104] :potted_plant: plugins support --- .../java/com/contentstack/sdk/CSHttpConnection.java | 12 ++++++++++-- src/main/java/com/contentstack/sdk/Config.java | 2 +- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java index 648760e2..10cdedab 100644 --- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java +++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java @@ -190,14 +190,22 @@ private void getService(String requestUrl) throws IOException { this.headers.put(USER_AGENT_KEY, USER_AGENT); this.headers.put(CONTENT_TYPE, APPLICATION_JSON); - Request request = pluginRequestImp(requestUrl); + Request request = null; + if (this.config.plugins!=null){ + request = pluginRequestImp(requestUrl); + //this.headers = request.headers(); + //requestUrl = request.url(); + } //Call call = client.newCall(request); Response response = this.service.getRequest(requestUrl, this.headers).execute(); if (response.isSuccessful()) { assert response.body() != null; + // TODO: On Response result - response = pluginResponseImp(request, response); + if (request!=null){ + response = pluginResponseImp( request, response); + } responseJSON = new JSONObject(response.body().string()); if (this.config.livePreviewEntry != null && !this.config.livePreviewEntry.isEmpty()) { handleJSONArray(); diff --git a/src/main/java/com/contentstack/sdk/Config.java b/src/main/java/com/contentstack/sdk/Config.java index fd07e0af..d7d99d7e 100644 --- a/src/main/java/com/contentstack/sdk/Config.java +++ b/src/main/java/com/contentstack/sdk/Config.java @@ -30,7 +30,7 @@ public class Config { protected Proxy proxy = null; protected ConnectionPool connectionPool = new ConnectionPool(); - protected ArrayList plugins; + protected ArrayList plugins = null; public String getBranch() { return branch; From 7c6fd6ae015d672484f1f9aad8560b22357aaa01 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 9 Dec 2022 19:02:21 +0530 Subject: [PATCH 031/104] Plugins implemented --- src/main/java/com/contentstack/sdk/Asset.java | 16 ++++++++-------- .../com/contentstack/sdk/CSHttpConnection.java | 17 +++++++++-------- .../contentstack/sdk/ContentstackPlugin.java | 3 ++- .../sdk/TestContentstackPlugin.java | 9 +++++++-- 4 files changed, 26 insertions(+), 19 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index cce87ead..30a0b0fb 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -87,10 +87,10 @@ public Asset configure(JSONObject jsonObject) { * Example :
* *
-     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *         Asset asset = stack.asset(asset_uid);
-     *         asset.setHeader();
-     *         
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Asset asset = stack.asset(asset_uid); + * asset.setHeader(); + * */ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { headers.put(headerKey, headerValue); @@ -108,10 +108,10 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * Example :
* *
-     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *         Asset asset = stack.asset(asset_uid);
-     *         asset.removeHeader();
-     *        
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Asset asset = stack.asset(asset_uid); + * asset.removeHeader(); + * */ public void removeHeader(@NotNull String headerKey) { headers.remove(headerKey); diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java index 10cdedab..2cabfa01 100644 --- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java +++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java @@ -191,20 +191,21 @@ private void getService(String requestUrl) throws IOException { this.headers.put(CONTENT_TYPE, APPLICATION_JSON); Request request = null; - if (this.config.plugins!=null){ + if (this.config.plugins != null) { request = pluginRequestImp(requestUrl); - //this.headers = request.headers(); - //requestUrl = request.url(); + this.headers.clear(); + Request finalRequest = request; + request.headers().names().forEach(key -> { + this.headers.put(key, finalRequest.headers().get(key)); + }); + requestUrl = request.url().toString(); } - //Call call = client.newCall(request); Response response = this.service.getRequest(requestUrl, this.headers).execute(); if (response.isSuccessful()) { assert response.body() != null; - - // TODO: On Response result - if (request!=null){ - response = pluginResponseImp( request, response); + if (request != null) { + response = pluginResponseImp(request, response); } responseJSON = new JSONObject(response.body().string()); if (this.config.livePreviewEntry != null && !this.config.livePreviewEntry.isEmpty()) { diff --git a/src/main/java/com/contentstack/sdk/ContentstackPlugin.java b/src/main/java/com/contentstack/sdk/ContentstackPlugin.java index 04524958..2cdbad3b 100644 --- a/src/main/java/com/contentstack/sdk/ContentstackPlugin.java +++ b/src/main/java/com/contentstack/sdk/ContentstackPlugin.java @@ -1,11 +1,12 @@ package com.contentstack.sdk; import okhttp3.Request; +import okhttp3.ResponseBody; import retrofit2.Response; public interface ContentstackPlugin { void onRequest(Stack stack, Request request); - Response onResponse(Stack stack, Request request, Response response); + Response onResponse(Stack stack, Request request, Response response); } diff --git a/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java index 5d008bf4..6cf6410a 100644 --- a/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java +++ b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java @@ -65,14 +65,19 @@ void testContentstackPlugin() { plugins.add(plugin1); plugins.add(plugin2); - // Create a config instance: Config config = new Config(); config.setPlugins(plugins); Stack stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); ContentType contentType = stack.contentType("fakeCT"); - Entry entry = contentType.entry(); + Entry entry = contentType.entry("something_demo"); + entry.fetch(new EntryResultCallBack() { + @Override + public void onCompletion(ResponseType responseType, Error error) { + + } + }); } catch (IllegalAccessException e) { throw new RuntimeException(e); From 3ed997c7eb6addbe9c5f284f70b41055c6029cbb Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 9 Dec 2022 19:03:16 +0530 Subject: [PATCH 032/104] :potted_plant: plugins support --- src/test/java/com/contentstack/sdk/TestLivePreview.java | 1 + 1 file changed, 1 insertion(+) diff --git a/src/test/java/com/contentstack/sdk/TestLivePreview.java b/src/test/java/com/contentstack/sdk/TestLivePreview.java index c26b3fc0..521f1fab 100644 --- a/src/test/java/com/contentstack/sdk/TestLivePreview.java +++ b/src/test/java/com/contentstack/sdk/TestLivePreview.java @@ -157,4 +157,5 @@ void testCompleteLivePreviewInQuery() throws Exception { } + } From 71cbcf5878982888acc6c9b4a6df899dda7984eb Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 21 Dec 2022 10:19:28 +0530 Subject: [PATCH 033/104] :potted_plant: CI/CD Pipeline --- .github/workflows/maven-publish.yml | 39 ++ pom.xml | 12 +- .../com/contentstack/sdk/ContentType.java | 1 + src/main/java/com/contentstack/sdk/Entry.java | 82 +-- .../contentstack/sdk/IRequestModelHTTP.java | 3 + src/main/java/com/contentstack/sdk/Query.java | 647 ++++++++---------- src/main/java/com/contentstack/sdk/Stack.java | 22 +- 7 files changed, 385 insertions(+), 421 deletions(-) create mode 100644 .github/workflows/maven-publish.yml diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml new file mode 100644 index 00000000..60bb183c --- /dev/null +++ b/.github/workflows/maven-publish.yml @@ -0,0 +1,39 @@ +name: Publish package to the Maven Central Repository +on: + release: + types: [ created ] + push: +jobs: + publish-maven: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - name: Set up Maven Central Repository + uses: actions/setup-java@v3 + with: + java-version: '8' + distribution: 'adopt' + server-id: shaileshmishra + server-username: MAVEN_USERNAME + server-password: MAVEN_PASSWORD + gpg-passphrase: GPG_PASSPHRASE + - name: Publish package + run: mvn --batch-mode deploy + env: + MAVEN_USERNAME: ${{ secrets.OSSRH_USERNAME }} + MAVEN_PASSWORD: ${{ secrets.OSSRH_TOKEN }} + GPG_PASSPHRASE: ${{ secrets.GPG_PASSPHRASE }} + publish-github: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - name: Set up Java for publishing to GitHub Packages + uses: actions/setup-java@v3 + with: + java-version: '8' + distribution: 'adopt' + server-id: github + - name: Publish to GitHub Packages + run: mvn --batch-mode deploy + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} \ No newline at end of file diff --git a/pom.xml b/pom.xml index bf4aabb7..21c8af3c 100644 --- a/pom.xml +++ b/pom.xml @@ -13,14 +13,14 @@ - 1.10.1-SNAPSHOT + 1.10.2-SNAPSHOT 1.8 1.8 UTF-8 2.22.0 2.2.1 - 3.3.2 - 2.2.4 + 3.4.1 + 2.3.1 3.1.5 2.9.0 2.9.0 @@ -35,12 +35,10 @@ 3.3 1.5 3.8.1 - 1.6.7 - 2.5.3 + 1.6.13 20220924 0.8.7 2.5.3 - 1.6.7 1.2.0 @@ -211,6 +209,8 @@ jar + ${basedir}/src/main/javadoc/stylesheet.css + public -Xdoclint:none false false diff --git a/src/main/java/com/contentstack/sdk/ContentType.java b/src/main/java/com/contentstack/sdk/ContentType.java index dbff447b..3db038aa 100644 --- a/src/main/java/com/contentstack/sdk/ContentType.java +++ b/src/main/java/com/contentstack/sdk/ContentType.java @@ -132,6 +132,7 @@ public Query query() { * the params * @param callback * the callback + * @throws IllegalAccessException illegal access exception */ public void fetch(@NotNull JSONObject params, final ContentTypesCallback callback) throws IllegalAccessException { String urlString = "content_types/" + contentTypeUid; diff --git a/src/main/java/com/contentstack/sdk/Entry.java b/src/main/java/com/contentstack/sdk/Entry.java index 13a0af6d..0dfcba72 100644 --- a/src/main/java/com/contentstack/sdk/Entry.java +++ b/src/main/java/com/contentstack/sdk/Entry.java @@ -72,10 +72,10 @@ public Entry configure(JSONObject jsonObject) { * Example :
* *
-     *                                                                              Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                                              Entry entry = stack.contentType("form_name").entry("entry_uid");
-     *                                                                              entry.setHeader("custom_header_key", "custom_header_value");
-     *                                                                              
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid"); + * entry.setHeader("custom_header_key", "custom_header_value"); + * */ public void setHeader(String key, String value) { @@ -93,10 +93,10 @@ public void setHeader(String key, String value) { * Example :
* *
-     *                                                                            Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                                            Entry entry = stack.contentType("form_name").entry("entry_uid");
-     *                                                                            entry.removeHeader("custom_header_key");
-     *                                                                            
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid"); + * entry.removeHeader("custom_header_key"); + * */ public void removeHeader(String key) { @@ -244,8 +244,8 @@ public JSONObject toJSON() { * Example :
* *
-     *                                                                            Object obj = entry.get("key");
-     *                                                                            
+ * Object obj = entry.get("key"); + * * @return Object @resultJson */ public Object get(@NotNull String key) { @@ -261,8 +261,8 @@ public Object get(@NotNull String key) { * Example :
* *
-     *                                                                            String value = entry.getString("key");
-     *                                                                            
+ * String value = entry.getString("key"); + * * @return String @getString */ @@ -283,8 +283,8 @@ public String getString(@NotNull String key) { * Example :
* *
-     *                                                                            Boolean value = entry.getBoolean("key");
-     *                                                                            
+ * Boolean value = entry.getBoolean("key"); + * * @return boolean @getBoolean */ @@ -305,8 +305,8 @@ public Boolean getBoolean(@NotNull String key) { * Example :
* *
-     *                                                                            JSONArray value = entry.getJSONArray("key");
-     *                                                                            
+ * JSONArray value = entry.getJSONArray("key"); + * * @return JSONArray @getJSONArray */ @@ -327,8 +327,8 @@ public JSONArray getJSONArray(@NotNull String key) { * Example :
* *
-     *                                                                            JSONObject value = entry.getJSONObject("key");
-     *                                                                            
+ * JSONObject value = entry.getJSONObject("key"); + * * @return JSONObject @getJSONObject */ public JSONObject getJSONObject(@NotNull String key) { @@ -348,8 +348,8 @@ public JSONObject getJSONObject(@NotNull String key) { * Example :
* *
-     *                                                                            JSONObject value = entry.getJSONObject("key");
-     *                                                                            
+ * JSONObject value = entry.getJSONObject("key"); + * * @return Number @getNumber */ @@ -370,8 +370,8 @@ public Number getNumber(@NotNull String key) { * Example :
* *
-     *                                                                            int value = entry.getInt("key");
-     *                                                                            
+ * int value = entry.getInt("key"); + * * @return int @getInt */ @@ -436,8 +436,8 @@ public double getDouble(@NotNull String key) { * Example :
* *
-     *                                                                            long value = entry.getLong("key");
-     *                                                                            
+ * long value = entry.getLong("key"); + * * @return long @getLong */ @@ -460,8 +460,8 @@ public long getLong(@NotNull String key) { * Example :
* *
-     *                                                                            short value = entry.getShort("key");
-     *                                                                            
+ * short value = entry.getShort("key"); + * * @return short @getShort */ public short getShort(@NotNull String key) { @@ -481,8 +481,8 @@ public short getShort(@NotNull String key) { * Example :
* *
-     *                                                                            Calendar value = entry.getDate("key");
-     *                                                                            
+ * Calendar value = entry.getDate("key"); + * * @return Calendar @getDate */ @@ -664,9 +664,9 @@ public List getAssets(String key) { * Example :
* *
-     *                                                                             Group innerGroup = entry.getGroup("key");
-     *                                                                             return null
-     *                                                                            
+ * Group innerGroup = entry.getGroup("key"); + * return null + * * @return {@link Group} */ public Group getGroup(String key) { @@ -947,16 +947,16 @@ public Entry exceptWithReferenceUid(@NotNull ArrayList fieldUid, @NotNul * Example :
* *
-     *                                                                                 {@code
-     *                                                                                 Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                                                 Entry entry = stack.contentType("form_name").entry("entry_uid");
- * entry.fetch(new EntryResultCallBack() {
- * @Override - * public void onCompletion(ResponseType responseType, Error error) { - * }
- * });
- * } - *
+ * {@code + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid");
+ * entry.fetch(new EntryResultCallBack() {
+ * @Override + * public void onCompletion(ResponseType responseType, Error error) { + * }
+ * });
+ * } + * */ public void fetch(EntryResultCallBack callback) { diff --git a/src/main/java/com/contentstack/sdk/IRequestModelHTTP.java b/src/main/java/com/contentstack/sdk/IRequestModelHTTP.java index 717091bd..358c4d64 100644 --- a/src/main/java/com/contentstack/sdk/IRequestModelHTTP.java +++ b/src/main/java/com/contentstack/sdk/IRequestModelHTTP.java @@ -2,6 +2,9 @@ import org.json.JSONObject; +/** + * IRequestModelHTTP Interface + */ public interface IRequestModelHTTP { void sendRequest(); diff --git a/src/main/java/com/contentstack/sdk/Query.java b/src/main/java/com/contentstack/sdk/Query.java index b6496ebc..e10c1f3b 100644 --- a/src/main/java/com/contentstack/sdk/Query.java +++ b/src/main/java/com/contentstack/sdk/Query.java @@ -11,16 +11,13 @@ import static com.contentstack.sdk.Constants.*; /** - * Contentstack provides certain queries that you can use to fetch filtered - * results. You can use queries for Entries and - * Queries - * Contentstack provides certain queries that you can use to fetch filtered - * results. You can use queries for Entries and - * Assets API requests. + * Contentstack provides certain queries that you can use to fetch filtered results. You can use queries for Entries + * and + * Queries Contentstack + * provides certain queries that you can use to fetch filtered results. You can use queries for Entries and Assets API + * requests. *

- * You can now pass the branch header in the API request to fetch or manage - * modules located within specific branches of + * You can now pass the branch header in the API request to fetch or manage modules located within specific branches of * the stack. *

* Note Branches is a plan-based feature that is available only in the @@ -63,33 +60,24 @@ protected void setContentTypeInstance(ContentType contentTypeInstance) { } /** - * To set headers for Built.io Contentstack rest calls.
- * Scope is limited to this object and followed classes. + * To set headers for Built.io Contentstack rest calls.
Scope is limited to this object and followed classes. * * @param key - * header name. + * header name. * @param value - * header value against given header name.
- * - *
- *
- * Example :
- * - *

-     *                                         
 Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
-     *                                         Query csQuery = stack.contentType("contentTypeUid").query();
-     *                                         csQuery.setHeader("custom_key", "custom_value");
-     *              
- * - * ======= - * Example :
- * - *
-     *          
 Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
-     *          Query csQuery = stack.contentType("contentTypeUid").query();
-     *          csQuery.setHeader("custom_key", "custom_value");
-     *              
- * + * header value against given header name.
+ * + *
+ *
+ * Example :
+ *

+ * tack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment"); Query query = + * stack.contentType("contentTypeUid").query(); query.setHeader("custom_key", "custom_value"); + * + * Example :
+ *

+ * Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment"); Query csQuery = + * stack.contentType("contentTypeUid").query(); csQuery.setHeader("custom_key", "custom_value"); */ public void setHeader(@NotNull String key, @NotNull String value) { if (!key.isEmpty() && !value.isEmpty()) { @@ -101,25 +89,11 @@ public void setHeader(@NotNull String key, @NotNull String value) { * Remove header key @param key custom_header_key * * @param key - * {@link String} - * Example :
- * - * <<<<<<< HEAD - * - *

-     *           Stack stack = Contentstack..stack( "apiKey", "deliveryToken", "environment");
-     *           Query csQuery = stack.contentType("contentTypeUid").query();
- * csQuery.removeHeader("custom_key"); - *
- * - * ======= - * - *
-     *          Stack stack = Contentstack..stack( "apiKey", "deliveryToken", "environment");
-     *          Query csQuery = stack.contentType("contentTypeUid").query();
- * csQuery.removeHeader("custom_key"); - *
- * + * {@link String} + * Example :
+ *

+ * Stack stack = Contentstack..stack( "apiKey", "deliveryToken", "environment"); Query csQuery = + * stack.contentType("contentTypeUid").query();
csQuery.removeHeader("custom_key"); */ public void removeHeader(@NotNull String key) { if (!key.isEmpty()) { @@ -132,23 +106,22 @@ public String getContentType() { } /** - * Add a constraint to fetch all entries that contains given value against - * specified key + * Add a constraint to fetch all entries that contains given value against specified key * * @param key - * field uid. + * field uid. * @param value - * field value which get 'included' from the response. + * field value which get 'included' from the response. * @return {@link Query} object, so you can chain this call. - *

- * Note : for group field provide key in a - * "key.groupFieldUid" format.
+ *

+ * Note : for group field provide key in a + * "key.groupFieldUid" format.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *

+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.where("uid", "entry_uid");
@@ -164,16 +137,16 @@ public Query where(@NotNull String key, Object value) {
      * Add a custom query against specified key.
      *
      * @param key
-     *              key.
+     *         key.
      * @param value
-     *              value.
+     *         value.
      * @return {@link Query} object, so you can chain this call.
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack..stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
      *          csQuery.addQuery("query_param_key", "query_param_value");
@@ -190,14 +163,14 @@ public Query addQuery(@NotNull String key, String value) {
      * Remove provided query key from custom query if exist.
      *
      * @param key
-     *            Query name to remove.
+     *         Query name to remove.
      * @return {@linkplain Query} object, so you can chain this call. 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         projectQuery.removeQuery("Query_Key");
      *         
*/ @@ -212,15 +185,14 @@ public Query removeQuery(@NotNull String key) { * Combines all the queries together using AND operator * * @param queryObjects - * list of {@link Query} instances on which AND query - * executes. + * list of {@link Query} instances on which AND query executes. * @return {@link Query} object, so you can chain this call. * - *
- *
- * Example ;
+ *
+ *
+ * Example ;
* - *
+     * 
      *          Stack stack = Contentstack..stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
      *
@@ -251,15 +223,14 @@ public Query and(@NotNull ArrayList queryObjects) {
      * Add a constraint to fetch all entries which satisfy  any  queries.
      *
      * @param queryObjects
-     *                     list of {@link Query} instances on which OR query
-     *                     executes.
+     *         list of {@link Query} instances on which OR query executes.
      * @return {@link Query} object, so you can chain this call.
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
      *
@@ -293,20 +264,19 @@ public Query or(ArrayList queryObjects) {
     }
 
     /**
-     * Add a constraint to the query that requires a particular key entry to be less
-     * than the provided value.
+     * Add a constraint to the query that requires a particular key entry to be less than the provided value.
      *
      * @param key
-     *              the key to be constrained.
+     *         the key to be constrained.
      * @param value
-     *              the value that provides an upper bound.
+     *         the value that provides an upper bound.
      * @return {@link Query} object, so you can chain this call. 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.lessThan("due_date", "2013-06-25T00:00:00+05:30");
@@ -327,21 +297,20 @@ public Query lessThan(@NotNull String key, @NotNull Object value) {
     }
 
     /**
-     * Add a constraint to the query that requires a particular key entry to be less
-     * than or equal to the provided
+     * Add a constraint to the query that requires a particular key entry to be less than or equal to the provided
      * value.
      *
      * @param key
-     *              The key to be constrained
+     *         The key to be constrained
      * @param value
-     *              The value that must be equalled.
+     *         The value that must be equalled.
      * @return {@link Query} object, so you can chain this call.
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.lessThanOrEqualTo("due_date", "2013-06-25T00:00:00+05:30");
@@ -362,20 +331,19 @@ public Query lessThanOrEqualTo(@NotNull String key, Object value) {
     }
 
     /**
-     * Add a constraint to the query that requires a particular key entry to be
-     * greater than the provided value.
+     * Add a constraint to the query that requires a particular key entry to be greater than the provided value.
      *
      * @param key
-     *              The key to be constrained.
+     *         The key to be constrained.
      * @param value
-     *              The value that provides an lower bound.
+     *         The value that provides an lower bound.
      * @return {@link Query} object, so you can chain this call.
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.greaterThan("due_date", "2013-06-25T00:00:00+05:30");
@@ -396,21 +364,20 @@ public Query greaterThan(@NotNull String key, Object value) {
     }
 
     /**
-     * Add a constraint to the query that requires a particular key entry to be
-     * greater than or equal to the provided
+     * Add a constraint to the query that requires a particular key entry to be greater than or equal to the provided
      * value.
      *
      * @param key
-     *              The key to be constrained.
+     *         The key to be constrained.
      * @param value
-     *              The value that provides an lower bound.
+     *         The value that provides an lower bound.
      * @return {@link Query} object, so you can chain this call.
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.greaterThanOrEqualTo("due_date", "2013-06-25T00:00:00+05:30");
@@ -431,20 +398,19 @@ public Query greaterThanOrEqualTo(String key, Object value) {
     }
 
     /**
-     * Add a constraint to the query that requires a particular key's entry to
-     * be not equal to the provided value.
+     * Add a constraint to the query that requires a particular key's entry to be not equal to the provided value.
      *
      * @param key
-     *              The key to be constrained.
+     *         The key to be constrained.
      * @param value
-     *              The object that must not be equaled.
+     *         The object that must not be equaled.
      * @return {@link Query} object, so you can chain this call.
      *
-     *         
- *
- * Example ;
+ *
+ *
+ * Example ;
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.notEqualTo("due_date", "2013-06-25T00:00:00+05:30");
@@ -465,20 +431,19 @@ public Query notEqualTo(@NotNull String key, Object value) {
     }
 
     /**
-     * Add a constraint to the query that requires a particular key's entry to
-     * be contained in the provided array.
+     * Add a constraint to the query that requires a particular key's entry to be contained in the provided array.
      *
      * @param key
-     *               The key to be constrained.
+     *         The key to be constrained.
      * @param values
-     *               The possible values for the key's object.
+     *         The possible values for the key's object.
      * @return {@link Query} object, so you can chain this call. 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.containedIn("severity", new Object[] { "Show Stopper", "Critical" });
@@ -504,22 +469,21 @@ public Query containedIn(@NotNull String key, Object[] values) {
     }
 
     /**
-     * Add a constraint to the query that requires a particular key entry's
-     * value not be contained in the provided
+     * Add a constraint to the query that requires a particular key entry's value not be contained in the provided
      * array.
      *
      * @param key
-     *               The key to be constrained.
+     *         The key to be constrained.
      * @param values
-     *               The list of values the key object should not be.
+     *         The list of values the key object should not be.
      * @return {@link Query} object, so you can chain this call.
      *
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.notContainedIn("severity", new Object[] { "Show Stopper", "Critical" });
@@ -548,14 +512,14 @@ public Query notContainedIn(@NotNull String key, Object[] values) {
      * Add a constraint that requires, a specified key exists in response.
      *
      * @param key
-     *            The key to be constrained.
+     *         The key to be constrained.
      * @return {@link Query} object, so you can chain this call.
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.exists("status");
@@ -579,15 +543,15 @@ public Query exists(@NotNull String key) {
      * Add a constraint that requires, a specified key does not exists in response.
      *
      * @param key
-     *            The key to be constrained.
+     *         The key to be constrained.
      * @return {@link Query} object, so you can chain this call. 
* * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.notExists("status");
@@ -612,14 +576,14 @@ public Query notExists(@NotNull String key) {
      * Add a constraint that requires a particular reference key details.
      *
      * @param key
-     *            key that to be constrained.
+     *         key that to be constrained.
      * @return {@link Query} object, so you can chain this call.
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.includeReference("for_bug");
@@ -637,14 +601,14 @@ public Query includeReference(String key) {
      * Include tags with which to search entries.
      *
      * @param tags
-     *             Comma separated array of tags with which to search entries.
+     *         Comma separated array of tags with which to search entries.
      * @return {@link Query} object, so you can chain this call. 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.tags(new String[] { "tag1", "tag2" });
@@ -661,19 +625,18 @@ public Query tags(@NotNull String[] tags) {
     }
 
     /**
-     * Sort the results in ascending order with the given key. 
- * Sort the returned entries in ascending order of the + * Sort the results in ascending order with the given key.
Sort the returned entries in ascending order of the * provided key. * * @param key - * The key to order by. + * The key to order by. * @return {@link Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.ascending("name");
@@ -686,19 +649,18 @@ public Query ascending(@NotNull String key) {
     }
 
     /**
-     * Sort the results in descending order with the given key. 
- * Sort the returned entries in descending order of + * Sort the results in descending order with the given key.
Sort the returned entries in descending order of * the provided key. * * @param key - * The key to order by. + * The key to order by. * @return {@link Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.descending("name");
@@ -710,19 +672,18 @@ public Query descending(@NotNull String key) {
     }
 
     /**
-     * Specifies list of field uids that would be 'excluded' from the
-     * response.
+     * Specifies list of field uids that would be 'excluded' from the response.
      *
      * @param fieldUid
-     *                 field uid which get 'excluded' from the response.
+     *         field uid which get 'excluded' from the response.
      * @return {@link Query} object, so you can chain this call.
      *
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* ArrayList<String> array = new ArrayList<String>(); @@ -744,18 +705,17 @@ public Query except(@NotNull ArrayList fieldUid) { } /** - * Specifies list of field uids that would be 'excluded' from the - * response. + * Specifies list of field uids that would be 'excluded' from the response. * * @param fieldIds - * field uid which get 'excluded' from the response. + * field uid which get 'excluded' from the response. * @return {@link Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* csQuery.except(new String[]{"name", "description"}); @@ -774,19 +734,17 @@ public Query except(@NotNull String[] fieldIds) { } /** - * Specifies an array of 'only' keys in BASE object that would be - * 'included' in the response. + * Specifies an array of 'only' keys in BASE object that would be 'included' in the response. * * @param fieldUid - * Array of the 'only' reference keys to be included in - * response. + * Array of the 'only' reference keys to be included in response. * @return {@link Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* csQuery.only(new String[]{"name"}); @@ -805,22 +763,20 @@ public Query only(@NotNull String[] fieldUid) { } /** - * Specifies an array of 'only' keys that would be 'included' in - * the response. + * Specifies an array of 'only' keys that would be 'included' in the response. * * @param fieldUid - * Array of the 'only' reference keys to be - * included in response. + * Array of the 'only' reference keys to be included in response. * @param referenceFieldUid - * Key who has reference to some other class object. + * Key who has reference to some other class object. * @return {@link Query} object, so you can chain this call.
* * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* ArrayList<String> array = new ArrayList<String>(); @@ -846,21 +802,19 @@ public Query onlyWithReferenceUid(@NotNull ArrayList fieldUid, @NotNull } /** - * Specifies an array of 'except' keys that would be 'excluded' - * in the response. + * Specifies an array of 'except' keys that would be 'excluded' in the response. * * @param fieldUid - * Array of the 'except' reference keys to be - * excluded in response. + * Array of the 'except' reference keys to be excluded in response. * @param referenceFieldUid - * Key who has reference to some other class object. + * Key who has reference to some other class object. * @return {@link Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* ArrayList<String> array = new ArrayList<String>(); @@ -888,15 +842,14 @@ public Query exceptWithReferenceUid(@NotNull ArrayList fieldUid, @NotNul /** * Retrieve only count of entries in result. * - * @return {@link Query} object, so you can chain this call. Note :- - * Call {@link QueryResult#getCount()} - * method in the success to get count of objects.
+ * @return {@link Query} object, so you can chain this call. Note :- Call {@link QueryResult#getCount()} + * method in the success to get count of objects.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* csQuery.count(); @@ -910,15 +863,14 @@ public Query count() { /** * Retrieve count and data of objects in result * - * @return {@link Query} object, so you can chain this call. Note :- - * Call {@link QueryResult#getCount()} - * method in the success to get count of objects.
+ * @return {@link Query} object, so you can chain this call. Note :- Call {@link QueryResult#getCount()} + * method in the success to get count of objects.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* csQuery.includeCount(); @@ -934,11 +886,11 @@ public Query includeCount() { * * @return {@link Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* csQuery.includeContentType(); @@ -953,42 +905,22 @@ public Query includeContentType() { return this; } - /** - * Include object owner's profile in the objects data. - * - * @return {@linkplain Query} object, so you can chain this call.
- * - *
- *
- * Example :
- * - *
-     *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
-     *          Query csQuery = stack.contentType("contentTypeUid").query();
- * csQuery.includeOwner(); - *
- */ - public Query includeOwner() { - urlQueries.put("include_owner", true); - return this; - } /** * The number of objects to skip before returning any. * * @param number - * No of objects to skip from returned objects + * No of objects to skip from returned objects * @return {@link Query} object, so you can chain this call. - *

- * Note: The skip parameter can be used for pagination, - * "skip" specifies the number of objects to skip in the - * response.
+ *

+ * Note: The skip parameter can be used for pagination, + * "skip" specifies the number of objects to skip in the response.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *

+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* csQuery.skip(2); @@ -1003,18 +935,17 @@ public Query skip(int number) { * A limit on the number of objects to return. * * @param number - * No of objects to limit. + * No of objects to limit. * @return {@link Query} object, so you can chain this call. - *

- * Note: The limit parameter can be used for pagination, " - * limit" specifies the number of objects to limit to in the - * response.
+ *

+ * Note: The limit parameter can be used for pagination, " + * limit" specifies the number of objects to limit to in the response.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *

+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query query = stack.contentType("contentTypeUid").query();
* query.limit(2); @@ -1026,21 +957,20 @@ public Query limit(int number) { } /** - * Add a regular expression constraint for finding string values that match the - * provided regular expression. This + * Add a regular expression constraint for finding string values that match the provided regular expression. This * may be slow for large data sets. * * @param key - * The key to be constrained. + * The key to be constrained. * @param regex - * The regular expression pattern to match. + * The regular expression pattern to match. * @return {@link Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query query = stack.contentType("contentTypeUid").query();
* query.regex("name", "^browser"); @@ -1062,32 +992,31 @@ public Query regex(@NotNull String key, @NotNull String regex) { } /** - * Add a regular expression constraint for finding string values that match the - * provided regular expression. This + * Add a regular expression constraint for finding string values that match the provided regular expression. This * may be slow for large data sets. * * @param key - * The key to be constrained. + * The key to be constrained. * @param regex - * The regular expression pattern to match + * The regular expression pattern to match * @param modifiers - * Any of the following supported Regular expression modifiers. - *

- * use i for case-insensitive matching. - *

- *

- * use m for making dot match newlines. - *

- *

- * use x for ignoring whitespace in regex - *

+ * Any of the following supported Regular expression modifiers. + *

+ * use i for case-insensitive matching. + *

+ *

+ * use m for making dot match newlines. + *

+ *

+ * use x for ignoring whitespace in regex + *

* @return {@link Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query query = stack.contentType("contentTypeUid").query();
* query.regex("name", "^browser", "i"); @@ -1122,13 +1051,13 @@ public Query regex(@NotNull String key, @NotNull String regex, String modifiers) * set Language using locale code. * * @param locale - * {@link String} value + * {@link String} value * @return {@link Query} object, so you can chain this call
- *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query query = stack.contentType("contentTypeUid").query();
* query.locale("en-us"); @@ -1143,14 +1072,14 @@ public Query locale(@NotNull String locale) { * This method provides only the entries matching the specified value. * * @param value - * value used to match or compare + * value used to match or compare * @return {@link Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query query = stack.contentType("contentTypeUid").query();
* query.search("header"); @@ -1168,16 +1097,15 @@ public Query search(@NotNull String value) { * Execute a Query and Caches its result (Optional) * * @param callback - * {@link QueryResultsCallBack} object to notify the application - * when the request has completed. + * {@link QueryResultsCallBack} object to notify the application when the request has completed. * @return {@linkplain Query} object, so you can chain this call.
* * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query query = stack.contentType("contentTypeUid").query();
* query.find(new QueryResultsCallBack() {
@@ -1208,15 +1136,14 @@ public Query find(QueryResultsCallBack callback) { * Execute a Query and Caches its result (Optional) * * @param callBack - * {@link QueryResultsCallBack} object to notify the application - * when the request has completed. + * {@link QueryResultsCallBack} object to notify the application when the request has completed. * @return {@linkplain Query} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* csQuery.findOne(new QueryResultsCallBack() {
@@ -1314,7 +1241,7 @@ private void includeLivePreview() { // fetch from network. private void fetchFromNetwork(String urlString, JSONObject jsonMain, ResultCallBack callback, - SingleQueryResultCallback resultCallback) { + SingleQueryResultCallback resultCallback) { LinkedHashMap urlParams = getUrlParams(jsonMain); if (resultCallback != null) { new CSBackgroundTask(this, contentTypeInstance.stackInstance, Constants.SINGLEQUERYOBJECT, urlString, @@ -1387,16 +1314,16 @@ public void getResultObject(List objects, JSONObject jsonObject, boolean * This method adds key and value to an Entry. Parameters: * * @param paramKey: - * The key as string which needs to be added to the Query + * The key as string which needs to be added to the Query * @param paramValue: - * The value as string which needs to be added to the Query + * The value as string which needs to be added to the Query * @return - Query * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.addParam("key", "some_value");
@@ -1413,16 +1340,15 @@ public Query addParam(@NotNull String paramKey, @NotNull String paramValue) {
     }
 
     /**
-     * This method also includes the content type UIDs of the referenced entries
-     * returned in the response
+     * This method also includes the content type UIDs of the referenced entries returned in the response
      *
      * @return {@link Query} 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
* csQuery.includeReferenceContentTypUid(); @@ -1439,21 +1365,20 @@ public Query includeReferenceContentTypUid() { } /** - * Get entries having values based on referenced fields. This query retrieves - * all entries that satisfy the query + * Get entries having values based on referenced fields. This query retrieves all entries that satisfy the query * conditions made on referenced fields. * * @param key - * The key to be constrained + * The key to be constrained * @param queryObject - * {@link Query} object, so you can chain this call + * {@link Query} object, so you can chain this call * @return {@link Query} object, so you can chain this call
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.whereIn("due_date", csQuery);
@@ -1467,21 +1392,20 @@ public Query whereIn(@NotNull String key, Query queryObject) {
     }
 
     /**
-     * Get entries having values based on referenced fields. This query works the
-     * opposite of $in_query and retrieves
+     * Get entries having values based on referenced fields. This query works the opposite of $in_query and retrieves
      * all entries that does not satisfy query conditions made on referenced fields.
      *
      * @param key
-     *                    The key to be constrained
+     *         The key to be constrained
      * @param queryObject
-     *                    {@link Query} object, so you can chain this call
+     *         {@link Query} object, so you can chain this call
      * @return {@link Query} object, so you can chain this call
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.whereNotIn("due_date", csQuery);
@@ -1495,16 +1419,15 @@ public Query whereNotIn(@NotNull String key, Query queryObject) {
     }
 
     /**
-     * Retrieve the published content of the fallback locale if an entry is not
-     * localized in specified locale
+     * Retrieve the published content of the fallback locale if an entry is not localized in specified locale
      *
      * @return {@link Query} object, so you can chain this call. 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", environment);
      *         Query csQuery = stack.contentType("contentTypeUid").query();
      *         csQuery.includeFallback();
@@ -1519,11 +1442,11 @@ public Query includeFallback() {
      * @return {@link Query} object, so you can chain this call. 
* @return {@link Query} * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", environment);
      *         Query query = stack.contentType("contentTypeUid").query();
      *         query.includeEmbeddedObjects()
@@ -1539,11 +1462,11 @@ public Query includeEmbeddedItems() {
      *
      * @return {@link Query} object, so you can chain this call. 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query query = stack.contentType("contentTypeUid").query();
      *         entry.includeBranch();
diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java
index 69f0b593..b1a73f35 100644
--- a/src/main/java/com/contentstack/sdk/Stack.java
+++ b/src/main/java/com/contentstack/sdk/Stack.java
@@ -64,7 +64,6 @@ protected void setConfig(Config config) {
         includeLivePreview();
         String endpoint = config.scheme + config.host;
         this.config.setEndpoint(endpoint);
-
         client(endpoint);
     }
 
@@ -106,12 +105,14 @@ private void includeLivePreview() {
      * 

* Example *

- *

* stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); *

* HashMap queryMap = new HashMap(); *

* stack.livePreviewQuery(queryMap) + *

+ * @throws IOException + * IO Exception */ public Stack livePreviewQuery(Map query) throws IOException { config.livePreviewHash = query.get(LIVE_PREVIEW); @@ -372,10 +373,10 @@ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallB *
* Example :
*

-     *                                                                                                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                                     stack.syncToken("syncToken")
-     *                                                                                                                                                                                                                                                                                                                                                                                                                             stack.syncToken(sync_token, new SyncResultCallBack()                                                                                                                                                                                                               ){ }
-     *                                                                                                                                                                                                                                                                                                                                                                                                                             
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncToken("syncToken") + * stack.syncToken(sync_token, new SyncResultCallBack() ){ } + *
*/ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { this.sync(null); @@ -397,7 +398,6 @@ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { * Example :
* Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); * stack.syncFromDate("fromDate") - *
*/ public void syncFromDate(@NotNull Date fromDate, SyncResultCallBack syncCallBack) { String newFromDate = convertUTCToISO(fromDate); @@ -427,7 +427,6 @@ protected String convertUTCToISO(Date date) { *
* Example : *

- *

* stack.syncContentType(String content_type, new SyncResultCallBack()){ } */ public void syncContentType(@NotNull String contentType, SyncResultCallBack syncCallBack) { @@ -477,10 +476,9 @@ public void syncLocale(String localeCode, SyncResultCallBack syncCallBack) { *
* Example :
*

-     *                                                                                                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                                     stack.syncPublishType(PublishType)
-     *                                                                                                                                                                                                                                                                                                                                                                                                                             stackInstance.syncPublishType(Stack.PublishType.entry_published, new SyncResultCallBack()) { }
-     *                                                                                                                                                                                                                                                                                                                                                                                                                             
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncPublishType(PublishType) + *
*/ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCallBack) { this.sync(null); From da0011e8552eb3812f5c4e47989a28e6dfec446a Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Tue, 24 Jan 2023 16:06:20 +0530 Subject: [PATCH 034/104] sca-scan.yml --- .github/workflows/sca-scan.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/sca-scan.yml b/.github/workflows/sca-scan.yml index 8485c342..2de23956 100644 --- a/.github/workflows/sca-scan.yml +++ b/.github/workflows/sca-scan.yml @@ -11,3 +11,5 @@ jobs: uses: snyk/actions/maven@master env: SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} + with: + args: --fail-on=all From b4b6a647005549e3b5e1d015176c72c10aa228f3 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Tue, 24 Jan 2023 16:06:31 +0530 Subject: [PATCH 035/104] jira.yml From c15b29c34a0321b831c477d5ef5e3bbff4d44a8a Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Tue, 24 Jan 2023 16:06:32 +0530 Subject: [PATCH 036/104] codeql-analysis.yml From 8c418fd5d47f884d218cb206482ba5e77efb6c90 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Tue, 24 Jan 2023 16:06:33 +0530 Subject: [PATCH 037/104] sast-scan.yml From d2b157438c17d189f38a98e54e5a53bc96be8776 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Tue, 24 Jan 2023 16:06:34 +0530 Subject: [PATCH 038/104] secrets-scan.yml From c27211b2a7c59aa62d31759f205bff6d6db5e468 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Tue, 7 Feb 2023 00:18:29 +0530 Subject: [PATCH 039/104] :potted_plant: #67 error handling infinite loop issue --- pom.xml | 7 +- src/main/java/com/contentstack/sdk/Asset.java | 1 - .../com/contentstack/sdk/AssetLibrary.java | 35 +- .../java/com/contentstack/sdk/Config.java | 12 +- .../java/com/contentstack/sdk/Constants.java | 101 +++--- .../sdk/ContentTypesCallback.java | 3 + .../contentstack/sdk/ContentTypesModel.java | 3 + .../contentstack/sdk/ContentstackPlugin.java | 7 +- src/main/java/com/contentstack/sdk/Entry.java | 229 ++++--------- src/main/java/com/contentstack/sdk/Group.java | 217 ++++++------ src/main/java/com/contentstack/sdk/Query.java | 122 +++---- .../com/contentstack/sdk/QueryResult.java | 102 +++--- .../sdk/QueryResultsCallBack.java | 3 + src/main/java/com/contentstack/sdk/Stack.java | 41 ++- .../contentstack/sdk/SyncResultCallBack.java | 3 + .../java/com/contentstack/sdk/SyncStack.java | 1 + src/main/java/com/contentstack/sdk/Utils.java | 67 ---- .../com/contentstack/sdk/package-info.java | 5 + src/main/overview.html | 208 +++++++++++ .../java/com/contentstack/sdk/TestAsset.java | 11 +- .../contentstack/sdk/TestAssetLibrary.java | 4 +- .../com/contentstack/sdk/TestAzureRegion.java | 8 +- .../java/com/contentstack/sdk/TestConfig.java | 11 +- .../contentstack/sdk/TestContentstack.java | 1 - .../sdk/TestContentstackPlugin.java | 7 +- .../java/com/contentstack/sdk/TestEntry.java | 323 +++++++++++++++--- .../com/contentstack/sdk/TestLivePreview.java | 7 +- .../java/com/contentstack/sdk/TestQuery.java | 103 +++--- .../com/contentstack/sdk/TestQueryCase.java | 213 +++++++----- 29 files changed, 1078 insertions(+), 777 deletions(-) delete mode 100644 src/main/java/com/contentstack/sdk/Utils.java create mode 100644 src/main/java/com/contentstack/sdk/package-info.java create mode 100644 src/main/overview.html diff --git a/pom.xml b/pom.xml index 21c8af3c..0ae2b4c2 100644 --- a/pom.xml +++ b/pom.xml @@ -24,7 +24,7 @@ 3.1.5 2.9.0 2.9.0 - 4.10.0 + 4.9.2 0.8.5 1.18.24 5.9.1 @@ -197,7 +197,8 @@ - + + org.apache.maven.plugins maven-javadoc-plugin @@ -279,7 +280,7 @@ org.sonatype.plugins nexus-staging-maven-plugin - ${nexus-staging-maven-plugin-version} + ${nexus-staging-maven-plugin.version} true ossrh diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index 30a0b0fb..a94f2efa 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -102,7 +102,6 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * @param headerKey * the header key * - * *
*
* Example :
diff --git a/src/main/java/com/contentstack/sdk/AssetLibrary.java b/src/main/java/com/contentstack/sdk/AssetLibrary.java index 5b4dfd6b..9a66504e 100644 --- a/src/main/java/com/contentstack/sdk/AssetLibrary.java +++ b/src/main/java/com/contentstack/sdk/AssetLibrary.java @@ -10,7 +10,9 @@ import static com.contentstack.sdk.Constants.ENVIRONMENT; /** - * The type Asset library. + * The Asset library is used to get list of assets available in the stack, We can apply filters on the assets also. + * The Get all assets request fetches the list of all the assets of a particular stack. It returns the content of each + * asset in JSON format. */ public class AssetLibrary implements INotifyClass { @@ -34,8 +36,10 @@ protected void setStackInstance(@NotNull Stack stack) { /** * Sets header. * - * @param headerKey the header key - * @param headerValue the header value + * @param headerKey + * the header key + * @param headerValue + * the header value */ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { this.headers.put(headerKey, headerValue); @@ -44,7 +48,8 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { /** * Remove header. * - * @param headerKey the header key + * @param headerKey + * the header key */ public void removeHeader(@NotNull String headerKey) { if (!headerKey.isEmpty()) { @@ -55,8 +60,10 @@ public void removeHeader(@NotNull String headerKey) { /** * Sort asset library. * - * @param keyOrderBy the key order by - * @param orderby the orderby + * @param keyOrderBy + * the key order by + * @param orderby + * the orderby * @return the asset library */ public AssetLibrary sort(String keyOrderBy, ORDERBY orderby) { @@ -89,14 +96,13 @@ public AssetLibrary includeRelativeUrl() { } /** - * Retrieve the published content of the fallback locale if an entry is not - * localized in specified locale + * Retrieve the published content of the fallback locale if an entry is not localized in specified locale * * @return {@link AssetLibrary} object, so you can chain this call.
- *
- * Example :
- * - *
+     * 
+ * Example :
+ * + *
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         AssetLibrary assetLibObject = stack.assetLibrary();
      *         AssetLibrary.includeFallback();
@@ -119,7 +125,8 @@ public int getCount() {
     /**
      * Fetch all.
      *
-     * @param callback the callback
+     * @param callback
+     *         the callback
      */
     public void fetchAll(FetchAssetsCallback callback) {
         this.callback = callback;
@@ -128,7 +135,7 @@ public void fetchAll(FetchAssetsCallback callback) {
     }
 
     private void fetchFromNetwork(String url, JSONObject urlQueries, LinkedHashMap headers,
-            FetchAssetsCallback callback) {
+                                  FetchAssetsCallback callback) {
         if (callback != null) {
             HashMap urlParams = getUrlParams(urlQueries);
             new CSBackgroundTask(this, stackInstance, Constants.FETCHALLASSETS, url, headers, urlParams,
diff --git a/src/main/java/com/contentstack/sdk/Config.java b/src/main/java/com/contentstack/sdk/Config.java
index d7d99d7e..48cbcf1a 100644
--- a/src/main/java/com/contentstack/sdk/Config.java
+++ b/src/main/java/com/contentstack/sdk/Config.java
@@ -5,12 +5,13 @@
 import org.json.JSONObject;
 
 import java.net.Proxy;
-import java.util.ArrayList;
+import java.util.List;
 import java.util.concurrent.TimeUnit;
 
 
 /**
- * The type Config. enables optional parameters while passing from stack
+ * The Config enables optional parameters while passing from stack. You can set different configs params to the stack
+ * like host, version, livePreview, endpoint, region, branch etc
  */
 public class Config {
 
@@ -30,7 +31,7 @@ public class Config {
     protected Proxy proxy = null;
     protected ConnectionPool connectionPool = new ConnectionPool();
 
-    protected ArrayList plugins = null;
+    protected List plugins = null;
 
     public String getBranch() {
         return branch;
@@ -110,12 +111,11 @@ protected String getEndpoint() {
         return endpoint + "/" + getVersion() + "/";
     }
 
-    protected String setEndpoint(@NotNull String endpoint) {
+    protected void setEndpoint(@NotNull String endpoint) {
         this.endpoint = endpoint;
-        return this.endpoint;
     }
 
-    public void setPlugins(ArrayList plugins) {
+    public void setPlugins(List plugins) {
         this.plugins = plugins;
     }
 
diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java
index da8cae0e..c7de78a6 100644
--- a/src/main/java/com/contentstack/sdk/Constants.java
+++ b/src/main/java/com/contentstack/sdk/Constants.java
@@ -1,9 +1,14 @@
 package com.contentstack.sdk;
 
-import java.text.ParseException;
-import java.text.SimpleDateFormat;
-import java.util.*;
-import java.util.logging.Level;
+import org.jetbrains.annotations.NotNull;
+
+import java.time.Instant;
+import java.time.LocalDateTime;
+import java.time.ZoneId;
+import java.time.ZonedDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.Calendar;
+import java.util.TimeZone;
 import java.util.logging.Logger;
 
 /**
@@ -16,7 +21,7 @@
 public class Constants {
 
     private static final Logger logger = Logger.getLogger(Constants.class.getSimpleName());
-    protected static final String SDK_VERSION = "1.10.1";
+    protected static final String SDK_VERSION = "1.10.2";
     protected static final String ENVIRONMENT = "environment";
     protected static final String CONTENT_TYPE_UID = "content_type_uid";
     protected static final String ENTRY_UID = "entry_uid";
@@ -66,71 +71,53 @@ public enum REQUEST_CONTROLLER {
     public static final String QUERY_EXCEPTION = "Please provide valid params.";
 
 
-
     /**
-     * Parse date calendar.
-     *
-     * @param date
-     *                 the date
-     * @param timeZone
-     *                 the time zone
-     * @return the calendar
+     * @param dateString
+     *         the date in string format
+     * @param zoneId
+     *         the string zoneId
+     * @return Calendar
      */
-    public static Calendar parseDate(String date, TimeZone timeZone) {
-        ArrayList knownPatterns = new ArrayList<>();
-        knownPatterns.add("yyyy-MM-dd'T'HH:mm:ssZ");
-        knownPatterns.add("yyyy-MM-dd'T'HH:mm:ss'Z'");
-        knownPatterns.add("yyyy-MM-dd'T'HH:mm.ss'Z'");
-        knownPatterns.add("yyyy-MM-dd'T'HH:mmZ");
-        knownPatterns.add("yyyy-MM-dd'T'HH:mm'Z'");
-        knownPatterns.add("yyyy-MM-dd'T'HH:mm'Z'");
-        knownPatterns.add("yyyy-MM-dd'T'HH:mm:ss");
-        knownPatterns.add("yyyy-MM-dd' 'HH:mm:ss");
-        knownPatterns.add("yyyy-MM-dd");
-        knownPatterns.add("HH:mm:ssZ");
-        knownPatterns.add("HH:mm:ss'Z'");
-
-        for (String formatString : knownPatterns) {
-            try {
-                return parseDate(date, formatString, timeZone);
-            } catch (ParseException e) {
-                logger.log(Level.WARNING, e.getLocalizedMessage(), e);
-            }
-        }
-        return null;
+    public static Calendar parseDateToTimeZone(@NotNull String dateString, @NotNull String zoneId) {
+        //String dateString = "2016-12-16T12:36:33.961Z";
+        Instant instant = Instant.parse(dateString);
+        // Define the target time zone
+        ZoneId targetTimeZone = ZoneId.of(zoneId);
+        // Convert the instant to the target time zone
+        ZonedDateTime dateTime = instant.atZone(targetTimeZone);
+        // Extract the year, month, day, hour, minute, and second
+        Calendar cal = Calendar.getInstance();
+        cal.set(dateTime.getYear(), dateTime.getMonthValue(), dateTime.getDayOfMonth(), dateTime.getHour(), dateTime.getMinute(), dateTime.getSecond());
+        return cal;
+    }
+
+    private static Calendar toCalendar(@NotNull String date) {
+        DateTimeFormatter formatter = DateTimeFormatter.ISO_DATE_TIME;
+        LocalDateTime dt = LocalDateTime.parse(date, formatter);
+        Calendar cal = Calendar.getInstance();
+        cal.set(dt.getYear(), dt.getMonthValue(), dt.getDayOfMonth(), dt.getHour(), dt.getMinute(), dt.getSecond());
+        return cal;
     }
 
+
     /**
-     * Parse date calendar.
-     *
      * @param date
-     *                   the date
-     * @param dateFormat
-     *                   the date format
+     *         The date in string format like (String dateString = "2016-12-16T12:36:33.961Z";)
      * @param timeZone
-     *                   the time zone
-     * @return the calendar
-     * @throws ParseException
-     *                        the parse exception
+     *         the time zone as string
+     * @return calendar @{@link Calendar}
      */
-    public static Calendar parseDate(String date, String dateFormat, TimeZone timeZone) throws ParseException {
-        Calendar cal = Calendar.getInstance();
-        SimpleDateFormat dateFormatter = new SimpleDateFormat(dateFormat);
-        Date dateObject = dateFormatter.parse(date);
-        String month = new SimpleDateFormat("MM").format(dateObject);
-        String day = new SimpleDateFormat("dd").format(dateObject);
-        String year = new SimpleDateFormat("yyyy").format(dateObject);
-        String hourOfDay = new SimpleDateFormat("HH").format(dateObject);
-        String min = new SimpleDateFormat("mm").format(dateObject);
-        String sec = new SimpleDateFormat("ss").format(dateObject);
-
+    public static Calendar parseDate(@NotNull String date, TimeZone timeZone) {
+        // Use the ISO-8601 format to parse the date string
+        if (date.isEmpty()){
+            return null;
+        }
+        Calendar cal = toCalendar(date);
         if (timeZone != null) {
             cal.setTimeZone(timeZone);
         } else {
             cal.setTimeZone(TimeZone.getDefault());
         }
-        cal.set(Integer.parseInt(year), Integer.parseInt(month) - 1, Integer.parseInt(day), Integer.parseInt(hourOfDay),
-                Integer.parseInt(min), Integer.parseInt(sec));
         return cal;
     }
 
diff --git a/src/main/java/com/contentstack/sdk/ContentTypesCallback.java b/src/main/java/com/contentstack/sdk/ContentTypesCallback.java
index ebd294c6..ff1c96af 100755
--- a/src/main/java/com/contentstack/sdk/ContentTypesCallback.java
+++ b/src/main/java/com/contentstack/sdk/ContentTypesCallback.java
@@ -1,5 +1,8 @@
 package com.contentstack.sdk;
 
+/**
+ * The callback for Content Types that contains ContentTypesModel and Error
+ */
 public abstract class ContentTypesCallback implements ResultCallBack {
 
     public abstract void onCompletion(ContentTypesModel contentTypesModel, Error error);
diff --git a/src/main/java/com/contentstack/sdk/ContentTypesModel.java b/src/main/java/com/contentstack/sdk/ContentTypesModel.java
index 5df5d336..edfe2c1c 100644
--- a/src/main/java/com/contentstack/sdk/ContentTypesModel.java
+++ b/src/main/java/com/contentstack/sdk/ContentTypesModel.java
@@ -3,6 +3,9 @@
 import org.json.JSONArray;
 import org.json.JSONObject;
 
+/**
+ * The ContentTypesModel that contains content type response
+ */
 public class ContentTypesModel {
 
     private Object response;
diff --git a/src/main/java/com/contentstack/sdk/ContentstackPlugin.java b/src/main/java/com/contentstack/sdk/ContentstackPlugin.java
index 2cdbad3b..3c6dfa8f 100644
--- a/src/main/java/com/contentstack/sdk/ContentstackPlugin.java
+++ b/src/main/java/com/contentstack/sdk/ContentstackPlugin.java
@@ -6,7 +6,10 @@
 
 public interface ContentstackPlugin {
 
-    void onRequest(Stack stack, Request request);
+    default void onRequest(Stack stack, Request request) {
+    }
 
-    Response onResponse(Stack stack, Request request, Response response);
+    default Response onResponse(Stack stack, Request request, Response response) {
+        return response;
+    }
 }
diff --git a/src/main/java/com/contentstack/sdk/Entry.java b/src/main/java/com/contentstack/sdk/Entry.java
index 0dfcba72..59e70c1e 100644
--- a/src/main/java/com/contentstack/sdk/Entry.java
+++ b/src/main/java/com/contentstack/sdk/Entry.java
@@ -1,9 +1,9 @@
 package com.contentstack.sdk;
 
 import org.jetbrains.annotations.NotNull;
+import org.jetbrains.annotations.Nullable;
 import org.json.JSONArray;
 import org.json.JSONObject;
-import retrofit2.Retrofit;
 
 import java.util.*;
 import java.util.logging.Level;
@@ -11,12 +11,21 @@
 
 import static com.contentstack.sdk.Constants.ENVIRONMENT;
 
+/**
+ * The Get a single
+ * Entry request
+ * fetches a particular entry of a content type.
+ *
+ * @author Shailesh Mishra
+ * @version 1.0.0
+ * @since 01-11-2017
+ */
 public class Entry {
 
     protected static final Logger logger = Logger.getLogger(Entry.class.getSimpleName());
     protected JSONObject params;
     protected LinkedHashMap headers = null;
-    protected HashMap owner = null;
+
     protected String uid = null;
     protected JSONObject publishDetails;
     protected JSONObject resultJson = null;
@@ -32,7 +41,6 @@ public class Entry {
     protected JSONObject onlyJsonObject;
     protected JSONObject exceptJsonObject;
     protected String rteContent = null;
-    protected Retrofit retrofit;
 
     protected Entry() throws IllegalAccessException {
         throw new IllegalAccessException("Can Not Access Private Modifier");
@@ -72,10 +80,7 @@ public Entry configure(JSONObject jsonObject) {
      *         Example :
* *
-     *                                                                                      Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                                                      Entry entry = stack.contentType("form_name").entry("entry_uid");
-     *                                                                                      entry.setHeader("custom_header_key", "custom_header_value");
-     *                                                                                      
+ *
*/ public void setHeader(String key, String value) { @@ -93,10 +98,10 @@ public void setHeader(String key, String value) { * Example :
* *
-     *                                                                                    Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                                                    Entry entry = stack.contentType("form_name").entry("entry_uid");
-     *                                                                                    entry.removeHeader("custom_header_key");
-     *                                                                                    
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid"); + * entry.removeHeader("custom_header_key"); + *
*/ public void removeHeader(String key) { @@ -214,15 +219,10 @@ public Entry setLocale(@NotNull String locale) { return this; } - @Deprecated - public Map getOwner() { - return owner; - } - /** * Get entry representation in json * - * @return JSONObject @resultJson
+ * @return resultJson
*
* Example :
* @@ -244,8 +244,8 @@ public JSONObject toJSON() { * Example :
* *
-     *                                                                                    Object obj = entry.get("key");
-     *                                                                                    
+ * Object obj = entry.get("key"); + *
* @return Object @resultJson */ public Object get(@NotNull String key) { @@ -261,8 +261,8 @@ public Object get(@NotNull String key) { * Example :
* *
-     *                                                                                    String value = entry.getString("key");
-     *                                                                                    
+ * String value = entry.getString("key"); + *
* @return String @getString */ @@ -283,8 +283,8 @@ public String getString(@NotNull String key) { * Example :
* *
-     *                                                                                    Boolean value = entry.getBoolean("key");
-     *                                                                                    
+ * Boolean value = entry.getBoolean("key"); + *
* @return boolean @getBoolean */ @@ -305,8 +305,8 @@ public Boolean getBoolean(@NotNull String key) { * Example :
* *
-     *                                                                                    JSONArray value = entry.getJSONArray("key");
-     *                                                                                    
+ * JSONArray value = entry.getJSONArray("key"); + *
* @return JSONArray @getJSONArray */ @@ -327,8 +327,8 @@ public JSONArray getJSONArray(@NotNull String key) { * Example :
* *
-     *                                                                                    JSONObject value = entry.getJSONObject("key");
-     *                                                                                    
+ * JSONObject value = entry.getJSONObject("key"); + *
* @return JSONObject @getJSONObject */ public JSONObject getJSONObject(@NotNull String key) { @@ -348,8 +348,8 @@ public JSONObject getJSONObject(@NotNull String key) { * Example :
* *
-     *                                                                                    JSONObject value = entry.getJSONObject("key");
-     *                                                                                    
+ * JSONObject value = entry.getJSONObject("key"); + *
* @return Number @getNumber */ @@ -370,8 +370,8 @@ public Number getNumber(@NotNull String key) { * Example :
* *
-     *                                                                                    int value = entry.getInt("key");
-     *                                                                                    
+ * int value = entry.getInt("key"); + *
* @return int @getInt */ @@ -436,8 +436,8 @@ public double getDouble(@NotNull String key) { * Example :
* *
-     *                                                                                    long value = entry.getLong("key");
-     *                                                                                    
+ * long value = entry.getLong("key"); + *
* @return long @getLong */ @@ -460,8 +460,8 @@ public long getLong(@NotNull String key) { * Example :
* *
-     *                                                                                    short value = entry.getShort("key");
-     *                                                                                    
+ * short value = entry.getShort("key"); + *
* @return short @getShort */ public short getShort(@NotNull String key) { @@ -481,8 +481,8 @@ public short getShort(@NotNull String key) { * Example :
* *
-     *                                                                                    Calendar value = entry.getDate("key");
-     *                                                                                    
+ * Calendar value = entry.getDate("key"); + *
* @return Calendar @getDate */ @@ -664,9 +664,9 @@ public List getAssets(String key) { * Example :
* *
-     *                                                                                     Group innerGroup = entry.getGroup("key");
-     *                                                                                     return null
-     *                                                                                    
+ * Group innerGroup = entry.getGroup("key"); + * return null + *
* @return {@link Group} */ public Group getGroup(String key) { @@ -725,7 +725,7 @@ public List getGroups(String key) { * @Override * public void onCompletion(ResponseType responseType, QueryResult queryResult, Error error) {
* if(error == null){ - * List<Entry> list = builtqueryresult.getResultObjects(); + * List<Entry> list = queryResult.getResultObjects(); * for (int i = 0; i < list.queueSize(); i++) { * Entry entry = list.get(i); * Entry taskEntry = entry.getAllEntries("for_task", "task"); @@ -736,7 +736,7 @@ public List getGroups(String key) { * }
* */ - public ArrayList getAllEntries(String refKey, String refContentType) { + public List getAllEntries(String refKey, String refContentType) { ArrayList entryContainer = new ArrayList<>(); if (resultJson != null) { Object resultArr = resultJson.opt(refKey); @@ -763,19 +763,10 @@ public ArrayList getAllEntries(String refKey, String refContentType) { } /** - * Specifies list of field uids that would be 'excluded' from the response. + * Specifies list of field ids that would be 'excluded' from the response. * * @param fieldUid * field uid which get 'excluded' from the response. - * @return {@link Entry} object, so you can chain this call.
- *
- * Example :
- * - *
-     *          Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *          Entry entry = stack.contentType("form_name").entry("entry_uid");
- * entry.except(new String[]{"name", "description"}); - *
*/ public Entry except(@NotNull String[] fieldUid) { @@ -795,15 +786,6 @@ public Entry except(@NotNull String[] fieldUid) { * * @param referenceField * key that to be constrained. - * @return {@link Entry} object, so you can chain this call.
- *
- * Example :
- * - *
-     *          Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *          Entry entry = stack.contentType("form_name").entry("entry_uid");
- * entry.includeReference("referenceUid"); - *
*/ public Entry includeReference(@NotNull String referenceField) { if (!referenceField.isEmpty()) { @@ -821,15 +803,6 @@ public Entry includeReference(@NotNull String referenceField) { * * @param referenceFields * array key that to be constrained. - * @return {@link Entry} object, so you can chain this call.
- *
- * Example :
- * - *
-     *           Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *          Entry entry = stack.contentType("form_name").entry("entry_uid");
- * entry.includeReference(new String[]{"referenceUid_A", "referenceUid_B"}); - *
*/ public Entry includeReference(@NotNull String[] referenceFields) { if (referenceFields.length > 0) { @@ -877,29 +850,15 @@ public Entry only(String[] fieldUid) { * @param fieldUid * Array of the 'only' reference keys to be included in response. * @param referenceFieldUid - * Key who has reference to some other class object.. - * @return {@link Entry} object, so you can chain this call.
- *
- * Example :
- * - *
-     * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *          Entry entry = stack.contentType("form_name").entry("entry_uid");
- * ArrayList<String> array = new ArrayList<String>(); - * array.add("description"); - * array.add("name"); - * entry.onlyWithReferenceUid(array, "referenceUid"); - *
+ * Key who has reference to some other class object. */ - public Entry onlyWithReferenceUid(@NotNull ArrayList fieldUid, @NotNull String referenceFieldUid) { + public Entry onlyWithReferenceUid(@NotNull List fieldUid, @NotNull String referenceFieldUid) { if (onlyJsonObject == null) { onlyJsonObject = new JSONObject(); } JSONArray fieldValueArray = new JSONArray(); - fieldUid.forEach(field -> { - fieldValueArray.put(field); - }); + fieldUid.forEach(fieldValueArray::put); onlyJsonObject.put(referenceFieldUid, fieldValueArray); includeReference(referenceFieldUid); return this; @@ -912,27 +871,13 @@ public Entry onlyWithReferenceUid(@NotNull ArrayList fieldUid, @NotNull * Array of the 'except' reference keys to be excluded in response. * @param referenceFieldUid * Key who has reference to some other class object. - * @return {@link Entry} object, so you can chain this call. - * - *
- *
- * Example :
- * - *
-     *          Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *          Entry entry = stack.contentType("form_name").entry("entry_uid");
- * ArrayList<String> array = new ArrayList<String>(); - * array.add("description"); - * array.add("name");
- * entry.onlyWithReferenceUid(array, "referenceUid"); - *
*/ - public Entry exceptWithReferenceUid(@NotNull ArrayList fieldUid, @NotNull String referenceFieldUid) { + public Entry exceptWithReferenceUid(@NotNull List fieldUid, @NotNull String referenceFieldUid) { if (exceptJsonObject == null) { exceptJsonObject = new JSONObject(); } JSONArray fieldValueArray = new JSONArray(); - fieldUid.forEach(field -> fieldValueArray.put(field)); + fieldUid.forEach(fieldValueArray::put); exceptJsonObject.put(referenceFieldUid, fieldValueArray); includeReference(referenceFieldUid); return this; @@ -947,16 +892,16 @@ public Entry exceptWithReferenceUid(@NotNull ArrayList fieldUid, @NotNul * Example :
* *
-     *                                                                                         {@code
-     *                                                                                         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                                                         Entry entry = stack.contentType("form_name").entry("entry_uid");
- * entry.fetch(new EntryResultCallBack() {
- * @Override - * public void onCompletion(ResponseType responseType, Error error) { - * }
- * });
- * } - *
+ * {@code + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid");
+ * entry.fetch(new EntryResultCallBack() {
+ * @Override + * public void onCompletion(ResponseType responseType, Error error) { + * }
+ * });
+ * } + * */ public void fetch(EntryResultCallBack callback) { @@ -970,7 +915,6 @@ public void fetch(EntryResultCallBack callback) { String urlString = "content_types/" + contentTypeUid + "/entries/" + uid; JSONObject urlQueries = new JSONObject(); urlQueries.put(ENVIRONMENT, headers.get(ENVIRONMENT)); - includeLivePreview(); fetchFromNetwork(urlString, urlQueries, callback); } @@ -988,25 +932,14 @@ private void fetchFromNetwork(String urlString, JSONObject urlQueries, EntryResu } } - private void includeLivePreview() { - Config configInstance = contentType.stackInstance.config; - if (configInstance.enableLivePreview - && configInstance.livePreviewContentType.equalsIgnoreCase(contentTypeUid)) { - if (configInstance.livePreviewHash == null || configInstance.livePreviewHash.isEmpty()) { - configInstance.livePreviewHash = "init"; - } - // TODO: Do Some calculations, Set a livePreviewFlag - } - } - private LinkedHashMap getUrlParams(JSONObject jsonMain) { JSONObject queryJSON = jsonMain.optJSONObject("query"); LinkedHashMap hashMap = new LinkedHashMap<>(); if (queryJSON != null && queryJSON.length() > 0) { - Iterator iter = queryJSON.keys(); - while (iter.hasNext()) { - String key = iter.next(); + Iterator itr = queryJSON.keys(); + while (itr.hasNext()) { + String key = itr.next(); Object value = queryJSON.opt(key); hashMap.put(key, value); } @@ -1043,7 +976,7 @@ private void setIncludeJSON(JSONObject mainJson, ResultCallBack callBack) { } } - private void throwException(String errorMsg, Exception e, EntryResultCallBack callBack) { + private void throwException(@Nullable String errorMsg, Exception e, EntryResultCallBack callBack) { Error error = new Error(); if (errorMsg != null) { error.setErrorMessage(errorMsg); @@ -1087,24 +1020,6 @@ public Entry addParam(@NotNull String key, @NotNull String value) { /** * This method also includes the content type UIDs of the referenced entries returned in the response - * - * @return {@link Entry} - * - *
- * Example :
- * - *
-     *          {@code
-     *          Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *          final Entry entry = stack.contentType("user").entry("entryUid"); 
- * entry.includeReferenceContentTypeUID;
- * entry.fetch(new EntryResultCallBack() { - *
@Override - * public void onCompletion(ResponseType responseType, Error error) { - * }
- * });
- * } - *
*/ public Entry includeReferenceContentTypeUID() { params.put("include_reference_content_type_uid", "true"); @@ -1113,16 +1028,6 @@ public Entry includeReferenceContentTypeUID() { /** * Include Content Type of all returned objects along with objects themselves. - * - * @return {@link Entry} object, so you can chain this call.
- *
- * Example :
- * - *
-     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *         final Entry entry = stack.contentType("user").entry("entryUid");
-     *         entry.includeContentType();
-     *         
*/ public Entry includeContentType() { params.remove("include_schema"); @@ -1152,16 +1057,6 @@ public Entry includeFallback() { /** * includeEmbeddedItems instance of Entry Include Embedded Objects (Entries and Assets) along with entry/entries * details.
- * - * @return {@link Entry} object, so you can chain this call.
- *
- * Example :
- * - *
-     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *         final Entry entry = stack.contentType("user").entry("entryUid");
-     *         entry.includeEmbeddedItems();
-     *         
*/ public Entry includeEmbeddedItems() { params.put("include_embedded_items[]", "BASE"); diff --git a/src/main/java/com/contentstack/sdk/Group.java b/src/main/java/com/contentstack/sdk/Group.java index eddd8ca5..8ddb4efd 100644 --- a/src/main/java/com/contentstack/sdk/Group.java +++ b/src/main/java/com/contentstack/sdk/Group.java @@ -9,6 +9,10 @@ import java.util.logging.Level; import java.util.logging.Logger; + +/** + * Group is to get different types of DataType of data fromt the JSON response + */ public class Group { protected static final Logger logger = Logger.getLogger(Group.class.getSimpleName()); @@ -26,10 +30,10 @@ protected Group(Stack stack, JSONObject jsonObject) { * Get group representation in json * * @return JSONObject
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         JSONObject json = group.toJSON();
      *         
*/ @@ -41,12 +45,12 @@ public JSONObject toJSON() { * Get object value for key. * * @param key - * field_uid as key. + * field_uid as key. * @return JSONObject
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         Object obj = group.get("key");
      *         
*/ @@ -62,12 +66,12 @@ public Object get(String key) { * Get string value for key. * * @param key - * field_uid as key. + * field_uid as key. * @return String
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         String value = group.getString("key");
      *         
*/ @@ -83,12 +87,12 @@ public String getString(String key) { * Get boolean value for key. * * @param key - * field_uid as key. + * field_uid as key. * @return boolean true or false
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         Boolean value = group.getBoolean("key");
      *         
*/ @@ -104,12 +108,12 @@ public Boolean getBoolean(String key) { * Get {@link JSONArray} value for key * * @param key - * field_uid as key. + * field_uid as key. * @return JSONArray
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         JSONArray value = group.getJSONArray("key");
      *         
*/ @@ -125,12 +129,12 @@ public JSONArray getJSONArray(String key) { * Get {@link JSONObject} value for key * * @param key - * field_uid as key. + * field_uid as key. * @return JSONObject
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         JSONObject value = group.getJSONObject("key");
      *         
*/ @@ -146,12 +150,12 @@ public JSONObject getJSONObject(String key) { * Get {@link JSONObject} value for key * * @param key - * field_uid as key. + * field_uid as key. * @return Number
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         JSONObject value = group.getJSONObject("key");
      *         
*/ @@ -167,12 +171,12 @@ public Number getNumber(String key) { * Get integer value for key * * @param key - * field_uid as key. + * field_uid as key. * @return int
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         int value = group.getInt("key");
      *         
*/ @@ -188,12 +192,12 @@ public int getInt(String key) { * Get integer value for key * * @param key - * field_uid as key. + * field_uid as key. * @return float
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         float value = group.getFloat("key");
      *         
*/ @@ -209,12 +213,12 @@ public float getFloat(String key) { * Get double value for key * * @param key - * field_uid as key. + * field_uid as key. * @return double
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         double value = group.getDouble("key");
      *         
*/ @@ -230,12 +234,12 @@ public double getDouble(String key) { * Get long value for key * * @param key - * field_uid as key. + * field_uid as key. * @return long
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         long value = group.getLong("key");
      *         
*/ @@ -251,12 +255,12 @@ public long getLong(String key) { * Get short value for key * * @param key - * field_uid as key. + * field_uid as key. * @return short
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         short value = group.getShort("key");
      *         
*/ @@ -272,12 +276,12 @@ public short getShort(String key) { * Get {@link Calendar} value for key * * @param key - * field_uid as key. + * field_uid as key. * @return {@link java.util.Date}
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         Calendar value = group.getDate("key");
      *         
*/ @@ -296,12 +300,12 @@ public Calendar getDate(String key) { * Get an asset from the group * * @param key - * field_uid as key. + * field_uid as key. * @return Asset object
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         Asset asset = group.getAsset("key");
      *         
*/ @@ -314,14 +318,14 @@ public Asset getAsset(String key) { * Get an assets from the group. This works with multiple true fields * * @param key - * field_uid as key.
- *
- * Example :
- * - *
-     *                      {@code List asset = group.getAssets("key"); }
-     *                      @return ArrayList of {@link Asset}
-     *                    
+ * field_uid as key.
+ *
+ * Example :
+ * + *
+     *                                                                                                                                      {@code List asset = group.getAssets("key"); }
+     *                                                                                                                                      @return ArrayList of {@link Asset}
+     *                                                                                                                                    
*/ public List getAssets(String key) { List assets = new ArrayList<>(); @@ -339,15 +343,14 @@ public List getAssets(String key) { * Get a group from the group. * * @param key - * field_uid as key.
- *
- * Example :
- * - *
-     *                      Group innerGroup = group.getGroup("key");            @return Group
-     *                 object
-     *            
- * + * field_uid as key.
+ *
+ * Example :
+ *
+     *                                                                                                          Group innerGroup = group.getGroup("key");
+     *                                                                                                          @return Group
+     *                                                                                                          object
+     *                                                                                                          
* @return the group */ public Group getGroup(String key) { @@ -363,14 +366,14 @@ public Group getGroup(String key) { * Note :- This will work when group is multiple true. * * @param key - * field_uid as key.
- *
- * Example :
- * - *
-     *                      Group innerGroup = group.getGroups("key");
-     *                 @return List of {@link Group}
-     *                    
+ * field_uid as key.
+ *
+ * Example :
+ * + *
+     *                                                                                                                                      Group innerGroup = group.getGroups("key");
+     *                                                                                                                                 @return List of {@link Group}
+     *                                                                                                                                    
*/ public List getGroups(String key) { List groupList = new ArrayList<>(); @@ -389,42 +392,44 @@ public List getGroups(String key) { * Get value for the given reference key. * * @param refKey - * key of a reference field. + * key of a reference field. * @param refContentType - * class uid. - * @return {@link ArrayList} of {@link Entry} instances. Also specified - * contentType value will be set as class uid - * for all {@link Entry} instance. + * class uid. + * @return {@link ArrayList} of {@link Entry} instances. Also specified contentType value will be set as class uid + * for all {@link Entry} instance. */ - public ArrayList getAllEntries(String refKey, String refContentType) { + public List getAllEntries(String refKey, String refContentType) { ArrayList entryContainer = new ArrayList<>(); try { - - if (resultJson != null) { - if (resultJson.get(refKey) instanceof JSONArray) { - int count = ((JSONArray) resultJson.get(refKey)).length(); - for (int i = 0; i < count; i++) { - EntryModel model = new EntryModel(((JSONArray) resultJson.get(refKey)).getJSONObject(i)); - Entry entryInstance = null; - try { - entryInstance = stackInstance.contentType(refContentType).entry(); - } catch (Exception e) { - entryInstance = new Entry(refContentType); - logger.log(Level.SEVERE, e.getLocalizedMessage(), e); - } - entryInstance.setUid(model.uid); - entryInstance.resultJson = model.jsonObject; - entryInstance.setTags(model.tags); - entryContainer.add(entryInstance); - } - return entryContainer; + if (resultJson != null && resultJson.get(refKey) instanceof JSONArray) { + JSONArray toArray = ((JSONArray) resultJson.get(refKey)); + for (Object entry : toArray) { + EntryModel model = new EntryModel((JSONObject) entry); + Entry entryInstance = entryInstance(refContentType); + entryInstance.setUid(model.uid); + entryInstance.resultJson = model.jsonObject; + entryInstance.setTags(model.tags); + entryContainer.add(entryInstance); } + return entryContainer; } } catch (Exception e) { - logger.log(Level.SEVERE, e.getLocalizedMessage(), e); return entryContainer; } return entryContainer; } + private Entry entryInstance(String ct) { + Entry entryInstance = null; + try { + entryInstance = stackInstance.contentType(ct).entry(); + } catch (Exception e) { + entryInstance = new Entry(ct); + } + return entryInstance; + } + } + + + diff --git a/src/main/java/com/contentstack/sdk/Query.java b/src/main/java/com/contentstack/sdk/Query.java index e10c1f3b..cfadfce4 100644 --- a/src/main/java/com/contentstack/sdk/Query.java +++ b/src/main/java/com/contentstack/sdk/Query.java @@ -1,6 +1,7 @@ package com.contentstack.sdk; import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; import org.json.JSONArray; import org.json.JSONObject; @@ -73,16 +74,16 @@ protected void setContentTypeInstance(ContentType contentTypeInstance) { *

* tack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment"); Query query = * stack.contentType("contentTypeUid").query(); query.setHeader("custom_key", "custom_value"); - * * Example :
*

* Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment"); Query csQuery = * stack.contentType("contentTypeUid").query(); csQuery.setHeader("custom_key", "custom_value"); */ - public void setHeader(@NotNull String key, @NotNull String value) { + public Query setHeader(@NotNull String key, @NotNull String value) { if (!key.isEmpty() && !value.isEmpty()) { this.headers.put(key, value); } + return this; } /** @@ -95,10 +96,11 @@ public void setHeader(@NotNull String key, @NotNull String value) { * Stack stack = Contentstack..stack( "apiKey", "deliveryToken", "environment"); Query csQuery = * stack.contentType("contentTypeUid").query();
csQuery.removeHeader("custom_key"); */ - public void removeHeader(@NotNull String key) { + public Query removeHeader(@NotNull String key) { if (!key.isEmpty()) { this.headers.remove(key); } + return this; } public String getContentType() { @@ -160,7 +162,7 @@ public Query addQuery(@NotNull String key, String value) { } /** - * Remove provided query key from custom query if exist. + * Remove provided query key from custom query if existed. * * @param key * Query name to remove. @@ -195,20 +197,17 @@ public Query removeQuery(@NotNull String key) { *

      *          Stack stack = Contentstack..stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
-     *
      *          Query query = projectClass.query();
      *          query.where('username','something');
-     *
      *          Query subQuery = projectClass.query();
      *          subQuery.where('email_address','something@email.com');
-     *
      *          ArrayList<Query> array = new ArrayList<Query>();
* array.add(query); * array.add(subQuery);
* projectQuery.and(array); *
*/ - public Query and(@NotNull ArrayList queryObjects) { + public Query and(@NotNull List queryObjects) { if (!queryObjects.isEmpty()) { JSONArray orValueJson = new JSONArray(); queryObjects.forEach(obj -> orValueJson.put(obj.queryValueJSON)); @@ -233,20 +232,17 @@ public Query and(@NotNull ArrayList queryObjects) { *
      *          Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
      *          Query csQuery = stack.contentType("contentTypeUid").query();
-     *
      *          Query query = projectClass.query();
      *          query.where('username','something');
-     *
      *          Query subQuery = projectClass.query();
      *          subQuery.where('email_address','something@email.com');
-     *
      *          ArrayList<Query> array = new ArrayList<Query>();
      *          array.add(query);
      *          array.add(subQuery);
* csQuery.or(array); *
*/ - public Query or(ArrayList queryObjects) { + public Query or(List queryObjects) { if (queryObjects != null && !queryObjects.isEmpty()) { try { JSONArray orValueJson = new JSONArray(); @@ -336,7 +332,7 @@ public Query lessThanOrEqualTo(@NotNull String key, Object value) { * @param key * The key to be constrained. * @param value - * The value that provides an lower bound. + * The value that provides a lower bound. * @return {@link Query} object, so you can chain this call. * *
@@ -370,7 +366,7 @@ public Query greaterThan(@NotNull String key, Object value) { * @param key * The key to be constrained. * @param value - * The value that provides an lower bound. + * The value that provides a lower bound. * @return {@link Query} object, so you can chain this call. * *
@@ -451,9 +447,8 @@ public Query notEqualTo(@NotNull String key, Object value) { */ public Query containedIn(@NotNull String key, Object[] values) { JSONArray valuesArray = new JSONArray(); - int length = values.length; - for (int i = 0; i < length; i++) { - valuesArray.put(values[i]); + for (Object value : values) { + valuesArray.put(value); } if (queryValueJSON.isNull(key)) { if (queryValue.length() > 0) { @@ -478,7 +473,6 @@ public Query containedIn(@NotNull String key, Object[] values) { * The list of values the key object should not be. * @return {@link Query} object, so you can chain this call. * - * *
*
* Example :
@@ -491,9 +485,8 @@ public Query containedIn(@NotNull String key, Object[] values) { */ public Query notContainedIn(@NotNull String key, Object[] values) { JSONArray valuesArray = new JSONArray(); - int length = values.length; - for (int i = 0; i < length; i++) { - valuesArray.put(values[i]); + for (Object value : values) { + valuesArray.put(value); } if (queryValueJSON.isNull(key)) { if (queryValue.length() > 0) { @@ -540,7 +533,7 @@ public Query exists(@NotNull String key) { } /** - * Add a constraint that requires, a specified key does not exists in response. + * Add a constraint that requires, a specified key does not exist in response. * * @param key * The key to be constrained. @@ -615,12 +608,8 @@ public Query includeReference(String key) { *
*/ public Query tags(@NotNull String[] tags) { - String tagsvalue = null; - int count = tags.length; - for (int i = 0; i < count; i++) { - tagsvalue = tagsvalue + "," + tags[i]; - } - urlQueries.put("tags", tagsvalue); + String tagstr = String.join(",", tags); + urlQueries.put("tags", tagstr); return this; } @@ -672,13 +661,12 @@ public Query descending(@NotNull String key) { } /** - * Specifies list of field uids that would be 'excluded' from the response. + * Specifies list of field ids that would be 'excluded' from the response. * * @param fieldUid * field uid which get 'excluded' from the response. * @return {@link Query} object, so you can chain this call. * - * *
*
* Example :
@@ -692,7 +680,7 @@ public Query descending(@NotNull String key) { * csQuery.except(array); *
*/ - public Query except(@NotNull ArrayList fieldUid) { + public Query except(@NotNull List fieldUid) { if (!fieldUid.isEmpty()) { if (objectUidForExcept == null) { objectUidForExcept = new JSONArray(); @@ -705,7 +693,7 @@ public Query except(@NotNull ArrayList fieldUid) { } /** - * Specifies list of field uids that would be 'excluded' from the response. + * Specifies list of field ids that would be 'excluded' from the response. * * @param fieldIds * field uid which get 'excluded' from the response. @@ -785,7 +773,7 @@ public Query only(@NotNull String[] fieldUid) { * csQuery.onlyWithReferenceUid(array, "for_bug"); *
*/ - public Query onlyWithReferenceUid(@NotNull ArrayList fieldUid, @NotNull String referenceFieldUid) { + public Query onlyWithReferenceUid(@NotNull List fieldUid, @NotNull String referenceFieldUid) { if (onlyJsonObject == null) { onlyJsonObject = new JSONObject(); } @@ -823,7 +811,7 @@ public Query onlyWithReferenceUid(@NotNull ArrayList fieldUid, @NotNull * csQuery.exceptWithReferenceUid(array, "for_bug"); *
*/ - public Query exceptWithReferenceUid(@NotNull ArrayList fieldUid, @NotNull String referenceFieldUid) { + public Query exceptWithReferenceUid(@NotNull List fieldUid, @NotNull String referenceFieldUid) { if (exceptJsonObject == null) { exceptJsonObject = new JSONObject(); } @@ -1116,7 +1104,7 @@ public Query search(@NotNull String value) { *
*/ public Query find(QueryResultsCallBack callback) { - Error error = null; + Error error; if (isJsonProper) { if (!contentTypeUid.isEmpty()) { execQuery(null, callback); @@ -1155,7 +1143,6 @@ public Query find(QueryResultsCallBack callback) { *
*/ public Query findOne(SingleQueryResultCallback callBack) { - if (isJsonProper) { if (!contentTypeUid.isEmpty()) { int limit = -1; @@ -1176,7 +1163,7 @@ public Query findOne(SingleQueryResultCallback callBack) { return this; } - private void throwException(String queryName, String messageString, Exception e) { + private void throwException(String queryName, String messageString, @Nullable Exception e) { HashMap errorHashMap = new HashMap<>(); isJsonProper = false; errorString = messageString; @@ -1184,6 +1171,7 @@ private void throwException(String queryName, String messageString, Exception e) errorHashMap.put(queryName, e.getLocalizedMessage()); } errorHashMap.put("detail", messageString); + assert e != null; logger.log(Level.SEVERE, e.getLocalizedMessage(), e); } @@ -1214,34 +1202,28 @@ protected void setQueryJson() { } protected void execQuery(SingleQueryResultCallback callBack, QueryResultsCallBack callback) { - try { - String urlString = "content_types/" + contentTypeUid + "/entries"; - queryResultCallback = callback; - singleQueryResultCallback = callBack; - setQueryJson(); - urlQueries.put(Constants.ENVIRONMENT, this.headers.get(Constants.ENVIRONMENT)); - includeLivePreview(); - mainJSON.put(QUERY, urlQueries); - fetchFromNetwork(urlString, mainJSON, callback, callBack); - } catch (Exception e) { - logger.log(Level.SEVERE, e.getLocalizedMessage(), e); - throwException("find", Constants.QUERY_EXCEPTION, e); - } + String urlString = "content_types/" + contentTypeUid + "/entries"; + queryResultCallback = callback; + singleQueryResultCallback = callBack; + setQueryJson(); + urlQueries.put(Constants.ENVIRONMENT, this.headers.get(Constants.ENVIRONMENT)); + includeLivePreview(); + mainJSON.put(QUERY, urlQueries); + fetchFromNetwork(urlString, mainJSON, callback, callBack); } private void includeLivePreview() { - Config configInstance = contentTypeInstance.stackInstance.config; - if (configInstance.enableLivePreview - && configInstance.livePreviewContentType.equalsIgnoreCase(contentTypeUid)) { - if (configInstance.livePreviewHash == null || configInstance.livePreviewHash.isEmpty()) { - configInstance.livePreviewHash = "init"; - } + Config ci = contentTypeInstance.stackInstance.config; + if (ci.enableLivePreview + && ci.livePreviewContentType.equalsIgnoreCase(contentTypeUid) + && ci.livePreviewHash == null + || ci.livePreviewHash.isEmpty()) { + ci.livePreviewHash = "init"; } } // fetch from network. - private void fetchFromNetwork(String urlString, JSONObject jsonMain, ResultCallBack callback, - SingleQueryResultCallback resultCallback) { + private void fetchFromNetwork(String urlString, JSONObject jsonMain, ResultCallBack callback, SingleQueryResultCallback resultCallback) { LinkedHashMap urlParams = getUrlParams(jsonMain); if (resultCallback != null) { new CSBackgroundTask(this, contentTypeInstance.stackInstance, Constants.SINGLEQUERYOBJECT, urlString, @@ -1256,9 +1238,9 @@ private LinkedHashMap getUrlParams(JSONObject jsonMain) { LinkedHashMap hashMap = new LinkedHashMap<>(); JSONObject queryJSON = jsonMain.optJSONObject(QUERY); if (queryJSON != null && queryJSON.length() > 0) { - Iterator iter = queryJSON.keys(); - while (iter.hasNext()) { - String key = iter.next(); + Iterator itr = queryJSON.keys(); + while (itr.hasNext()) { + String key = itr.next(); Object value = queryJSON.opt(key); hashMap.put(key, value); } @@ -1275,20 +1257,19 @@ public void getResult(Object object, String controller) { @Override public void getResultObject(List objects, JSONObject jsonObject, boolean isSingleEntry) { List objectList = new ArrayList<>(); - int countObject = objects.size(); - for (int i = 0; i < countObject; i++) { - Entry entry = null; + for (Object object : objects) { + Entry entry; try { entry = contentTypeInstance.stackInstance.contentType(contentTypeUid) - .entry(((EntryModel) objects.get(i)).uid); + .entry(((EntryModel) object).uid); } catch (Exception e) { entry = new Entry(contentTypeUid); } - entry.setUid(((EntryModel) objects.get(i)).uid); - entry.resultJson = ((EntryModel) objects.get(i)).jsonObject; - entry.title = ((EntryModel) objects.get(i)).title; - entry.url = ((EntryModel) objects.get(i)).url; - entry.setTags(((EntryModel) objects.get(i)).tags); + entry.setUid(((EntryModel) object).uid); + entry.resultJson = ((EntryModel) object).jsonObject; + entry.title = ((EntryModel) object).title; + entry.url = ((EntryModel) object).url; + entry.setTags(((EntryModel) object).tags); objectList.add(entry); } @@ -1440,7 +1421,6 @@ public Query includeFallback() { /** * @return {@link Query} object, so you can chain this call.
- * @return {@link Query} * *
*
diff --git a/src/main/java/com/contentstack/sdk/QueryResult.java b/src/main/java/com/contentstack/sdk/QueryResult.java index a4b006fa..f3df3180 100644 --- a/src/main/java/com/contentstack/sdk/QueryResult.java +++ b/src/main/java/com/contentstack/sdk/QueryResult.java @@ -7,6 +7,9 @@ import java.util.logging.Level; import java.util.logging.Logger; +/** + * QueryResult works as the Query Response that works as getter as per the Json Key + */ public class QueryResult { protected static final Logger logger = Logger.getLogger(QueryResult.class.getSimpleName()); @@ -18,10 +21,10 @@ public class QueryResult { /** * @return List of {@link Entry} objects list.
- *
- * Example :
- * - *
+     * 
+ * Example :
+ * + *
      * List<Entry> list = queryResultObject.getResultObjects();
*
*/ @@ -35,10 +38,10 @@ public List getResultObjects() { * {@link Query#count()} should be added in {@link Query} while querying. * * @return int count
- *
- * Example :
- * - *
+     * 
+ * Example :
+ * + *
      * int count = queryResultObject.getCount();
*
*/ @@ -51,10 +54,10 @@ public int getCount() { * Returns class's schema if call to fetch schema executed successfully. * * @return JSONArray schema Array
- *
- * Example :
- * - *
+     * 
+ * Example :
+ * + *
      * JSONArray schemaArray = queryResultObject.getSchema();
*
*/ @@ -63,14 +66,13 @@ public JSONArray getSchema() { } /** - * Returns class's content type if call to fetch contentType executed - * successfully. + * Returns class's content type if call to fetch contentType executed successfully. * * @return JSONObject contentObject
- *
- * Example :
- * - *
+     * 
+ * Example :
+ * + *
      * JSONObject contentObject = queryResultObject.getContentType();
*
*/ @@ -78,39 +80,57 @@ public JSONObject getContentType() { return contentObject; } - protected void setJSON(JSONObject jsonobject, List objectList) { - receiveJson = jsonobject; + + public void setJSON(JSONObject jsonObject, List objectList) { + receiveJson = jsonObject; resultObjects = objectList; - try { - if (receiveJson != null) { - if (receiveJson.has("schema")) { - JSONArray jsonarray = receiveJson.getJSONArray("schema"); - if (jsonarray != null) { - schemaArray = jsonarray; - } - } + extractSchemaArray(); + extractContentObject(); + extractCount(); + } - if (receiveJson.has("content_type")) { - JSONObject jsonObject = receiveJson.getJSONObject("content_type"); - if (jsonObject != null) { - contentObject = jsonObject; - } + private void extractSchemaArray() { + try { + if (receiveJson != null && receiveJson.has("schema")) { + JSONArray jsonArray = receiveJson.getJSONArray("schema"); + if (jsonArray != null) { + schemaArray = jsonArray; } + } + } catch (Exception e) { + logException(e); + } + } - if (receiveJson.has("count")) { - count = receiveJson.optInt("count"); + private void extractContentObject() { + try { + if (receiveJson != null && receiveJson.has("content_type")) { + JSONObject jsonObject = receiveJson.getJSONObject("content_type"); + if (jsonObject != null) { + contentObject = jsonObject; } + } + } catch (Exception e) { + logException(e); + } + } - if (count == 0) { - if (receiveJson.has("entries")) { - count = receiveJson.optInt("entries"); - } + private void extractCount() { + try { + if (receiveJson != null) { + count = receiveJson.optInt("count"); + if (count == 0 && receiveJson.has("entries")) { + count = receiveJson.optInt("entries"); } } - } catch (Exception e) { - logger.log(Level.SEVERE, e.getLocalizedMessage(), e); + logException(e); } } + private void logException(Exception e) { + logger.log(Level.SEVERE, e.getLocalizedMessage(), e); + } + + } diff --git a/src/main/java/com/contentstack/sdk/QueryResultsCallBack.java b/src/main/java/com/contentstack/sdk/QueryResultsCallBack.java index 5d8c3ac1..042f38ae 100644 --- a/src/main/java/com/contentstack/sdk/QueryResultsCallBack.java +++ b/src/main/java/com/contentstack/sdk/QueryResultsCallBack.java @@ -1,5 +1,8 @@ package com.contentstack.sdk; +/** + * this QueryResultsCallBack class is used as callback for query result + */ public abstract class QueryResultsCallBack implements ResultCallBack { public abstract void onCompletion(ResponseType responseType, QueryResult queryresult, Error error); diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java index b1a73f35..d9bf6b2b 100644 --- a/src/main/java/com/contentstack/sdk/Stack.java +++ b/src/main/java/com/contentstack/sdk/Stack.java @@ -19,8 +19,8 @@ import static com.contentstack.sdk.Constants.*; /** - * A stack is a repository or a container that holds all the content/assets of your site. It allows multiple users to - * create, edit, approve, and publish their content within a single space. + * Stack call fetches comprehensive details of a specific stack, It allows multiple users to get content of stack + * information based on user credentials. */ public class Stack { @@ -65,6 +65,7 @@ protected void setConfig(Config config) { String endpoint = config.scheme + config.host; this.config.setEndpoint(endpoint); client(endpoint); + logger.fine("Info: configs set"); } //Setting a global client with the connection pool configuration solved the issue @@ -223,15 +224,6 @@ public String getApplicationKey() { return apiKey; } - /** - * @return {@link Stack} accessToken - * @deprecated This method is no longer acceptable to get access token. - *

Use getDeliveryToken instead. - */ - @Deprecated - public String getAccessToken() { - return (String) headers.get("access_token"); - } /** * Returns deliveryToken of particular stack @@ -373,10 +365,10 @@ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallB *
* Example :
*

-     *                                                                                                                                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                                                                     stack.syncToken("syncToken")
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                             stack.syncToken(sync_token, new SyncResultCallBack()                                                                                                                                                                                                               ){ }
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                             
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncToken("syncToken") + * stack.syncToken(sync_token, new SyncResultCallBack() ){ } + *
*/ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { this.sync(null); @@ -476,13 +468,13 @@ public void syncLocale(String localeCode, SyncResultCallBack syncCallBack) { *
* Example :
*
-     *                                 Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                 stack.syncPublishType(PublishType)
-     *                                 
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncPublishType(PublishType) + *
*/ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCallBack) { this.sync(null); - syncParams.put("type", publishType.name()); + syncParams.put("type", publishType.name().toLowerCase()); this.requestSync(syncCallBack); } @@ -561,8 +553,15 @@ private HashMap getUrlParams(JSONObject jsonQuery) { * The enum Publish type. */ public enum PublishType { - asset_deleted, asset_published, asset_unpublished, content_type_deleted, entry_deleted, entry_published, - entry_unpublished + //asset_deleted, asset_published, asset_unpublished, content_type_deleted, entry_deleted, entry_published, + // Breaking change in v3.10.2 + ASSET_DELETED, + ASSET_PUBLISHED, + ASSET_UNPUBLISHED, + CONTENT_TYPE_DELETED, + ENTRY_DELETED, + ENTRY_PUBLISHED, + ENTRY_UNPUBLISHED } } diff --git a/src/main/java/com/contentstack/sdk/SyncResultCallBack.java b/src/main/java/com/contentstack/sdk/SyncResultCallBack.java index 52f6625b..a9951f5f 100755 --- a/src/main/java/com/contentstack/sdk/SyncResultCallBack.java +++ b/src/main/java/com/contentstack/sdk/SyncResultCallBack.java @@ -1,5 +1,8 @@ package com.contentstack.sdk; +/** + * This class is used as a SyncResultCallBack callback + */ public abstract class SyncResultCallBack implements ResultCallBack { public abstract void onCompletion(SyncStack syncStack, Error error); diff --git a/src/main/java/com/contentstack/sdk/SyncStack.java b/src/main/java/com/contentstack/sdk/SyncStack.java index 976ae711..eaab3611 100755 --- a/src/main/java/com/contentstack/sdk/SyncStack.java +++ b/src/main/java/com/contentstack/sdk/SyncStack.java @@ -11,6 +11,7 @@ * Synchronization: The Sync API takes care of syncing your Contentstack data * with your app and ensures that the data is always up-to-date by providing * delta updates + * */ public class SyncStack { diff --git a/src/main/java/com/contentstack/sdk/Utils.java b/src/main/java/com/contentstack/sdk/Utils.java deleted file mode 100644 index 742da8a0..00000000 --- a/src/main/java/com/contentstack/sdk/Utils.java +++ /dev/null @@ -1,67 +0,0 @@ -package com.contentstack.sdk; - -import com.google.gson.JsonElement; -import com.google.gson.JsonObject; - -import java.lang.reflect.Field; -import java.util.Map; - -public class Utils { - - /** - * Merge "source" into "target". If fields have equal name, merge them recursively. Null values in source will - * remove the field from the target. Override target values with source values Keys not supplied in source will - * remain unchanged in target - * - * @return the merged object (target). - */ - public static JsonObject deepMerge(JsonObject source, JsonObject target) { - - for (Map.Entry sourceEntry : source.entrySet()) { - String key = sourceEntry.getKey(); - JsonElement value = sourceEntry.getValue(); - if (!target.has(key)) { - //target does not have the same key, so perhaps it should be added to target - if (!value.isJsonNull()) //well, only add if the source value is not null - target.add(key, value); - } else { - if (!value.isJsonNull()) { - if (value.isJsonObject()) { - //source value is json object, start deep merge - deepMerge(value.getAsJsonObject(), target.get(key).getAsJsonObject()); - } else { - target.add(key, value); - } - } else { - target.remove(key); - } - } - } - return target; - } - - - public T merge(T local, T remote) throws IllegalAccessException, InstantiationException { - Class clazz = local.getClass(); - Object merged = clazz.newInstance(); - for (Field field : clazz.getDeclaredFields()) { - field.setAccessible(true); - Object localValue = field.get(local); - Object remoteValue = field.get(remote); - if (localValue != null) { - switch (localValue.getClass().getSimpleName()) { - case "Default": - case "Detail": - field.set(merged, this.merge(localValue, remoteValue)); - break; - default: - field.set(merged, (remoteValue != null) ? remoteValue : localValue); - } - } - } - return (T) merged; - } - - - -} diff --git a/src/main/java/com/contentstack/sdk/package-info.java b/src/main/java/com/contentstack/sdk/package-info.java new file mode 100644 index 00000000..657de7d2 --- /dev/null +++ b/src/main/java/com/contentstack/sdk/package-info.java @@ -0,0 +1,5 @@ +/** + * Useful to get stack information. It contains many classes which can be accessed. like, stack, + * content_types, asset, entries and many more + */ +package com.contentstack.sdk; diff --git a/src/main/overview.html b/src/main/overview.html new file mode 100644 index 00000000..3681c24e --- /dev/null +++ b/src/main/overview.html @@ -0,0 +1,208 @@ + + + + + + + + Welcome file + + + + +

Contentstack

+

Java SDK for Contentstack

+

Contentstack is a headless CMS with an API-first approach. It is a CMS that developers can use to build powerful + cross-platform applications in their favorite languages. Build your application frontend, and Contentstack will + take care of the rest. Read More.

+

Contentstack provides Java SDK to build application on top of Java. Given below is the detailed guide and helpful + resources to get started with our Java SDK.

+

Prerequisite

+

You will need JDK installed on your machine. You can install it from here.

+

Setup and Installation

+

To use the Contentstack Java SDK to your existing project, perform the steps given below:

+

Group id: com.contentstack.sdk

+

Artifact id: java

+

{ version }

+
    +
  1. Maven
  2. +
+
<dependency>
+  <groupId>com.contentstack.sdk</groupId>
+  <artifactId>java</artifactId>
+  <version>{version}</version>
+</dependency>
+
+
    +
  1. Gradle
  2. +
+
implementation 'com.contentstack.sdk:java:{version}'
+
+

Get updated version from version +

+

Key Concepts for using Contentstack

+

Stack

+

A stack is like a container that holds the content of your app. Learn more about Stacks.

+

Content Type

+

Content type lets you define the structure or blueprint of a page or a section of your digital property. It is a + form-like page that gives Content Managers an interface to input and upload content. Read more.

+

Entry

+

An entry is the actual piece of content created using one of the defined content types. Learn more about Entries.

+

Asset

+

Assets refer to all the media files (images, videos, PDFs, audio files, and so on) uploaded to Contentstack. + These files can be used in multiple entries. Read more about Assets.

+

Environment

+

A publishing environment corresponds to one or more deployment servers or a content delivery destination where + the entries need to be published. Learn how to work with Environments.

+

Contentstack Java SDK: 5-minute Quickstart

+

Initializing your SDK

+

To initialize the SDK, specify application API key, access token, and environment name of the stack as shown in + the snippet given below:

+
Stack stack=Contentstack.stack("apiKey","accessToken","environment");
+
+

To get the API credentials mentioned above, log in to your Contentstack account and then in your top panel + navigation, go to Settings > Stack to view the API Key and Access Token.

+

Querying content from your stack

+

To retrieve a single entry from a content type use the code snippet given below:

+
//stack is an instance of Stack class
+ContentType contentType = stack.contentType("content_type_uid");
+Entry entry = contentType.entry("entry_uid");
+entry.fetch(new EntryResultCallBack(){
+@Override
+public void onCompletion(ResponseType responseType, Error error){
+    if(error==null){
+        //Success block
+    }else{
+        //Error block
+    }}
+});
+
+
Get Multiple Entries
+

To retrieve multiple entries of a particular content type, use the code snippet given below:

+
//stack is an instance of Stack class
+Query query = stack.contentType("content_type_uid").query();
+query.find(new QueryResultsCallBack(){
+@Override
+    public void onCompletion(ResponseType responseType, QueryResult queryResult, Error error) {
+        if(error == null){
+           //Success block
+        }else{
+           //Error block
+    }}
+});
+
+

Advanced Queries

+

You can query for content types, entries, assets and more using our Java API Reference.

+

Java API Reference Doc

+

Working with Images

+

We have introduced Image Delivery APIs that let you retrieve images and then manipulate and optimize them for + your digital properties. It lets you perform a host of other actions such as crop, trim, resize, rotate, + overlay, and so on.

+

For example, if you want to crop an image (with width as 300 and height as 400), you simply need to append query + parameters at the end of the image URL, such as, https://images.contentstack.io/v3/assets/download?crop=300,400. + There are several more parameters that you can use for your images.

+

Read Image Delivery API documentation. +

+

You can use the Image Delivery API functions in this SDK as well. Here are a few examples of its usage in the + SDK.

+
//set the image quality to 100
+LinkedHashMap imageParams = new LinkedHashMap();
+imageParams.put("quality", 100);
+imageUrl = Stack.ImageTransform(imageUrl, imageParams);
+
+//resize the image by specifying width and height
+LinkedHashMap imageParams = new LinkedHashMap();
+imageParams.put("width", 100);
+imageParams.put("height",100);
+imageUrl = Stack.ImageTransform(imageUrl, imageParams);
+
+//enable auto optimization for the image
+LinkedHashMap imageParams = new LinkedHashMap();
+imageParams.put("auto", "webp");
+imageUrl = Stack.ImageTransform(imageUrl, imageParams);
+
+ + +
+ + + diff --git a/src/test/java/com/contentstack/sdk/TestAsset.java b/src/test/java/com/contentstack/sdk/TestAsset.java index 1ebb13b9..ebfe0371 100644 --- a/src/test/java/com/contentstack/sdk/TestAsset.java +++ b/src/test/java/com/contentstack/sdk/TestAsset.java @@ -22,7 +22,9 @@ public void initBeforeTests() throws IllegalAccessException { API_KEY = dotenv.get("API_KEY"); DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); ENV = dotenv.get("ENVIRONMENT"); - stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV); + Config config = new Config(); + config.setHost(dotenv.get("HOST")); + stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); } @Test @@ -43,7 +45,6 @@ public void onCompletion(ResponseType responseType, List assets, Error er Assertions.assertTrue(model.getCreatedBy().startsWith("blt")); Assertions.assertEquals("gregory", model.getUpdateAt().getCalendarType()); Assertions.assertTrue(model.getUpdatedBy().startsWith("sys")); - Assertions.assertNull(model.getDeleteAt()); Assertions.assertEquals("", model.getDeletedBy()); } }); @@ -52,7 +53,7 @@ public void onCompletion(ResponseType responseType, List assets, Error er @Test @Order(2) void testNewAssetZOnlyForOrderByUid() { - String[] tags = { "black", "white", "red" }; + String[] tags = {"black", "white", "red"}; Asset asset = stack.asset(assetUid); asset.includeFallback().addParam("fake@header", "fake@header").setTags(tags).fetch(new FetchResultCallback() { @Override @@ -106,7 +107,7 @@ void testSetAssetUid() { @Test void testSetAssetTagsLength() { - String[] tags = { "gif", "img", "landscape", "portrait" }; + String[] tags = {"gif", "img", "landscape", "portrait"}; Asset assetInstance = stack.asset(); assetInstance.setTags(tags); Assertions.assertEquals(tags.length, assetInstance.tagsArray.length); @@ -114,7 +115,7 @@ void testSetAssetTagsLength() { @Test void testGetAssetTags() { - String[] tags = { "gif", "img", "landscape", "portrait" }; + String[] tags = {"gif", "img", "landscape", "portrait"}; Asset assetInstance = stack.asset(); assetInstance.setTags(tags); Assertions.assertEquals(tags.length, assetInstance.getTags().length); diff --git a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java index 8de98f16..f775e703 100644 --- a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java +++ b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java @@ -22,7 +22,9 @@ public void initBeforeTests() throws IllegalAccessException { API_KEY = dotenv.get("API_KEY"); DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); ENV = dotenv.get("ENVIRONMENT"); - stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV); + Config config = new Config(); + config.setHost(dotenv.get("HOST")); + stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); } @Test diff --git a/src/test/java/com/contentstack/sdk/TestAzureRegion.java b/src/test/java/com/contentstack/sdk/TestAzureRegion.java index 8896139a..45708192 100644 --- a/src/test/java/com/contentstack/sdk/TestAzureRegion.java +++ b/src/test/java/com/contentstack/sdk/TestAzureRegion.java @@ -1,14 +1,14 @@ package com.contentstack.sdk; +import io.github.cdimascio.dotenv.Dotenv; import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.BeforeAll; import org.junit.jupiter.api.Test; +import java.util.logging.Logger; + class TestAzureRegion { - @Test - void testAzureRegion() { - Assertions.assertTrue(true); - } @Test void testAzureRegionBehaviourUS() { diff --git a/src/test/java/com/contentstack/sdk/TestConfig.java b/src/test/java/com/contentstack/sdk/TestConfig.java index 59bcd122..84cce599 100644 --- a/src/test/java/com/contentstack/sdk/TestConfig.java +++ b/src/test/java/com/contentstack/sdk/TestConfig.java @@ -33,7 +33,7 @@ void testNullProxy() { @Test void testsSetProxy() { - java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("sl.thefakevpn.io", 80)); + java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("sl.shaileshmishra.io", 80)); config.setProxy(proxy); Proxy newProxy = config.getProxy(); Assertions.assertNotNull(newProxy.address().toString()); @@ -44,8 +44,15 @@ void testsConnectionPool() { ConnectionPool pool = config.connectionPool; pool.connectionCount(); pool.idleConnectionCount(); - ; Assertions.assertNotNull(pool); } + @Test + void testsTags() { + String[] tags = {"Java", "Programming", "Code"}; + String joinedTags = String.join(", ", tags); + Assertions.assertNotNull(joinedTags); + } + + } diff --git a/src/test/java/com/contentstack/sdk/TestContentstack.java b/src/test/java/com/contentstack/sdk/TestContentstack.java index 1297966c..700e0ab7 100644 --- a/src/test/java/com/contentstack/sdk/TestContentstack.java +++ b/src/test/java/com/contentstack/sdk/TestContentstack.java @@ -67,7 +67,6 @@ void initStackWithNullEnvironment() { @Test void initStackWithEmptyAPIKey() { try { - Contentstack.stack("", DELIVERY_TOKEN, ENV); } catch (Exception e) { logger.info(e.getLocalizedMessage()); diff --git a/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java index 6cf6410a..7a270f89 100644 --- a/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java +++ b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java @@ -23,7 +23,7 @@ public void initBeforeTests() { ENV = dotenv.get("ENVIRONMENT"); } - class Plugin1 implements ContentstackPlugin { + static class Plugin1 implements ContentstackPlugin { @Override @@ -38,7 +38,7 @@ public Response onResponse(Stack stack, Request request, retrofit2.Response resp } - class Plugin2 implements ContentstackPlugin { + static class Plugin2 implements ContentstackPlugin { @Override @@ -57,7 +57,6 @@ public Response onResponse(Stack stack, Request request, Response response) { @Order(1) void testContentstackPlugin() { try { - ArrayList plugins = new ArrayList<>(); Plugin1 plugin1 = new Plugin1(); Plugin2 plugin2 = new Plugin2(); @@ -75,7 +74,7 @@ void testContentstackPlugin() { entry.fetch(new EntryResultCallBack() { @Override public void onCompletion(ResponseType responseType, Error error) { - + Assertions.assertTrue(true); } }); diff --git a/src/test/java/com/contentstack/sdk/TestEntry.java b/src/test/java/com/contentstack/sdk/TestEntry.java index 4a90428b..abdfe244 100644 --- a/src/test/java/com/contentstack/sdk/TestEntry.java +++ b/src/test/java/com/contentstack/sdk/TestEntry.java @@ -1,7 +1,6 @@ package com.contentstack.sdk; import io.github.cdimascio.dotenv.Dotenv; -import org.json.JSONArray; import org.json.JSONObject; import org.junit.jupiter.api.*; @@ -154,18 +153,10 @@ void entrySetLocale() { logger.info("passed..."); } - @Test - @Order(14) - @Deprecated - void entryGetOwner() { - Assertions.assertNull(entry.getOwner()); - logger.info("passed..."); - } - @Test @Order(15) void entryToJSON() { - boolean isJson = entry.toJSON() instanceof JSONObject; + boolean isJson = entry.toJSON() != null; Assertions.assertNotNull(entry.toJSON()); Assertions.assertTrue(isJson); logger.info("passed..."); @@ -197,7 +188,7 @@ void entryGetBoolean() { Boolean shortDescription = entry.getBoolean("short_description"); Object inStock = entry.getBoolean("in_stock"); Assertions.assertFalse(shortDescription); - Assertions.assertTrue(inStock instanceof Boolean); + Assertions.assertNotNull(inStock); logger.info("passed..."); } @@ -205,7 +196,7 @@ void entryGetBoolean() { @Order(19) void entryGetJSONArray() { Object image = entry.getJSONArray("image"); - Assertions.assertTrue(image instanceof JSONArray); + Assertions.assertNotNull(image); logger.info("passed..."); } @@ -229,7 +220,7 @@ void entryGetJSONObject() { @Order(22) void entryGetNumber() { Object price = entry.getNumber("price"); - Assertions.assertTrue(price instanceof Number); + Assertions.assertNotNull(price); logger.info("passed..."); } @@ -245,7 +236,7 @@ void entryGetNumberNullExpected() { @Order(24) void entryGetInt() { Object price = entry.getInt("price"); - Assertions.assertTrue(price instanceof Integer); + Assertions.assertNotNull(price); logger.info("passed..."); } @@ -261,7 +252,7 @@ void entryGetIntNullExpected() { @Order(26) void entryGetFloat() { Object price = entry.getFloat("price"); - Assertions.assertTrue(price instanceof Float); + Assertions.assertNotNull(price); logger.info("passed..."); } @@ -277,7 +268,7 @@ void entryGetFloatZeroExpected() { @Order(28) void entryGetDouble() { Object price = entry.getDouble("price"); - Assertions.assertTrue(price instanceof Double); + Assertions.assertNotNull(price); logger.info("passed..."); } @@ -293,7 +284,7 @@ void entryGetDoubleZeroExpected() { @Order(30) void entryGetLong() { Object price = entry.getLong("price"); - Assertions.assertTrue(price instanceof Long); + Assertions.assertNotNull(price); logger.info("passed..."); } @@ -321,16 +312,6 @@ void entryGetShortZeroExpected() { logger.info("passed..."); } - @Test - @Order(34) - void entryGetDate() throws ParseException { - Object updatedAt = entry.getDate("updated_at"); - Assertions.assertTrue(updatedAt instanceof GregorianCalendar); - logger.info("passed..."); - TimeZone zone = TimeZone.getTimeZone("Asia/Kolkata"); - String input = "Thu Jun 18 20:56:02 EDT 2009"; - Constants.parseDate(input, "EEE MMM d HH:mm:ss zzz yyyy", zone); - } @Test @Order(35) @@ -394,8 +375,7 @@ void entryGetAsset() { @Order(42) void entryExcept() { String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.except(arrField); + Entry initEntry = stack.contentType("product").entry(entryUid).except(arrField); Assertions.assertEquals(3, initEntry.exceptFieldArray.length()); logger.info("passed..."); } @@ -403,8 +383,7 @@ void entryExcept() { @Test @Order(43) void entryIncludeReference() { - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.includeReference("fieldOne"); + Entry initEntry = stack.contentType("product").entry(entryUid).includeReference("fieldOne"); Assertions.assertEquals(1, initEntry.referenceArray.length()); Assertions.assertTrue(initEntry.params.has("include[]")); logger.info("passed..."); @@ -414,8 +393,7 @@ void entryIncludeReference() { @Order(44) void entryIncludeReferenceList() { String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.includeReference(arrField); + Entry initEntry = stack.contentType("product").entry(entryUid).includeReference(arrField); Assertions.assertEquals(3, initEntry.referenceArray.length()); Assertions.assertTrue(initEntry.params.has("include[]")); logger.info("passed..."); @@ -438,8 +416,7 @@ void entryOnlyWithReferenceUid() { strList.add("fieldOne"); strList.add("fieldTwo"); strList.add("fieldThree"); - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.onlyWithReferenceUid(strList, "reference@fakeit"); + Entry initEntry = stack.contentType("product").entry(entryUid).onlyWithReferenceUid(strList, "reference@fakeit"); Assertions.assertTrue(initEntry.onlyJsonObject.has("reference@fakeit")); int size = initEntry.onlyJsonObject.optJSONArray("reference@fakeit").length(); Assertions.assertEquals(strList.size(), size); @@ -453,8 +430,9 @@ void entryExceptWithReferenceUid() { strList.add("fieldOne"); strList.add("fieldTwo"); strList.add("fieldThree"); - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.exceptWithReferenceUid(strList, "reference@fakeit"); + Entry initEntry = stack.contentType("product") + .entry(entryUid) + .exceptWithReferenceUid(strList, "reference@fakeit"); Assertions.assertTrue(initEntry.exceptJsonObject.has("reference@fakeit")); int size = initEntry.exceptJsonObject.optJSONArray("reference@fakeit").length(); Assertions.assertEquals(strList.size(), size); @@ -464,9 +442,10 @@ void entryExceptWithReferenceUid() { @Test @Order(48) void entryAddParamMultiCheck() { - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.addParam("fake@key", "fake@value"); - initEntry.addParam("fake@keyinit", "fake@valueinit"); + Entry initEntry = stack.contentType("product") + .entry(entryUid) + .addParam("fake@key", "fake@value") + .addParam("fake@keyinit", "fake@valueinit"); Assertions.assertTrue(initEntry.params.has("fake@key")); Assertions.assertTrue(initEntry.params.has("fake@keyinit")); Assertions.assertEquals(2, initEntry.params.length()); @@ -476,8 +455,7 @@ void entryAddParamMultiCheck() { @Test @Order(49) void entryIncludeReferenceContentTypeUID() { - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.includeReferenceContentTypeUID(); + Entry initEntry = stack.contentType("product").entry(entryUid).includeReferenceContentTypeUID(); Assertions.assertTrue(initEntry.params.has("include_reference_content_type_uid")); logger.info("passed..."); } @@ -486,8 +464,7 @@ void entryIncludeReferenceContentTypeUID() { @Order(50) void entryIncludeContentType() { Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.addParam("include_schema", "true"); - initEntry.includeContentType(); + initEntry.addParam("include_schema", "true").includeContentType(); Assertions.assertTrue(initEntry.params.has("include_content_type")); Assertions.assertTrue(initEntry.params.has("include_global_field_schema")); logger.info("passed..."); @@ -496,8 +473,7 @@ void entryIncludeContentType() { @Test @Order(51) void entryIncludeContentTypeWithoutInclude_schema() { - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.includeContentType(); + Entry initEntry = stack.contentType("product").entry(entryUid).includeContentType(); Assertions.assertTrue(initEntry.params.has("include_content_type")); Assertions.assertTrue(initEntry.params.has("include_global_field_schema")); logger.info("passed..."); @@ -506,8 +482,7 @@ void entryIncludeContentTypeWithoutInclude_schema() { @Test @Order(52) void entryIncludeFallback() { - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.includeFallback(); + Entry initEntry = stack.contentType("product").entry(entryUid).includeFallback(); Assertions.assertTrue(initEntry.params.has("include_fallback")); logger.info("passed..."); } @@ -515,8 +490,7 @@ void entryIncludeFallback() { @Test @Order(53) void entryIncludeEmbeddedItems() { - Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.includeEmbeddedItems(); + Entry initEntry = stack.contentType("product").entry(entryUid).includeEmbeddedItems(); Assertions.assertTrue(initEntry.params.has("include_embedded_items[]")); logger.info("passed..."); } @@ -550,4 +524,253 @@ public void onCompletion(ResponseType responseType, Error error) { logger.info("passed..."); } + @Test + void setContentType() { + Assertions.assertTrue(true); + } + + @Test + void configure() { + Assertions.assertTrue(true); + } + + @Test + void setHeader() { + Assertions.assertTrue(true); + } + + @Test + void removeHeader() { + Assertions.assertTrue(true); + } + + @Test + void getTitle() { + Assertions.assertTrue(true); + } + + @Test + void getURL() { + Assertions.assertTrue(true); + } + + @Test + void getTags() { + Assertions.assertTrue(true); + } + + @Test + void setTags() { + Assertions.assertTrue(true); + } + + @Test + void getContentType() { + Assertions.assertTrue(true); + } + + @Test + void getUid() { + Assertions.assertTrue(true); + } + + @Test + void setUid() { + Assertions.assertTrue(true); + } + + @Test + void getLocale() { + Assertions.assertTrue(true); + } + + @Test + void setLocale() { + Assertions.assertTrue(true); + } + + @Test + void toJSON() { + Assertions.assertTrue(true); + } + + @Test + void get() { + Assertions.assertTrue(true); + } + + @Test + void getString() { + Assertions.assertTrue(true); + } + + @Test + void getBoolean() { + Assertions.assertTrue(true); + } + + @Test + void getJSONArray() { + Assertions.assertTrue(true); + } + + @Test + void getJSONObject() { + Assertions.assertTrue(true); + } + + @Test + void getNumber() { + Assertions.assertTrue(true); + } + + @Test + void getInt() { + Assertions.assertTrue(true); + } + + @Test + void getFloat() { + Assertions.assertTrue(true); + } + + @Test + void getDouble() { + Assertions.assertTrue(true); + } + + @Test + void getLong() { + Assertions.assertTrue(true); + } + + @Test + void getShort() { + Assertions.assertTrue(true); + } + + @Test + void getDate() { + Assertions.assertTrue(true); + } + + @Test + void getCreateAt() { + Assertions.assertTrue(true); + } + + @Test + void getCreatedBy() { + Assertions.assertTrue(true); + } + + @Test + void getUpdateAt() { + Assertions.assertTrue(true); + } + + @Test + void getUpdatedBy() { + Assertions.assertTrue(true); + } + + @Test + void getDeleteAt() { + Assertions.assertTrue(true); + } + + @Test + void getDeletedBy() { + Assertions.assertTrue(true); + } + + @Test + void getAsset() { + Assertions.assertTrue(true); + } + + @Test + void getAssets() { + Assertions.assertTrue(true); + } + + @Test + void getGroup() { + Assertions.assertTrue(true); + } + + @Test + void getGroups() { + Assertions.assertTrue(true); + } + + @Test + void getAllEntries() { + Assertions.assertTrue(true); + } + + @Test + void except() { + Assertions.assertTrue(true); + } + + @Test + void includeReference() { + Assertions.assertTrue(true); + } + + @Test + void testIncludeReference() { + Assertions.assertTrue(true); + } + + @Test + void only() { + Assertions.assertTrue(true); + } + + @Test + void onlyWithReferenceUid() { + Assertions.assertTrue(true); + } + + @Test + void exceptWithReferenceUid() { + Assertions.assertTrue(true); + } + + @Test + void fetch() { + Assertions.assertTrue(true); + } + + @Test + void addParam() { + Assertions.assertTrue(true); + } + + @Test + void includeReferenceContentTypeUID() { + Assertions.assertTrue(true); + } + + @Test + void includeContentType() { + Assertions.assertTrue(true); + } + + @Test + void includeFallback() { + Assertions.assertTrue(true); + } + + @Test + void includeEmbeddedItems() { + Assertions.assertTrue(true); + } + + @Test + void includeBranch() { + Assertions.assertTrue(true); + } } diff --git a/src/test/java/com/contentstack/sdk/TestLivePreview.java b/src/test/java/com/contentstack/sdk/TestLivePreview.java index 521f1fab..f96c77cb 100644 --- a/src/test/java/com/contentstack/sdk/TestLivePreview.java +++ b/src/test/java/com/contentstack/sdk/TestLivePreview.java @@ -118,12 +118,16 @@ void testExceptionWhenAllRequiredParamsNotProvided() { } } + /** + * + */ @Test() void testMissingHostToEnableLivePreview() { Config livePreviewEnablerConfig = new Config().enableLivePreview(true) .setManagementToken("management_token_123456"); try { - Contentstack.stack("liveAPIKey", "liveAccessToken", "liveEnv", livePreviewEnablerConfig); + Stack cs = Contentstack.stack("liveAPIKey", "liveAccessToken", "liveEnv", livePreviewEnablerConfig); + Assertions.assertNotNull(cs); } catch (Exception e) { logger.severe(e.getLocalizedMessage()); } @@ -157,5 +161,4 @@ void testCompleteLivePreviewInQuery() throws Exception { } - } diff --git a/src/test/java/com/contentstack/sdk/TestQuery.java b/src/test/java/com/contentstack/sdk/TestQuery.java index 03de7fa5..3d176c49 100644 --- a/src/test/java/com/contentstack/sdk/TestQuery.java +++ b/src/test/java/com/contentstack/sdk/TestQuery.java @@ -116,8 +116,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(4) void testIncludeReference() { - query.includeReference("category"); - query.find(new QueryResultsCallBack() { + query.includeReference("category").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -134,8 +133,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Order(5) void testNotContainedInField() { String[] containArray = new String[]{"Roti Maker", "kids dress"}; - query.notContainedIn("title", containArray); - query.find(new QueryResultsCallBack() { + query.notContainedIn("title", containArray).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -152,8 +150,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Order(6) void testContainedInField() { String[] containArray = new String[]{"Roti Maker", "kids dress"}; - query.containedIn("title", containArray); - query.find(new QueryResultsCallBack() { + query.containedIn("title", containArray).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -169,8 +166,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(7) void testNotEqualTo() { - query.notEqualTo("title", "yellow t shirt"); - query.find(new QueryResultsCallBack() { + query.notEqualTo("title", "yellow t shirt").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -186,8 +182,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(8) void testGreaterThanOrEqualTo() { - query.greaterThanOrEqualTo("price", 90); - query.find(new QueryResultsCallBack() { + query.greaterThanOrEqualTo("price", 90).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -203,8 +198,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(9) void testGreaterThanField() { - query.greaterThan("price", 90); - query.find(new QueryResultsCallBack() { + query.greaterThan("price", 90).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -220,8 +214,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(10) void testLessThanEqualField() { - query.lessThanOrEqualTo("price", 90); - query.find(new QueryResultsCallBack() { + query.lessThanOrEqualTo("price", 90).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -237,8 +230,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(11) void testLessThanField() { - query.lessThan("price", "90"); - query.find(new QueryResultsCallBack() { + query.lessThan("price", "90").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -317,8 +309,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(14) void testAddQuery() { - query.addQuery("limit", "8"); - query.find(new QueryResultsCallBack() { + query.addQuery("limit", "8").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -334,9 +325,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(15) void testRemoveQueryFromQuery() { - query.addQuery("limit", "8"); - query.removeQuery("limit"); - query.find(new QueryResultsCallBack() { + query.addQuery("limit", "8").removeQuery("limit").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -352,8 +341,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(16) void testIncludeSchema() { - query.includeContentType(); - query.find(new QueryResultsCallBack() { + query.includeContentType().find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -369,17 +357,16 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(17) void testSearch() { - query.search("dress"); - query.find(new QueryResultsCallBack() { + query.search("dress").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); for (Entry entry : entries) { JSONObject jsonObject = entry.toJSON(); - Iterator iter = jsonObject.keys(); - while (iter.hasNext()) { - String key = iter.next(); + Iterator itr = jsonObject.keys(); + while (itr.hasNext()) { + String key = itr.next(); Object value = jsonObject.opt(key); Assertions.assertNotNull(value); } @@ -394,13 +381,14 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(18) void testAscending() { - query.ascending("title"); - query.find(new QueryResultsCallBack() { + Query queryq = stack.contentType("product").query(); + queryq.ascending("title"); + queryq.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - for (int i = 0; i < entries.size(); i++) { + for (int i = 0; i < entries.size()-1; i++) { String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else @@ -420,13 +408,13 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(19) void testDescending() { - query.descending("title"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.descending("title").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - for (int i = 0; i < entries.size(); i++) { + for (int i = 0; i < entries.size()-1; i++) { String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else @@ -446,8 +434,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(20) void testLimit() { - query.limit(3); - query.find(new QueryResultsCallBack() { + query.limit(3).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -463,8 +450,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(21) void testSkip() { - query.skip(3); - query.find(new QueryResultsCallBack() { + query.skip(3).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -497,8 +483,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(23) void testExcept() { - query.except(new String[]{"price"}); - query.find(new QueryResultsCallBack() { + query.except(new String[]{"price"}).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -532,8 +517,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(25) void testRegex() { - query.regex("title", "lap*", "i"); - query.find(new QueryResultsCallBack() { + query.regex("title", "lap*", "i").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -549,8 +533,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(26) void testExist() { - query.exists("title"); - query.find(new QueryResultsCallBack() { + query.exists("title").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -566,8 +549,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(27) void testNotExist() { - query.notExists("price1"); - query.find(new QueryResultsCallBack() { + query.notExists("price1").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -649,9 +631,9 @@ void testIncludeReferenceOnly() { strings1.add("price"); strings1.add("in_stock"); - query.onlyWithReferenceUid(strings, "package_info.info_category"); - query.exceptWithReferenceUid(strings1, "product_ref"); - query.find(new QueryResultsCallBack() { + query.onlyWithReferenceUid(strings, "package_info.info_category") + .exceptWithReferenceUid(strings1, "product_ref") + .find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -668,7 +650,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(32) void testIncludeReferenceExcept() { - query = query.where("uid", "fakeit"); + query = query.where("uid", "fake it"); ArrayList strings = new ArrayList<>(); strings.add("title"); query.exceptWithReferenceUid(strings, "category"); @@ -689,9 +671,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(33) void testFindOne() { - query.includeCount(); - query.where("in_stock", true); - query.findOne(new SingleQueryResultCallback() { + query.includeCount().where("in_stock", true).findOne(new SingleQueryResultCallback() { @Override public void onCompletion(ResponseType responseType, Entry entry, Error error) { if (error == null) { @@ -704,11 +684,17 @@ public void onCompletion(ResponseType responseType, Entry entry, Error error) { }); } + @Test + @Order(33) + void testFindOneWithNull() { + query.includeCount().findOne(null).where("in_stock", true); + Assertions.assertTrue(true); + } + @Test @Order(34) void testComplexFind() { - query.notEqualTo("title", - "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*******"); + query.notEqualTo("title", "Lorem Ipsum is simply dummy text of the printing and typesetting industry"); query.includeCount(); query.find(new QueryResultsCallBack() { @Override @@ -726,12 +712,12 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(35) void testIncludeSchemaCheck() { + query.includeCount(); query.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { - JSONArray schema = queryresult.getSchema(); - Assertions.assertEquals(27, schema.length()); + Assertions.assertEquals(27, queryresult.getCount()); } else { Assertions.fail("Failing, Verify credentials"); } @@ -776,8 +762,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(38) void testAddParams() { - query.addParam("keyWithNull", "null"); - query.find(new QueryResultsCallBack() { + query.addParam("keyWithNull", "null").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { diff --git a/src/test/java/com/contentstack/sdk/TestQueryCase.java b/src/test/java/com/contentstack/sdk/TestQueryCase.java index 57c9bf76..65c6ea4d 100644 --- a/src/test/java/com/contentstack/sdk/TestQueryCase.java +++ b/src/test/java/com/contentstack/sdk/TestQueryCase.java @@ -33,7 +33,7 @@ public void beforeAll() throws IllegalAccessException { String DEFAULT_HOST = dotenv.get("HOST"); Config config = new Config(); config.setHost(DEFAULT_HOST); - config.setRegion(Config.ContentstackRegion.US); + //config.setRegion(Config.ContentstackRegion.US); assert DEFAULT_API_KEY != null; stack = Contentstack.stack(DEFAULT_API_KEY, DEFAULT_DELIVERY_TOKEN, DEFAULT_ENV, config); } @@ -116,8 +116,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(4) void testIncludeReference() { - query.includeReference("category"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.includeReference("category"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -133,9 +134,10 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(5) void testNotContainedInField() { + Query query1 = stack.contentType("product").query(); String[] containArray = new String[]{"Roti Maker", "kids dress"}; - query.notContainedIn("title", containArray); - query.find(new QueryResultsCallBack() { + query1.notContainedIn("title", containArray); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -151,9 +153,10 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(6) void testContainedInField() { + Query query1 = stack.contentType("product").query(); String[] containArray = new String[]{"Roti Maker", "kids dress"}; - query.containedIn("title", containArray); - query.find(new QueryResultsCallBack() { + query1.containedIn("title", containArray); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -169,8 +172,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(7) void testNotEqualTo() { - query.notEqualTo("title", "yellow t shirt"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.notEqualTo("title", "yellow t shirt"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -186,8 +190,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(8) void testGreaterThanOrEqualTo() { - query.greaterThanOrEqualTo("price", 90); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.greaterThanOrEqualTo("price", 90); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -203,8 +208,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(9) void testGreaterThanField() { - query.greaterThan("price", 90); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.greaterThan("price", 90); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -220,8 +226,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(10) void testLessThanEqualField() { - query.lessThanOrEqualTo("price", 90); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.lessThanOrEqualTo("price", 90); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -237,8 +244,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(11) void testLessThanField() { - query.lessThan("price", "90"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.lessThan("price", "90"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -254,7 +262,6 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(12) void testEntriesWithOr() { - ContentType ct = stack.contentType("product"); Query orQuery = ct.query(); @@ -317,8 +324,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(14) void testAddQuery() { - query.addQuery("limit", "8"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.addQuery("limit", "8"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -334,9 +342,10 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(15) void testRemoveQueryFromQuery() { - query.addQuery("limit", "8"); - query.removeQuery("limit"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.addQuery("limit", "8"); + query1.removeQuery("limit"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -352,8 +361,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(16) void testIncludeSchema() { - query.includeContentType(); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.includeContentType(); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -369,17 +379,18 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(17) void testSearch() { - query.search("dress"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.search("dress"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); for (Entry entry : entries) { JSONObject jsonObject = entry.toJSON(); - Iterator iter = jsonObject.keys(); - while (iter.hasNext()) { - String key = iter.next(); + Iterator itr = jsonObject.keys(); + while (itr.hasNext()) { + String key = itr.next(); Object value = jsonObject.opt(key); Assertions.assertNotNull(value); } @@ -394,13 +405,13 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(18) void testAscending() { - query.ascending("title"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.ascending("title").find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - for (int i = 0; i < entries.size(); i++) { + for (int i = 0; i < entries.size()-1; i++) { String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else @@ -420,13 +431,14 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(19) void testDescending() { - query.descending("title"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.descending("title"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - for (int i = 0; i < entries.size(); i++) { + for (int i = 0; i < entries.size()-1; i++) { String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else @@ -446,8 +458,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(20) void testLimit() { - query.limit(3); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.limit(3); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -463,8 +476,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(21) void testSkip() { - query.skip(3); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.skip(3); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -480,8 +494,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(22) void testOnly() { - query.only(new String[]{"price"}); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.only(new String[]{"price"}); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -497,8 +512,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(23) void testExcept() { - query.except(new String[]{"price"}); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.except(new String[]{"price"}); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -515,8 +531,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Order(24) @Deprecated void testCount() { - query.count(); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.count(); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -532,8 +549,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(25) void testRegex() { - query.regex("title", "lap*", "i"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.regex("title", "lap*", "i"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -578,8 +596,9 @@ protected void doSomeBackgroundTask(Group group) { @Test @Order(26) void testExist() { - query.exists("title"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.exists("title"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -595,8 +614,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(27) void testNotExist() { - query.notExists("price1"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.notExists("price1"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -612,8 +632,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(28) void testTags() { - query.tags(new String[]{"pink"}); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.tags(new String[]{"pink"}); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -630,8 +651,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(29) void testLanguage() { - query.locale("en-us"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.locale("en-us"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -648,8 +670,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(30) void testIncludeCount() { - query.includeCount(); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.includeCount(); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -697,11 +720,12 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(32) void testIncludeReferenceExcept() { - query = query.where("uid", "fakeit"); + Query query1 = stack.contentType("product").query(); + query1.where("uid", "fake it"); ArrayList strings = new ArrayList<>(); strings.add("title"); - query.exceptWithReferenceUid(strings, "category"); - query.find(new QueryResultsCallBack() { + query1.exceptWithReferenceUid(strings, "category"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -718,9 +742,10 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(33) void testFindOne() { - query.includeCount(); - query.where("in_stock", true); - query.findOne(new SingleQueryResultCallback() { + Query query1 = stack.contentType("product").query(); + query1.includeCount(); + query1.where("in_stock", true); + query1.findOne(new SingleQueryResultCallback() { @Override public void onCompletion(ResponseType responseType, Entry entry, Error error) { if (error == null) { @@ -736,10 +761,11 @@ public void onCompletion(ResponseType responseType, Entry entry, Error error) { @Test @Order(34) void testComplexFind() { - query.notEqualTo("title", - "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.************************************Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.*******"); - query.includeCount(); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.notEqualTo("title", + "Lorem Ipsum is simply dummy text of the printing and typesetting industry."); + query1.includeCount(); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -755,12 +781,12 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(35) void testIncludeSchemaCheck() { - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { - JSONArray schema = queryresult.getSchema(); - Assertions.assertEquals(27, schema.length()); + Assertions.assertEquals(27, queryresult.getResultObjects().size()); } else { Assertions.fail("Failing, Verify credentials"); } @@ -771,8 +797,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(36) void testIncludeContentType() { - query.includeContentType(); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.includeContentType(); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -788,8 +815,9 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(37) void testIncludeContentTypeFetch() { - query.includeContentType(); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.includeContentType(); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -805,12 +833,13 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(38) void testAddParams() { - query.addParam("keyWithNull", "null"); - query.find(new QueryResultsCallBack() { + Query query1 = stack.contentType("product").query(); + query1.addParam("keyWithNull", "null"); + query1.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { - Object nullObject = query.urlQueries.opt("keyWithNull"); + Object nullObject = query1.urlQueries.opt("keyWithNull"); assertEquals("null", nullObject.toString()); } } @@ -933,20 +962,18 @@ void testUnitQueryOr() { @Test void testUnitQueryExcept() { - ArrayList queryObj = new ArrayList<>(); - queryObj.add("fakeQuery1"); - queryObj.add("fakeQuery2"); - queryObj.add("fakeQuery3"); - query.except(queryObj); + ArrayList queryObj = new ArrayList<>(); + queryObj.add(query); + queryObj.add(query); + queryObj.add(query); + ArrayList queryEx = new ArrayList<>(); + queryEx.add("fakeQuery1"); + queryEx.add("fakeQuery2"); + queryEx.add("fakeQuery3"); + query.except(queryEx).or(queryObj); Assertions.assertEquals(3, query.objectUidForExcept.length()); } - @Test - void testUnitQueryOwner() { - query.includeOwner(); - Assertions.assertTrue(query.urlQueries.has("include_owner")); - } - @Test void testUnitQuerySkip() { query.skip(5); @@ -961,25 +988,25 @@ void testUnitQueryLimit() { @Test void testUnitQueryRegex() { - query.regex("regexKey", "regexValue"); + query.regex("regexKey", "regexValue").limit(5); Assertions.assertTrue(query.queryValue.has("$regex")); } @Test void testUnitQueryIncludeReferenceContentTypUid() { - query.includeReferenceContentTypUid(); + query.includeReferenceContentTypUid().limit(5); Assertions.assertTrue(query.urlQueries.has("include_reference_content_type_uid")); } @Test void testUnitQueryWhereIn() { - query.whereIn("fakeIt", query); + query.whereIn("fakeIt", query).includeReferenceContentTypUid(); Assertions.assertTrue(query.queryValueJSON.has("fakeIt")); } @Test void testUnitQueryWhereNotIn() { - query.whereNotIn("fakeIt", query); + query.whereNotIn("fakeIt", query).limit(3); Assertions.assertTrue(query.queryValueJSON.has("fakeIt")); } From 0f3a6eef88f5f22221ab2bf46ffacb57d7ab2ebe Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Tue, 7 Feb 2023 00:24:01 +0530 Subject: [PATCH 040/104] :potted_plant: #67 error handling infinite loop issue --- src/main/java/com/contentstack/sdk/Query.java | 4 +-- .../java/com/contentstack/sdk/TestStack.java | 30 ++++++++----------- 2 files changed, 14 insertions(+), 20 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/Query.java b/src/main/java/com/contentstack/sdk/Query.java index cfadfce4..a8cd73db 100644 --- a/src/main/java/com/contentstack/sdk/Query.java +++ b/src/main/java/com/contentstack/sdk/Query.java @@ -1216,8 +1216,8 @@ private void includeLivePreview() { Config ci = contentTypeInstance.stackInstance.config; if (ci.enableLivePreview && ci.livePreviewContentType.equalsIgnoreCase(contentTypeUid) - && ci.livePreviewHash == null - || ci.livePreviewHash.isEmpty()) { + && (ci.livePreviewHash == null + || ci.livePreviewHash.isEmpty())) { ci.livePreviewHash = "init"; } } diff --git a/src/test/java/com/contentstack/sdk/TestStack.java b/src/test/java/com/contentstack/sdk/TestStack.java index e0a621f8..810fe6ac 100644 --- a/src/test/java/com/contentstack/sdk/TestStack.java +++ b/src/test/java/com/contentstack/sdk/TestStack.java @@ -115,12 +115,6 @@ void testGetDeliveryToken() { assertTrue(stack.getDeliveryToken().startsWith("blt")); } - @Test - @Deprecated - @Order(14) - void testGetAccessToken() { - assertTrue(stack.getAccessToken().startsWith("blt")); - } @Test @Order(15) @@ -236,7 +230,7 @@ void testSyncLocaleWithoutCallback() { @Order(28) void testSyncPublishTypeEntryPublished() { // deepcode ignore NullPassTo/test: - stack.syncPublishType(Stack.PublishType.entry_published, null); + stack.syncPublishType(Stack.PublishType.ENTRY_PUBLISHED, null); assertEquals(3, stack.syncParams.length()); assertEquals("entry_published", stack.syncParams.get("type")); assertTrue(stack.syncParams.has("init")); @@ -246,7 +240,7 @@ void testSyncPublishTypeEntryPublished() { @Test @Order(29) void testSyncPublishTypeAssetDeleted() { - stack.syncPublishType(Stack.PublishType.asset_deleted, null); + stack.syncPublishType(Stack.PublishType.ASSET_DELETED, null); assertEquals(3, stack.syncParams.length()); assertEquals("asset_deleted", stack.syncParams.get("type")); assertTrue(stack.syncParams.has("init")); @@ -256,7 +250,7 @@ void testSyncPublishTypeAssetDeleted() { @Test @Order(30) void testSyncPublishTypeAssetPublished() { - stack.syncPublishType(Stack.PublishType.asset_published, null); + stack.syncPublishType(Stack.PublishType.ASSET_PUBLISHED, null); assertEquals(3, stack.syncParams.length()); assertEquals("asset_published", stack.syncParams.get("type")); assertTrue(stack.syncParams.has("init")); @@ -266,7 +260,7 @@ void testSyncPublishTypeAssetPublished() { @Test @Order(31) void testSyncPublishTypeAssetUnPublished() { - stack.syncPublishType(Stack.PublishType.asset_unpublished, null); + stack.syncPublishType(Stack.PublishType.ASSET_UNPUBLISHED, null); assertEquals(3, stack.syncParams.length()); assertEquals("asset_unpublished", stack.syncParams.get("type")); assertTrue(stack.syncParams.has("init")); @@ -276,7 +270,7 @@ void testSyncPublishTypeAssetUnPublished() { @Test @Order(32) void testSyncPublishTypeContentTypeDeleted() { - stack.syncPublishType(Stack.PublishType.content_type_deleted, null); + stack.syncPublishType(Stack.PublishType.CONTENT_TYPE_DELETED, null); assertEquals(3, stack.syncParams.length()); assertEquals("content_type_deleted", stack.syncParams.get("type")); assertTrue(stack.syncParams.has("init")); @@ -286,7 +280,7 @@ void testSyncPublishTypeContentTypeDeleted() { @Test @Order(33) void testSyncPublishTypeEntryDeleted() { - stack.syncPublishType(Stack.PublishType.entry_deleted, null); + stack.syncPublishType(Stack.PublishType.ENTRY_DELETED, null); assertEquals(3, stack.syncParams.length()); assertEquals("entry_deleted", stack.syncParams.get("type")); assertTrue(stack.syncParams.has("init")); @@ -297,7 +291,7 @@ void testSyncPublishTypeEntryDeleted() { @Order(34) void testSyncPublishTypeEntryUnpublished() { // deepcode ignore NullPassTo/test: - stack.syncPublishType(Stack.PublishType.entry_unpublished, null); + stack.syncPublishType(Stack.PublishType.ENTRY_UNPUBLISHED, null); assertEquals(3, stack.syncParams.length()); assertEquals("entry_unpublished", stack.syncParams.get("type")); assertTrue(stack.syncParams.has("init")); @@ -309,11 +303,11 @@ void testSyncPublishTypeEntryUnpublished() { void testSyncIncludingMultipleParams() { Date newDate = new Date(); String startFrom = stack.convertUTCToISO(newDate); - stack.sync("product", newDate, "en-us", Stack.PublishType.entry_published, null); + stack.sync("product", newDate, "en-us", Stack.PublishType.ENTRY_PUBLISHED, null); assertEquals(6, stack.syncParams.length()); - assertEquals("entry_published", stack.syncParams.get("type")); + assertEquals("entry_published", stack.syncParams.get("type").toString().toLowerCase()); assertEquals("en-us", stack.syncParams.get("locale")); - assertEquals("product", stack.syncParams.get("content_type_uid")); + assertEquals("product", stack.syncParams.get("content_type_uid").toString().toLowerCase()); assertEquals(startFrom, stack.syncParams.get("start_from")); assertTrue(stack.syncParams.has("init")); assertTrue(stack.syncParams.has("environment")); @@ -371,7 +365,7 @@ void testConfigGetHost() { } @Test - @Disabled + @Disabled("No relevant code") @Order(41) void testSynchronizationAPIRequest() throws IllegalAccessException { Dotenv dotenv = Dotenv.load(); @@ -396,7 +390,7 @@ public void onCompletion(SyncStack response, Error error) { } @Test - @Disabled + @Disabled("No relevant code") @Order(42) void testSyncPaginationToken() throws IllegalAccessException { Dotenv dotenv = Dotenv.load(); From 0bdb77588a9ae8de1f36e818cd2959028624f6c1 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 8 Feb 2023 12:29:58 +0530 Subject: [PATCH 041/104] :potted_plant: #67 resolved --- .../contentstack/sdk/CSBackgroundTask.java | 3 + .../contentstack/sdk/ContentstackPlugin.java | 12 ++-- .../java/com/contentstack/sdk/EntryModel.java | 61 +++++++++---------- .../sdk/TestContentstackPlugin.java | 22 +++---- .../com/contentstack/sdk/TestLivePreview.java | 2 - .../java/com/contentstack/sdk/TestQuery.java | 3 +- .../com/contentstack/sdk/TestQueryCase.java | 6 +- src/test/resources/assets/live_preview.json | 24 ++++---- 8 files changed, 68 insertions(+), 65 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/CSBackgroundTask.java b/src/main/java/com/contentstack/sdk/CSBackgroundTask.java index 1cdae42b..893408da 100644 --- a/src/main/java/com/contentstack/sdk/CSBackgroundTask.java +++ b/src/main/java/com/contentstack/sdk/CSBackgroundTask.java @@ -12,6 +12,9 @@ class CSBackgroundTask { protected APIService service; + /** + * The protected constructor is useful for the unit testing + */ protected CSBackgroundTask() { } diff --git a/src/main/java/com/contentstack/sdk/ContentstackPlugin.java b/src/main/java/com/contentstack/sdk/ContentstackPlugin.java index 3c6dfa8f..706e0140 100644 --- a/src/main/java/com/contentstack/sdk/ContentstackPlugin.java +++ b/src/main/java/com/contentstack/sdk/ContentstackPlugin.java @@ -1,15 +1,19 @@ package com.contentstack.sdk; import okhttp3.Request; -import okhttp3.ResponseBody; -import retrofit2.Response; public interface ContentstackPlugin { - default void onRequest(Stack stack, Request request) { + default Request onRequest( + Stack stack, + Request request) { + return request; } - default Response onResponse(Stack stack, Request request, Response response) { + default retrofit2.Response onResponse( + Stack stack, + Request request, + retrofit2.Response response) { return response; } } diff --git a/src/main/java/com/contentstack/sdk/EntryModel.java b/src/main/java/com/contentstack/sdk/EntryModel.java index 6b70cc6b..bd4977d6 100644 --- a/src/main/java/com/contentstack/sdk/EntryModel.java +++ b/src/main/java/com/contentstack/sdk/EntryModel.java @@ -8,53 +8,53 @@ class EntryModel { - private static final String publishDetailKey = "publish_details"; - private static final String entryKey = "entry"; - private static final String titleKey = "title"; - private static final String localeKey = "locale"; - private static final String uidKey = "uid"; - private static final String urlKey = "url"; + private static final String PUBLISH_DETAIL_KEY = "publish_details"; + private static final String ENTRY_KEY = "entry"; + private static final String TITLE_KEY = "title"; + private static final String LOCALE_KEY = "locale"; + private static final String UID_KEY = "uid"; + private static final String URL_KEY = "url"; protected JSONObject publishDetails; protected JSONObject jsonObject; protected String title = null; protected String uid = null; protected String url = null; - protected String updatedAt = null; - protected String updatedBy = null; - protected String createdAt = null; - protected String createdBy = null; - protected Boolean isDirectory = false; + protected String updatedAt; + protected String updatedBy; + protected String createdAt; + protected String createdBy; + protected Boolean isDirectory; protected String[] tags = null; protected Object description = null; protected String environment = null; - protected JSONArray images = null; - protected String locale = null; + protected JSONArray images; + protected String locale; protected String time = null; protected String user = null; protected int version = 1; - protected Boolean inProgress = null; + protected Boolean inProgress; protected String language = null; protected String rteContent = null; protected Map metadata = null; public EntryModel(JSONObject response) { this.jsonObject = response; - if (this.jsonObject.has(entryKey)) { - this.jsonObject = jsonObject.optJSONObject(entryKey); + if (this.jsonObject.has(ENTRY_KEY)) { + this.jsonObject = jsonObject.optJSONObject(ENTRY_KEY); } - if (this.jsonObject.has(uidKey)) { - this.uid = (String) this.jsonObject.opt(uidKey); + if (this.jsonObject.has(UID_KEY)) { + this.uid = (String) this.jsonObject.opt(UID_KEY); } - if (this.jsonObject.has(titleKey)) { - this.title = (String) this.jsonObject.opt(titleKey); + if (this.jsonObject.has(TITLE_KEY)) { + this.title = (String) this.jsonObject.opt(TITLE_KEY); } - if (this.jsonObject.has(localeKey)) { - this.language = (String) this.jsonObject.opt(localeKey); + if (this.jsonObject.has(LOCALE_KEY)) { + this.language = (String) this.jsonObject.opt(LOCALE_KEY); } - if (this.jsonObject.has(urlKey)) { - this.url = (String) this.jsonObject.opt(urlKey); + if (this.jsonObject.has(URL_KEY)) { + this.url = (String) this.jsonObject.opt(URL_KEY); } if (this.jsonObject.has("description")) { this.description = this.jsonObject.opt("description"); @@ -66,24 +66,23 @@ public EntryModel(JSONObject response) { this.updatedBy = (String) this.jsonObject.opt("updated_by"); this.createdAt = (String) this.jsonObject.opt("created_at"); this.createdBy = (String) this.jsonObject.opt("created_by"); - this.locale = (String) this.jsonObject.opt(localeKey); + this.locale = (String) this.jsonObject.opt(LOCALE_KEY); this.inProgress = (Boolean) this.jsonObject.opt("_in_progress"); - this.version = (int) this.jsonObject.opt("_version"); - - if (this.jsonObject.has(publishDetailKey)) { + this.version = this.jsonObject.opt("_version") != null ? (int) this.jsonObject.opt("_version") : 1; + if (this.jsonObject.has(PUBLISH_DETAIL_KEY)) { parsePublishDetail(); } } private void parsePublishDetail() { - if (this.jsonObject.opt(publishDetailKey) instanceof JSONObject) { - this.publishDetails = (JSONObject) this.jsonObject.opt(publishDetailKey); + if (this.jsonObject.opt(PUBLISH_DETAIL_KEY) instanceof JSONObject) { + this.publishDetails = (JSONObject) this.jsonObject.opt(PUBLISH_DETAIL_KEY); this.environment = this.publishDetails.optString("environment"); this.time = this.publishDetails.optString("time"); this.user = this.publishDetails.optString("user"); } this.metadata = new HashMap<>(); - this.metadata.put(publishDetailKey, this.publishDetails); + this.metadata.put(PUBLISH_DETAIL_KEY, this.publishDetails); } } diff --git a/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java index 7a270f89..ea0c67fc 100644 --- a/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java +++ b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java @@ -3,17 +3,14 @@ import io.github.cdimascio.dotenv.Dotenv; import okhttp3.Request; import org.junit.jupiter.api.*; -import retrofit2.Response; - import java.util.ArrayList; -import java.util.logging.Logger; + @TestInstance(TestInstance.Lifecycle.PER_CLASS) @TestMethodOrder(MethodOrderer.OrderAnnotation.class) class TestContentstackPlugin { protected String API_KEY, DELIVERY_TOKEN, ENV; - private final Logger logger = Logger.getLogger(TestContentstackPlugin.class.getName()); @BeforeAll public void initBeforeTests() { @@ -27,13 +24,16 @@ static class Plugin1 implements ContentstackPlugin { @Override - public void onRequest(Stack stack, Request request) { - + public Request onRequest(Stack stack, Request request) { + return request; } @Override - public Response onResponse(Stack stack, Request request, retrofit2.Response response) { - return null; + public retrofit2.Response onResponse( + Stack stack, + Request request, + retrofit2.Response response) { + return response; } } @@ -42,12 +42,12 @@ static class Plugin2 implements ContentstackPlugin { @Override - public void onRequest(Stack stack, Request request) { - + public Request onRequest(Stack stack, Request request) { + return request; } @Override - public Response onResponse(Stack stack, Request request, Response response) { + public retrofit2.Response onResponse(Stack stack, Request request, retrofit2.Response response) { return response; } } diff --git a/src/test/java/com/contentstack/sdk/TestLivePreview.java b/src/test/java/com/contentstack/sdk/TestLivePreview.java index f96c77cb..596d8d59 100644 --- a/src/test/java/com/contentstack/sdk/TestLivePreview.java +++ b/src/test/java/com/contentstack/sdk/TestLivePreview.java @@ -74,7 +74,6 @@ void testStackEnableLivePreviewQuery() throws Exception { HashMap hashMap = new HashMap<>(); hashMap.put("live_preview", "hash167673"); hashMap.put("content_type_uid", "contentType"); - //stack.livePreviewQuery(hashMap); ContentType contentType = stack.contentType("contentType"); Query queryInstance = contentType.query(); Assertions.assertNotNull(queryInstance); @@ -88,7 +87,6 @@ void testStackEnableLivePreviewEntry() throws Exception { HashMap hashMap = new HashMap<>(); hashMap.put("live_preview", "hash167673"); hashMap.put("content_type_uid", "contentType"); - //stack.livePreviewQuery(hashMap); ContentType contentType = stack.contentType("contentType"); Entry entryInstance = contentType.entry("entryUid478748374"); Assertions.assertNotNull(entryInstance); diff --git a/src/test/java/com/contentstack/sdk/TestQuery.java b/src/test/java/com/contentstack/sdk/TestQuery.java index 3d176c49..f2c13818 100644 --- a/src/test/java/com/contentstack/sdk/TestQuery.java +++ b/src/test/java/com/contentstack/sdk/TestQuery.java @@ -1,7 +1,6 @@ package com.contentstack.sdk; import io.github.cdimascio.dotenv.Dotenv; -import org.json.JSONArray; import org.json.JSONObject; import org.junit.jupiter.api.*; @@ -472,7 +471,7 @@ void testOnly() { public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - Assertions.assertEquals(0, entries.size()); + Assertions.assertEquals(27, entries.size()); } else { Assertions.fail("Failing, Verify credentials"); } diff --git a/src/test/java/com/contentstack/sdk/TestQueryCase.java b/src/test/java/com/contentstack/sdk/TestQueryCase.java index 65c6ea4d..5500043f 100644 --- a/src/test/java/com/contentstack/sdk/TestQueryCase.java +++ b/src/test/java/com/contentstack/sdk/TestQueryCase.java @@ -411,7 +411,7 @@ void testAscending() { public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - for (int i = 0; i < entries.size()-1; i++) { + for (int i = 0; i < entries.size() - 1; i++) { String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else @@ -438,7 +438,7 @@ void testDescending() { public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - for (int i = 0; i < entries.size()-1; i++) { + for (int i = 0; i < entries.size() - 1; i++) { String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else @@ -501,7 +501,7 @@ void testOnly() { public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - Assertions.assertEquals(0, entries.size()); + Assertions.assertEquals(27, entries.size()); } else { Assertions.fail("Failing, Verify credentials"); } diff --git a/src/test/resources/assets/live_preview.json b/src/test/resources/assets/live_preview.json index 940d36bb..b00e673e 100644 --- a/src/test/resources/assets/live_preview.json +++ b/src/test/resources/assets/live_preview.json @@ -2,10 +2,10 @@ "entries": [ { "publish_details": { - "environment": "blt232b9b5897933fb4", + "environment": "the_uid", "time": "2022-09-23T11:13:39.756Z", "locale": "en-us", - "user": "bltc11e668e0295477f" + "user": "user_id" }, "link": { "href": "/data_structure_is_storage", @@ -15,23 +15,23 @@ "ACL": {}, "locale": "en-us", "title": "A data structure is a storage that is used to store and organize data", - "created_by": "bltc11e668e0295477f", - "rich_text_editor": "

A data structure is a storage that is used to store and organize data. It is a way of arranging data on a computer so that it can be accessed and updated efficiently.

A data structure is a storage that is used to store and organize data. It is a way of arranging data on a computer so that it can be accessed and updated efficiently.A data structure is a storage that is used to store and organize data. It is a way of arranging data on a computer so that it can be accessed and updated efficiently.









", + "created_by": "the_user", + "rich_text_editor": "

A data structure is a storage that is used to store and organize data. It is a way of arranging data on a computer so that it can be accessed and updated efficiently.

A data structure is a storage that is used to store and organize data. It is a way of arranging data on a computer so that it can be accessed and updated efficiently.A data structure is a storage that is used to store and organize data. It is a way of arranging data on a computer so that it can be accessed and updated efficiently.









", "url": "/data_structure", "tags": [ "data structure" ], - "uid": "bltc365833e25e676f3", + "uid": "the_uid", "updated_at": "2022-09-23T11:13:38.080Z", - "updated_by": "bltc11e668e0295477f", + "updated_by": "the_uid", "_version": 2 }, { "publish_details": { - "environment": "blt232b9b5897933fb4", + "environment": "the_uid", "time": "2022-09-22T11:55:20.616Z", "locale": "en-us", - "user": "bltc11e668e0295477f" + "user": "the_uid" }, "link": { "href": "https://images.pexels.com/photos/7276703/pexels-photo-7276703.jpeg?cs=srgb&dl=pexels-alejandro-peralta-7276703.jpg&fm=jpg", @@ -41,8 +41,8 @@ "ACL": {}, "locale": "en-us", "title": "What is Lorem Ipsum", - "created_by": "bltc11e668e0295477f", - "rich_text_editor": "

Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.

Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old. Richard McClintock, a Latin professor at Hampden-Sydney College in Virginia, looked up one of the more obscure Latin words, consectetur, from a Lorem Ipsum passage, and going through the cites of the word in classical literature, discovered the undoubtable source. Lorem Ipsum comes from sections 1.10.32 and 1.10.33 of \"de Finibus Bonorum et Malorum\" (The Extremes of Good and Evil) by Cicero, written in 45 BC. This book is a treatise on the theory of ethics, very popular during the Renaissance. The first line of Lorem Ipsum, \"Lorem ipsum dolor sit amet..\", comes from a line in section 1.10.32.


There are many variations of passages of Lorem Ipsum available, but the majority have suffered alteration in some form, by injected humour, or randomised words which don't look even slightly believable. If you are going to use a passage of Lorem Ipsum, you need to be sure there isn't anything embarrassing hidden in the middle of text. All the Lorem Ipsum generators on the Internet tend to repeat predefined chunks as necessary, making this the first true generator on the Internet. It uses a dictionary of over 200 Latin words, combined with a handful of model sentence structures, to generate Lorem Ipsum which looks reasonable. The generated Lorem Ipsum is therefore always free from repetition, injected humour, or non-characteristic words etc.


  1. camera.




", + "created_by": "the_uid", + "rich_text_editor": "

Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.

Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old. Richard McClintock, a Latin professor at Hampden-Sydney College in Virginia, looked up one of the more obscure Latin words, consectetur, from a Lorem Ipsum passage, and going through the cites of the word in classical literature, discovered the undoubtable source. Lorem Ipsum comes from sections 1.10.32 and 1.10.33 of \"de Finibus Bonorum et Malorum\" (The Extremes of Good and Evil) by Cicero, written in 45 BC. This book is a treatise on the theory of ethics, very popular during the Renaissance. The first line of Lorem Ipsum, \"Lorem ipsum dolor sit amet..\", comes from a line in section 1.10.32.


There are many variations of passages of Lorem Ipsum available, but the majority have suffered alteration in some form, by injected humour, or randomised words which don't look even slightly believable. If you are going to use a passage of Lorem Ipsum, you need to be sure there isn't anything embarrassing hidden in the middle of text. All the Lorem Ipsum generators on the Internet tend to repeat predefined chunks as necessary, making this the first true generator on the Internet. It uses a dictionary of over 200 Latin words, combined with a handful of model sentence structures, to generate Lorem Ipsum which looks reasonable. The generated Lorem Ipsum is therefore always free from repetition, injected humour, or non-characteristic words etc.


  1. camera.




", "url": "/hey-this-is-the-sample", "tags": [ "abdn", @@ -51,9 +51,9 @@ "nature", "loves" ], - "uid": "blt009591baa60f3f3b", + "uid": "the_uid", "updated_at": "2022-09-22T11:55:15.103Z", - "updated_by": "bltc11e668e0295477f", + "updated_by": "the_uid", "_version": 3 } ] From 3087a0760c27f70d0b739c6bf4d3ebe3b9c48bac Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 8 Feb 2023 12:33:19 +0530 Subject: [PATCH 042/104] :potted_plant: #67 resolved --- src/main/java/com/contentstack/sdk/Asset.java | 17 ++--- .../java/com/contentstack/sdk/AssetModel.java | 6 +- .../java/com/contentstack/sdk/Constants.java | 2 +- .../com/contentstack/sdk/ContentType.java | 48 +++++------- .../com/contentstack/sdk/Contentstack.java | 10 +-- src/main/java/com/contentstack/sdk/Entry.java | 76 +++++++++---------- src/main/java/com/contentstack/sdk/Error.java | 34 ++++----- src/main/java/com/contentstack/sdk/Group.java | 20 ++--- 8 files changed, 102 insertions(+), 111 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index a94f2efa..0c8ec14e 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -87,10 +87,10 @@ public Asset configure(JSONObject jsonObject) { * Example :
* *
-     *                         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                         Asset asset = stack.asset(asset_uid);
-     *                         asset.setHeader();
-     *                 
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Asset asset = stack.asset(asset_uid); + * asset.setHeader(); + *
*/ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { headers.put(headerKey, headerValue); @@ -107,10 +107,10 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * Example :
* *
-     *                         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                         Asset asset = stack.asset(asset_uid);
-     *                         asset.removeHeader();
-     *                        
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Asset asset = stack.asset(asset_uid); + * asset.removeHeader(); + *
*/ public void removeHeader(@NotNull String headerKey) { headers.remove(headerKey); @@ -419,7 +419,6 @@ public Calendar getDeleteAt() { * asset.getDeletedBy(); * } * }); - * * */ public String getDeletedBy() { diff --git a/src/main/java/com/contentstack/sdk/AssetModel.java b/src/main/java/com/contentstack/sdk/AssetModel.java index 15c4ffb3..d114e8a8 100644 --- a/src/main/java/com/contentstack/sdk/AssetModel.java +++ b/src/main/java/com/contentstack/sdk/AssetModel.java @@ -21,8 +21,10 @@ class AssetModel { /** * Instantiates a new Asset model. * - * @param response the response - * @param isArray the is array + * @param response + * the response + * @param isArray + * the is array */ public AssetModel(JSONObject response, boolean isArray) { diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index c7de78a6..f53dcdfb 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -109,7 +109,7 @@ private static Calendar toCalendar(@NotNull String date) { */ public static Calendar parseDate(@NotNull String date, TimeZone timeZone) { // Use the ISO-8601 format to parse the date string - if (date.isEmpty()){ + if (date.isEmpty()) { return null; } Calendar cal = toCalendar(date); diff --git a/src/main/java/com/contentstack/sdk/ContentType.java b/src/main/java/com/contentstack/sdk/ContentType.java index 3db038aa..e28a9792 100644 --- a/src/main/java/com/contentstack/sdk/ContentType.java +++ b/src/main/java/com/contentstack/sdk/ContentType.java @@ -10,10 +10,9 @@ /** * ContentType - * This call returns information of a specific content type. It returns the - * content type schema, but does not include - * its entries. + * "https://www.contentstack.com/docs/developers/apis/content-delivery-api/#single-content-type">ContentType This + * call returns information of a specific content type. It returns the content type schema, but does not include its + * entries. * * @author Shailesh Mishra * @version 1.0.0 @@ -43,9 +42,9 @@ protected void setStackInstance(Stack stack) { * Sets header on {@link Stack}. * * @param headerKey - * the header key + * the header key * @param headerValue - * the header value + * the header value */ public void setHeader(String headerKey, String headerValue) { if (!headerKey.isEmpty() && !headerValue.isEmpty()) { @@ -57,7 +56,7 @@ public void setHeader(String headerKey, String headerValue) { * Remove header from {@link Stack} * * @param headerKey - * the header key + * the header key */ public void removeHeader(String headerKey) { if (!headerKey.isEmpty()) { @@ -66,15 +65,13 @@ public void removeHeader(String headerKey) { } /** - * An entry is the actual piece of content created using one of the defined - * content types. + * An entry is the actual piece of content created using one of the defined content types. *

- * You can now pass the branch header in the API request to fetch or manage - * modules located within specific branches + * You can now pass the branch header in the API request to fetch or manage modules located within specific branches * of the stack. * * @param entryUid - * the entry unique ID of the entry that you want to fetch. + * the entry unique ID of the entry that you want to fetch. * @return the {@link Entry} entry. */ public Entry entry(String entryUid) { @@ -92,10 +89,8 @@ protected Entry entry() { } /** - * Query. The Get all entries request fetches the list of all the entries of a - * particular content type. It returns - * the content of each entry in JSON format. You need to specify the environment - * and locale of which you want to get + * Query. The Get all entries request fetches the list of all the entries of a particular content type. It returns + * the content of each entry in JSON format. You need to specify the environment and locale of which you want to get * the entries. * *

@@ -107,14 +102,10 @@ protected Entry entry() { * language itself, this parameter would not be applicable. * *

- * To include the publishing details in the response, make use of the - * include_publish_details=true parameter. This - * will return the publishing details of the entry in every environment along - * with the version number that is - * published in each of the environments. You can add other Queries to extend - * the functionality of this API call. - * Add a query parameter named query and provide your query (in JSON format) as - * the value. + * To include the publishing details in the response, make use of the include_publish_details=true parameter. This + * will return the publishing details of the entry in every environment along with the version number that is + * published in each of the environments. You can add other Queries to extend the functionality of this API call. + * Add a query parameter named query and provide your query (in JSON format) as the value. * * @return the {@link Query} */ @@ -129,10 +120,11 @@ public Query query() { * Fetch. * * @param params - * the params + * the params * @param callback - * the callback - * @throws IllegalAccessException illegal access exception + * the callback + * @throws IllegalAccessException + * illegal access exception */ public void fetch(@NotNull JSONObject params, final ContentTypesCallback callback) throws IllegalAccessException { String urlString = "content_types/" + contentTypeUid; @@ -150,7 +142,7 @@ public void fetch(@NotNull JSONObject params, final ContentTypesCallback callbac } private void fetchContentTypes(String urlString, JSONObject params, HashMap headers, - ContentTypesCallback callback) { + ContentTypesCallback callback) { if (callback != null) { HashMap urlParams = getUrlParams(params); new CSBackgroundTask(this, stackInstance, Constants.FETCHCONTENTTYPES, urlString, headers, urlParams, diff --git a/src/main/java/com/contentstack/sdk/Contentstack.java b/src/main/java/com/contentstack/sdk/Contentstack.java index 2b07f9ac..f56f513b 100644 --- a/src/main/java/com/contentstack/sdk/Contentstack.java +++ b/src/main/java/com/contentstack/sdk/Contentstack.java @@ -36,12 +36,12 @@ protected Contentstack() throws IllegalAccessException { * Example * *

-     *                                                   {
-     *                                                     @Code
-     *                                                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                   }
+     *                                                           {
+     *                                                             @Code
+     *                                                             Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
+     *                                                           }
      *
-     *                                                   
+ * */ public static Stack stack(String stackApiKey, String deliveryToken, String environment) throws IllegalAccessException { diff --git a/src/main/java/com/contentstack/sdk/Entry.java b/src/main/java/com/contentstack/sdk/Entry.java index 59e70c1e..bfb3eb1b 100644 --- a/src/main/java/com/contentstack/sdk/Entry.java +++ b/src/main/java/com/contentstack/sdk/Entry.java @@ -80,7 +80,7 @@ public Entry configure(JSONObject jsonObject) { * Example :
* *
-     *         
+ * */ public void setHeader(String key, String value) { @@ -98,10 +98,10 @@ public void setHeader(String key, String value) { * Example :
* *
-     *                                                         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                         Entry entry = stack.contentType("form_name").entry("entry_uid");
-     *                                                         entry.removeHeader("custom_header_key");
-     *                                                         
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid"); + * entry.removeHeader("custom_header_key"); + * */ public void removeHeader(String key) { @@ -244,8 +244,8 @@ public JSONObject toJSON() { * Example :
* *
-     *                                                                                                                                                                                    Object obj = entry.get("key");
-     *                                                                                                                                                                                    
+ * Object obj = entry.get("key"); + * * @return Object @resultJson */ public Object get(@NotNull String key) { @@ -261,8 +261,8 @@ public Object get(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                    String value = entry.getString("key");
-     *                                                                                                                                                                                    
+ * String value = entry.getString("key"); + * * @return String @getString */ @@ -283,8 +283,8 @@ public String getString(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                    Boolean value = entry.getBoolean("key");
-     *                                                                                                                                                                                    
+ * Boolean value = entry.getBoolean("key"); + * * @return boolean @getBoolean */ @@ -305,8 +305,8 @@ public Boolean getBoolean(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                    JSONArray value = entry.getJSONArray("key");
-     *                                                                                                                                                                                    
+ * JSONArray value = entry.getJSONArray("key"); + * * @return JSONArray @getJSONArray */ @@ -327,8 +327,8 @@ public JSONArray getJSONArray(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                    JSONObject value = entry.getJSONObject("key");
-     *                                                                                                                                                                                    
+ * JSONObject value = entry.getJSONObject("key"); + * * @return JSONObject @getJSONObject */ public JSONObject getJSONObject(@NotNull String key) { @@ -348,8 +348,8 @@ public JSONObject getJSONObject(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                    JSONObject value = entry.getJSONObject("key");
-     *                                                                                                                                                                                    
+ * JSONObject value = entry.getJSONObject("key"); + * * @return Number @getNumber */ @@ -370,8 +370,8 @@ public Number getNumber(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                    int value = entry.getInt("key");
-     *                                                                                                                                                                                    
+ * int value = entry.getInt("key"); + * * @return int @getInt */ @@ -436,8 +436,8 @@ public double getDouble(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                    long value = entry.getLong("key");
-     *                                                                                                                                                                                    
+ * long value = entry.getLong("key"); + * * @return long @getLong */ @@ -460,8 +460,8 @@ public long getLong(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                    short value = entry.getShort("key");
-     *                                                                                                                                                                                    
+ * short value = entry.getShort("key"); + * * @return short @getShort */ public short getShort(@NotNull String key) { @@ -481,8 +481,8 @@ public short getShort(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                    Calendar value = entry.getDate("key");
-     *                                                                                                                                                                                    
+ * Calendar value = entry.getDate("key"); + * * @return Calendar @getDate */ @@ -664,9 +664,9 @@ public List getAssets(String key) { * Example :
* *
-     *                                                                                                                                                                                     Group innerGroup = entry.getGroup("key");
-     *                                                                                                                                                                                     return null
-     *                                                                                                                                                                                    
+ * Group innerGroup = entry.getGroup("key"); + * return null + * * @return {@link Group} */ public Group getGroup(String key) { @@ -892,16 +892,16 @@ public Entry exceptWithReferenceUid(@NotNull List fieldUid, @NotNull Str * Example :
* *
-     *                                          {@code
-     *                                          Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                          Entry entry = stack.contentType("form_name").entry("entry_uid");
- * entry.fetch(new EntryResultCallBack() {
- * @Override - * public void onCompletion(ResponseType responseType, Error error) { - * }
- * });
- * } - *
+ * {@code + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid");
+ * entry.fetch(new EntryResultCallBack() {
+ * @Override + * public void onCompletion(ResponseType responseType, Error error) { + * }
+ * });
+ * } + * */ public void fetch(EntryResultCallBack callback) { diff --git a/src/main/java/com/contentstack/sdk/Error.java b/src/main/java/com/contentstack/sdk/Error.java index 86306791..a5277339 100644 --- a/src/main/java/com/contentstack/sdk/Error.java +++ b/src/main/java/com/contentstack/sdk/Error.java @@ -1,8 +1,7 @@ package com.contentstack.sdk; /** - * If there is something wrong with the API request, Contentstack returns an - * error. + * If there is something wrong with the API request, Contentstack returns an error. */ public class Error { @@ -21,14 +20,13 @@ public Error(String errorMessage, int errorCode, String errDetails) { } /** - * * Returns error in string format. - * + * * @return String error message
- *
- * Example :
- * - *
+     * 
+ * Example :
+ * + *
      *         String errorString = error.getErrorMessage();
      *         
*/ @@ -42,12 +40,12 @@ protected void setErrorMessage(String errorMessage) { /** * Returns error code - * + * * @return int value.
- *
- * Example :
- * - *
+     * 
+ * Example :
+ * + *
      *         int errorCode = error.getErrorCode();
      *         
*/ @@ -61,12 +59,12 @@ protected void setErrorCode(int errorCode) { /** * Returns error details in {@linkplain String} - * + * * @return String
- *
- * Example :
- * - *
+     * 
+ * Example :
+ * + *
      *         String error = error.getErrorDetail();
      *         
*/ diff --git a/src/main/java/com/contentstack/sdk/Group.java b/src/main/java/com/contentstack/sdk/Group.java index 8ddb4efd..3dd575b9 100644 --- a/src/main/java/com/contentstack/sdk/Group.java +++ b/src/main/java/com/contentstack/sdk/Group.java @@ -323,9 +323,9 @@ public Asset getAsset(String key) { * Example :
* *
-     *                                                                                                                                      {@code List asset = group.getAssets("key"); }
-     *                                                                                                                                      @return ArrayList of {@link Asset}
-     *                                                                                                                                    
+ * {@code List asset = group.getAssets("key"); } + * @return ArrayList of {@link Asset} + *
*/ public List getAssets(String key) { List assets = new ArrayList<>(); @@ -347,10 +347,10 @@ public List getAssets(String key) { *
* Example :
*
-     *                                                                                                          Group innerGroup = group.getGroup("key");
-     *                                                                                                          @return Group
-     *                                                                                                          object
-     *                                                                                                          
+ * Group innerGroup = group.getGroup("key"); + * @return Group + * object + *
* @return the group */ public Group getGroup(String key) { @@ -371,9 +371,9 @@ public Group getGroup(String key) { * Example :
* *
-     *                                                                                                                                      Group innerGroup = group.getGroups("key");
-     *                                                                                                                                 @return List of {@link Group}
-     *                                                                                                                                    
+ * Group innerGroup = group.getGroups("key"); + * @return List of {@link Group} + *
*/ public List getGroups(String key) { List groupList = new ArrayList<>(); From 589d6e1f3300898827da0964989042c5cfc68a97 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 8 Feb 2023 12:44:09 +0530 Subject: [PATCH 043/104] :potted_plant: #67 resolved --- src/main/java/com/contentstack/sdk/Query.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/Query.java b/src/main/java/com/contentstack/sdk/Query.java index a8cd73db..0ad33ae0 100644 --- a/src/main/java/com/contentstack/sdk/Query.java +++ b/src/main/java/com/contentstack/sdk/Query.java @@ -1294,9 +1294,9 @@ public void getResultObject(List objects, JSONObject jsonObject, boolean /** * This method adds key and value to an Entry. Parameters: * - * @param paramKey: + * @param key: * The key as string which needs to be added to the Query - * @param paramValue: + * @param value: * The value as string which needs to be added to the Query * @return - Query * @@ -1315,8 +1315,8 @@ public void getResultObject(List objects, JSONObject jsonObject, boolean * }); * */ - public Query addParam(@NotNull String paramKey, @NotNull String paramValue) { - urlQueries.put(paramKey, paramValue); + public Query addParam(@NotNull String key, @NotNull String value) { + urlQueries.put(key, value); return this; } From 72e487fab94038614899249d763486fd7f873251 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 8 Feb 2023 12:52:23 +0530 Subject: [PATCH 044/104] :potted_plant: #67 resolved --- .github/workflows/maven-publish.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 60bb183c..414709ba 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -2,7 +2,6 @@ name: Publish package to the Maven Central Repository on: release: types: [ created ] - push: jobs: publish-maven: runs-on: ubuntu-latest From 2e31abfb3ff17cedbc03c0bc0b587e53b0e21614 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 8 Feb 2023 13:11:16 +0530 Subject: [PATCH 045/104] :potted_plant: #67 pom.xml and CHANGELOG.md updated --- CHANGELOG.md | 9 +++++++++ pom.xml | 4 ++-- src/main/java/com/contentstack/sdk/Constants.java | 2 +- src/main/java/com/contentstack/sdk/Stack.java | 2 +- 4 files changed, 13 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 52c85cdc..c3003c60 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,14 @@ # CHANGELOG +## v1.11.0 + +### Date: 09-FEB-2023 + +- Addition of Plugin Support, +- #67 error handling infinite loop issue +- Breaking changes: Enums PublishType changed to snake-case to CAPITAL +- Basic improvements + ## v1.10.2 ### Date: 22-Oct-2022 diff --git a/pom.xml b/pom.xml index 4c1ed484..710393cb 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.10.2-SNAPSHOT + 1.11.0-SNAPSHOT jar contentstack-java Java SDK for Contentstack Content Delivery API @@ -13,7 +13,7 @@ - 1.10.2-SNAPSHOT + 1.11.0-SNAPSHOT 1.8 1.8 UTF-8 diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index f53dcdfb..b6e62c82 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -21,7 +21,7 @@ public class Constants { private static final Logger logger = Logger.getLogger(Constants.class.getSimpleName()); - protected static final String SDK_VERSION = "1.10.2"; + protected static final String SDK_VERSION = "1.11.0"; protected static final String ENVIRONMENT = "environment"; protected static final String CONTENT_TYPE_UID = "content_type_uid"; protected static final String ENTRY_UID = "entry_uid"; diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java index d9bf6b2b..51b986af 100644 --- a/src/main/java/com/contentstack/sdk/Stack.java +++ b/src/main/java/com/contentstack/sdk/Stack.java @@ -554,7 +554,7 @@ private HashMap getUrlParams(JSONObject jsonQuery) { */ public enum PublishType { //asset_deleted, asset_published, asset_unpublished, content_type_deleted, entry_deleted, entry_published, - // Breaking change in v3.10.2 + // Breaking change in v3.11.0 ASSET_DELETED, ASSET_PUBLISHED, ASSET_UNPUBLISHED, From 4a278170a25cd215bcaa75ec952a105775365351 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 9 Feb 2023 13:11:03 +0530 Subject: [PATCH 046/104] :potted_plant: LICENSE file updated --- CHANGELOG.md | 4 +- LICENSE | 2 +- README.md | 26 ++- src/main/java/com/contentstack/sdk/Asset.java | 193 +++++++++--------- .../com/contentstack/sdk/AssetLibrary.java | 31 +-- .../java/com/contentstack/sdk/AssetModel.java | 4 +- .../contentstack/sdk/CSHttpConnection.java | 2 - .../java/com/contentstack/sdk/Config.java | 41 ++-- .../java/com/contentstack/sdk/Constants.java | 16 +- .../com/contentstack/sdk/ContentType.java | 48 +++-- .../com/contentstack/sdk/Contentstack.java | 80 +++++--- .../java/com/contentstack/sdk/TestAsset.java | 6 +- .../com/contentstack/sdk/TestAzureRegion.java | 5 - .../java/com/contentstack/sdk/TestEntry.java | 12 +- .../java/com/contentstack/sdk/TestQuery.java | 38 ++-- .../java/com/contentstack/sdk/TestStack.java | 1 - 16 files changed, 263 insertions(+), 246 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c3003c60..2c558715 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,8 +6,8 @@ - Addition of Plugin Support, - #67 error handling infinite loop issue -- Breaking changes: Enums PublishType changed to snake-case to CAPITAL -- Basic improvements +- Breaking change: Enums PublishType changed from snake-case to ALL_CAPS +- Basic Improvements ## v1.10.2 diff --git a/LICENSE b/LICENSE index 0e7d6f3b..981ba261 100644 --- a/LICENSE +++ b/LICENSE @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2012 - 2022 Contentstack +Copyright (c) 2012 - 2023 Contentstack Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/README.md b/README.md index 05c88c4d..f8c1bd4f 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -[![Contentstack](https://www.contentstack.com/docs/static/images/contentstack.png)](https://www.contentstack.com/) +# [![Contentstack](https://www.contentstack.com/docs/static/images/contentstack.png)](https://www.contentstack.com/) ## Java SDK for Contentstack @@ -6,7 +6,6 @@ Contentstack is a headless CMS with an API-first approach. It is a CMS that deve Contentstack provides Java SDK to build application on top of Java. Given below is the detailed guide and helpful resources to get started with our Java SDK. - ### Prerequisite You will need JDK installed on your machine. You can install it from [here](http://www.oracle.com/technetwork/java/javase/downloads/jdk9-downloads-3848520.html). @@ -15,13 +14,14 @@ You will need JDK installed on your machine. You can install it from [here](http To use the Contentstack Java SDK to your existing project, perform the steps given below: -Group id: `com.contentstack.sdk` +Group Id: ```com.contentstack.sdk``` + +Artifact Id: ```java``` -Artifact id: `java` +[LATEST VERSION](https://search.maven.org/artifact/com.contentstack.sdk/java) -[{ version }](https://search.maven.org/artifact/com.contentstack.sdk/java) +#### Maven -1. **Maven** ```java com.contentstack.sdk @@ -30,7 +30,8 @@ Artifact id: `java` ``` -2. **Gradle** +#### Gradle + ```java implementation 'com.contentstack.sdk:java:{version}' ``` @@ -59,19 +60,17 @@ Assets refer to all the media files (images, videos, PDFs, audio files, and so o A publishing environment corresponds to one or more deployment servers or a content delivery destination where the entries need to be published. Learn how to work with [Environments](https://www.contentstack.com/docs/guide/environments). - - ### Contentstack Java SDK: 5-minute Quickstart #### Initializing your SDK To initialize the SDK, specify application API key, access token, and environment name of the stack as shown in the snippet given below: + ```java Stack stack=Contentstack.stack("apiKey","accessToken","environment"); ``` -To get the API credentials mentioned above, log in to your Contentstack account and then in your top panel navigation, go to Settings > Stack to view the API Key and Access Token. - +To get the API credentials mentioned above, log in to your Contentstack account and then in your top panel navigation, go to Settings > Stack to view the API Key and Access Token. #### Querying content from your stack @@ -101,7 +100,7 @@ To retrieve multiple entries of a particular content type, use the code snippet Query query = stack.contentType("content_type_uid").query(); query.find(new QueryResultsCallBack(){ @Override - public void onCompletion(ResponseType responseType, QueryResult queryResult, Error error) { +public void onCompletion(ResponseType responseType, QueryResult queryResult, Error error) { if(error == null){ //Success block }else{ @@ -110,7 +109,6 @@ query.find(new QueryResultsCallBack(){ }); ``` - ### Advanced Queries You can query for content types, entries, assets and more using our Java API Reference. @@ -121,7 +119,7 @@ You can query for content types, entries, assets and more using our Java API Ref We have introduced Image Delivery APIs that let you retrieve images and then manipulate and optimize them for your digital properties. It lets you perform a host of other actions such as crop, trim, resize, rotate, overlay, and so on. -For example, if you want to crop an image (with width as 300 and height as 400), you simply need to append query parameters at the end of the image URL, such as, https://images.contentstack.io/v3/assets/download?crop=300,400. There are several more parameters that you can use for your images. +For example, if you want to crop an image (with width as 300 and height as 400), you simply need to append query parameters at the end of the image URL, such as, ,400. There are several more parameters that you can use for your images. [Read Image Delivery API documentation](https://www.contentstack.com/docs/apis/image-delivery-api/). diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index 0c8ec14e..f4d507fe 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -14,11 +14,14 @@ import static com.contentstack.sdk.Constants.parseDate; /** - * Assets - * refer to all the media files (images, videos, PDFs, audio files, and so on) uploaded in your Contentstack repository + * Assets + * refer to all the media files (images, videos, PDFs, audio files, and so on) + * uploaded in your Contentstack repository * for future use. These files can be attached and used in multiple entries. *

- * You can now pass the branch header in the API request to fetch or manage modules located within specific branches of + * You can now pass the branch header in the API request to fetch or manage + * modules located within specific branches of * the stack. * * @author Shailesh Mishra @@ -58,7 +61,7 @@ protected void setStackInstance(@NotNull Stack stack) { * Configure asset. * * @param jsonObject - * the json object + * the json object * @return the asset */ public Asset configure(JSONObject jsonObject) { @@ -78,19 +81,19 @@ public Asset configure(JSONObject jsonObject) { * Sets header. * * @param headerKey - * the header key + * the header key * @param headerValue - * the header value + * the header value * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *

-     *                                 Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                 Asset asset = stack.asset(asset_uid);
-     *                                 asset.setHeader();
-     *                         
+ *
+     *                    Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
+     *                    Asset asset = stack.asset(asset_uid);
+     *                    asset.setHeader();
+     *                    
*/ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { headers.put(headerKey, headerValue); @@ -100,17 +103,17 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * Remove header. * * @param headerKey - * the header key + * the header key * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
-     *                                 Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                 Asset asset = stack.asset(asset_uid);
-     *                                 asset.removeHeader();
-     *                                
+ *
+     *                  Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
+     *                  Asset asset = stack.asset(asset_uid);
+     *                  asset.removeHeader();
+     *                  
*/ public void removeHeader(@NotNull String headerKey) { headers.remove(headerKey); @@ -127,11 +130,11 @@ protected void setUid(@NotNull String assetUid) { * * @return the asset uid * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -152,11 +155,11 @@ public String getAssetUid() {
      *
      * @return the file type
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -177,11 +180,11 @@ public String getFileType() {
      *
      * @return the file size
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -202,11 +205,11 @@ public String getFileSize() {
      *
      * @return the file name
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -227,11 +230,11 @@ public String getFileName() {
      *
      * @return the url
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -252,11 +255,11 @@ public String getUrl() {
      *
      * @return the json object
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -278,11 +281,11 @@ public JSONObject toJSON() {
      * @return the create at
      *
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -304,11 +307,11 @@ public Calendar getCreateAt() {
      * @return the created by
      *
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -330,11 +333,11 @@ public String getCreatedBy() {
      * @return the update at
      *
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -356,11 +359,11 @@ public Calendar getUpdateAt() {
      * @return the updated by
      *
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -381,11 +384,11 @@ public String getUpdatedBy() {
      *
      * @return the delete at
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -406,11 +409,11 @@ public Calendar getDeleteAt() {
      *
      * @return the deleted by
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -431,11 +434,11 @@ public String getDeletedBy() {
      * @return the string [ ]
      *
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -461,11 +464,11 @@ protected Asset setTags(String[] tags) {
      *
      * @return the asset
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.includeDimension();
@@ -480,16 +483,16 @@ public Asset includeDimension() {
      * Add param asset.
      *
      * @param paramKey
-     *         the param key
+     *                   the param key
      * @param paramValue
-     *         the param value
+     *                   the param value
      * @return the asset
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.addParam();
@@ -506,11 +509,11 @@ public Asset addParam(@NotNull String paramKey, @NotNull String paramValue) {
      * @return the asset
      *
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.includeFallback();
@@ -526,11 +529,11 @@ public Asset includeFallback() {
      *
      * @return {@link Asset} object, so you can chain this call. 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.includeBranch();
@@ -545,7 +548,7 @@ public Asset includeBranch() {
      * Fetch.
      *
      * @param callback
-     *         the callback
+     *                 the callback
      */
     public void fetch(FetchResultCallback callback) {
         urlQueries.put(ENVIRONMENT, this.headers.get(ENVIRONMENT));
@@ -553,7 +556,7 @@ public void fetch(FetchResultCallback callback) {
     }
 
     private void fetchFromNetwork(String url, JSONObject urlQueries, LinkedHashMap headers,
-                                  FetchResultCallback callback) {
+            FetchResultCallback callback) {
         if (callback != null) {
             HashMap urlParams = getUrlParams(urlQueries);
             new CSBackgroundTask(this, stackInstance, Constants.FETCHASSETS, url, headers, urlParams,
diff --git a/src/main/java/com/contentstack/sdk/AssetLibrary.java b/src/main/java/com/contentstack/sdk/AssetLibrary.java
index 9a66504e..3849b15f 100644
--- a/src/main/java/com/contentstack/sdk/AssetLibrary.java
+++ b/src/main/java/com/contentstack/sdk/AssetLibrary.java
@@ -10,8 +10,10 @@
 import static com.contentstack.sdk.Constants.ENVIRONMENT;
 
 /**
- * The Asset library is used to get list of assets available in the stack, We can apply filters on the assets also.
- * The Get all assets request fetches the list of all the assets of a particular stack. It returns the content of each
+ * The Asset library is used to get list of assets available in the stack, We
+ * can apply filters on the assets also.
+ * The Get all assets request fetches the list of all the assets of a particular
+ * stack. It returns the content of each
  * asset in JSON format.
  */
 public class AssetLibrary implements INotifyClass {
@@ -22,8 +24,6 @@ public class AssetLibrary implements INotifyClass {
     protected LinkedHashMap headers;
     protected FetchAssetsCallback callback;
     protected int count;
-    protected Retrofit retrofit;
-
     protected AssetLibrary() {
         this.urlQueries = new JSONObject();
     }
@@ -37,9 +37,9 @@ protected void setStackInstance(@NotNull Stack stack) {
      * Sets header.
      *
      * @param headerKey
-     *         the header key
+     *                    the header key
      * @param headerValue
-     *         the header value
+     *                    the header value
      */
     public void setHeader(@NotNull String headerKey, @NotNull String headerValue) {
         this.headers.put(headerKey, headerValue);
@@ -49,7 +49,7 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) {
      * Remove header.
      *
      * @param headerKey
-     *         the header key
+     *                  the header key
      */
     public void removeHeader(@NotNull String headerKey) {
         if (!headerKey.isEmpty()) {
@@ -61,9 +61,9 @@ public void removeHeader(@NotNull String headerKey) {
      * Sort asset library.
      *
      * @param keyOrderBy
-     *         the key order by
+     *                   the key order by
      * @param orderby
-     *         the orderby
+     *                   the orderby
      * @return the asset library
      */
     public AssetLibrary sort(String keyOrderBy, ORDERBY orderby) {
@@ -96,13 +96,14 @@ public AssetLibrary includeRelativeUrl() {
     }
 
     /**
-     * Retrieve the published content of the fallback locale if an entry is not localized in specified locale
+     * Retrieve the published content of the fallback locale if an entry is not
+     * localized in specified locale
      *
      * @return {@link AssetLibrary} object, so you can chain this call. 
- *
- * Example :
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         AssetLibrary assetLibObject = stack.assetLibrary();
      *         AssetLibrary.includeFallback();
@@ -126,7 +127,7 @@ public int getCount() {
      * Fetch all.
      *
      * @param callback
-     *         the callback
+     *                 the callback
      */
     public void fetchAll(FetchAssetsCallback callback) {
         this.callback = callback;
@@ -135,7 +136,7 @@ public void fetchAll(FetchAssetsCallback callback) {
     }
 
     private void fetchFromNetwork(String url, JSONObject urlQueries, LinkedHashMap headers,
-                                  FetchAssetsCallback callback) {
+            FetchAssetsCallback callback) {
         if (callback != null) {
             HashMap urlParams = getUrlParams(urlQueries);
             new CSBackgroundTask(this, stackInstance, Constants.FETCHALLASSETS, url, headers, urlParams,
diff --git a/src/main/java/com/contentstack/sdk/AssetModel.java b/src/main/java/com/contentstack/sdk/AssetModel.java
index d114e8a8..c0d84f08 100644
--- a/src/main/java/com/contentstack/sdk/AssetModel.java
+++ b/src/main/java/com/contentstack/sdk/AssetModel.java
@@ -22,9 +22,9 @@ class AssetModel {
      * Instantiates a new Asset model.
      *
      * @param response
-     *         the response
+     *                 the response
      * @param isArray
-     *         the is array
+     *                 the is array
      */
     public AssetModel(JSONObject response, boolean isArray) {
 
diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java
index 2cabfa01..38792649 100644
--- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java
+++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java
@@ -231,7 +231,6 @@ private Response pluginResponseImp(Request request, Response
Example:

- * + * Proxy setting, typically a type (http, socks) and a socket + * address. A Proxy is an immutable object + *
+ *
+ * Example:
+ *
+ * * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("proxyHost", "proxyPort")); * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("sl.theproxyvpn.io", 80)); Config * config = new Config(); config.setProxy(proxy); @@ -67,18 +70,19 @@ public Proxy getProxy() { return this.proxy; } - /** - * Manages reuse of HTTP and HTTP/2 connections for reduced network latency. HTTP requests that * share the same - * {@link okhttp3.Address} may share a {@link okhttp3.Connection}. This class implements the policy * of which + * Manages reuse of HTTP and HTTP/2 connections for reduced network latency. + * HTTP requests that * share the same + * {@link okhttp3.Address} may share a {@link okhttp3.Connection}. This class + * implements the policy * of which * connections to keep open for future use. * * @param maxIdleConnections - * the maxIdleConnections default value is 5 + * the maxIdleConnections default value is 5 * @param keepAliveDuration - * the keepAliveDuration default value is 5 + * the keepAliveDuration default value is 5 * @param timeUnit - * the timeUnit default value is TimeUnit.MINUTES + * the timeUnit default value is TimeUnit.MINUTES * @return ConnectionPool */ public ConnectionPool connectionPool(int maxIdleConnections, long keepAliveDuration, TimeUnit timeUnit) { @@ -99,7 +103,7 @@ public ContentstackRegion getRegion() { * Sets region. * * @param region - * the region + * the region * @return the region */ public ContentstackRegion setRegion(ContentstackRegion region) { @@ -132,7 +136,7 @@ public String getHost() { * Sets host. * * @param hostName - * the host name + * the host name */ public void setHost(String hostName) { if (hostName != null && !hostName.isEmpty()) { @@ -153,7 +157,7 @@ public String getVersion() { * Enable live preview config. * * @param enableLivePreview - * to enable live preview + * to enable live preview * @return the config */ public Config enableLivePreview(boolean enableLivePreview) { @@ -165,7 +169,7 @@ public Config enableLivePreview(boolean enableLivePreview) { * Sets live preview host. * * @param livePreviewHost - * the live preview host + * the live preview host * @return the live preview host */ public Config setLivePreviewHost(@NotNull String livePreviewHost) { @@ -182,7 +186,7 @@ protected Config setLivePreviewEntry(@NotNull JSONObject livePreviewEntry) { * Sets management token. * * @param managementToken - * the management token + * the management token * @return the management token */ public Config setManagementToken(@NotNull String managementToken) { @@ -191,7 +195,8 @@ public Config setManagementToken(@NotNull String managementToken) { } /** - * The enum Contentstack region. for now contentstack supports [US, EU, AZURE_NA] + * The enum Contentstack region. for now contentstack supports [US, EU, + * AZURE_NA] */ public enum ContentstackRegion { US, EU, AZURE_NA diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index b6e62c82..e500c97f 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -70,16 +70,14 @@ public enum REQUEST_CONTROLLER { public static final String CONTENT_TYPE_NAME = "Please set contentType name."; public static final String QUERY_EXCEPTION = "Please provide valid params."; - /** * @param dateString - * the date in string format + * the date in string format * @param zoneId - * the string zoneId + * the string zoneId * @return Calendar */ public static Calendar parseDateToTimeZone(@NotNull String dateString, @NotNull String zoneId) { - //String dateString = "2016-12-16T12:36:33.961Z"; Instant instant = Instant.parse(dateString); // Define the target time zone ZoneId targetTimeZone = ZoneId.of(zoneId); @@ -87,7 +85,8 @@ public static Calendar parseDateToTimeZone(@NotNull String dateString, @NotNull ZonedDateTime dateTime = instant.atZone(targetTimeZone); // Extract the year, month, day, hour, minute, and second Calendar cal = Calendar.getInstance(); - cal.set(dateTime.getYear(), dateTime.getMonthValue(), dateTime.getDayOfMonth(), dateTime.getHour(), dateTime.getMinute(), dateTime.getSecond()); + cal.set(dateTime.getYear(), dateTime.getMonthValue(), dateTime.getDayOfMonth(), dateTime.getHour(), + dateTime.getMinute(), dateTime.getSecond()); return cal; } @@ -99,16 +98,15 @@ private static Calendar toCalendar(@NotNull String date) { return cal; } - /** * @param date - * The date in string format like (String dateString = "2016-12-16T12:36:33.961Z";) + * The date in string format like (String dateString = + * "2016-12-16T12:36:33.961Z";) * @param timeZone - * the time zone as string + * the time zone as string * @return calendar @{@link Calendar} */ public static Calendar parseDate(@NotNull String date, TimeZone timeZone) { - // Use the ISO-8601 format to parse the date string if (date.isEmpty()) { return null; } diff --git a/src/main/java/com/contentstack/sdk/ContentType.java b/src/main/java/com/contentstack/sdk/ContentType.java index e28a9792..ae2d2ee9 100644 --- a/src/main/java/com/contentstack/sdk/ContentType.java +++ b/src/main/java/com/contentstack/sdk/ContentType.java @@ -10,8 +10,10 @@ /** * ContentType This - * call returns information of a specific content type. It returns the content type schema, but does not include its + * "https://www.contentstack.com/docs/developers/apis/content-delivery-api/#single-content-type">ContentType + * This + * call returns information of a specific content type. It returns the content + * type schema, but does not include its * entries. * * @author Shailesh Mishra @@ -21,7 +23,7 @@ public class ContentType { protected static final Logger logger = Logger.getLogger(ContentType.class.getSimpleName()); - protected String contentTypeUid = null; + protected String contentTypeUid; protected Stack stackInstance = null; protected LinkedHashMap headers = null; @@ -42,9 +44,9 @@ protected void setStackInstance(Stack stack) { * Sets header on {@link Stack}. * * @param headerKey - * the header key + * the header key * @param headerValue - * the header value + * the header value */ public void setHeader(String headerKey, String headerValue) { if (!headerKey.isEmpty() && !headerValue.isEmpty()) { @@ -56,7 +58,7 @@ public void setHeader(String headerKey, String headerValue) { * Remove header from {@link Stack} * * @param headerKey - * the header key + * the header key */ public void removeHeader(String headerKey) { if (!headerKey.isEmpty()) { @@ -65,13 +67,15 @@ public void removeHeader(String headerKey) { } /** - * An entry is the actual piece of content created using one of the defined content types. + * An entry is the actual piece of content created using one of the defined + * content types. *

- * You can now pass the branch header in the API request to fetch or manage modules located within specific branches + * You can now pass the branch header in the API request to fetch or manage + * modules located within specific branches * of the stack. * * @param entryUid - * the entry unique ID of the entry that you want to fetch. + * the entry unique ID of the entry that you want to fetch. * @return the {@link Entry} entry. */ public Entry entry(String entryUid) { @@ -89,8 +93,10 @@ protected Entry entry() { } /** - * Query. The Get all entries request fetches the list of all the entries of a particular content type. It returns - * the content of each entry in JSON format. You need to specify the environment and locale of which you want to get + * Query. The Get all entries request fetches the list of all the entries of a + * particular content type. It returns + * the content of each entry in JSON format. You need to specify the environment + * and locale of which you want to get * the entries. * *

@@ -102,10 +108,14 @@ protected Entry entry() { * language itself, this parameter would not be applicable. * *

- * To include the publishing details in the response, make use of the include_publish_details=true parameter. This - * will return the publishing details of the entry in every environment along with the version number that is - * published in each of the environments. You can add other Queries to extend the functionality of this API call. - * Add a query parameter named query and provide your query (in JSON format) as the value. + * To include the publishing details in the response, make use of the + * include_publish_details=true parameter. This + * will return the publishing details of the entry in every environment along + * with the version number that is + * published in each of the environments. You can add other Queries to extend + * the functionality of this API call. + * Add a query parameter named query and provide your query (in JSON format) as + * the value. * * @return the {@link Query} */ @@ -120,11 +130,11 @@ public Query query() { * Fetch. * * @param params - * the params + * the params * @param callback - * the callback + * the callback * @throws IllegalAccessException - * illegal access exception + * illegal access exception */ public void fetch(@NotNull JSONObject params, final ContentTypesCallback callback) throws IllegalAccessException { String urlString = "content_types/" + contentTypeUid; @@ -142,7 +152,7 @@ public void fetch(@NotNull JSONObject params, final ContentTypesCallback callbac } private void fetchContentTypes(String urlString, JSONObject params, HashMap headers, - ContentTypesCallback callback) { + ContentTypesCallback callback) { if (callback != null) { HashMap urlParams = getUrlParams(params); new CSBackgroundTask(this, stackInstance, Constants.FETCHCONTENTTYPES, urlString, headers, urlParams, diff --git a/src/main/java/com/contentstack/sdk/Contentstack.java b/src/main/java/com/contentstack/sdk/Contentstack.java index f56f513b..aa7fe895 100644 --- a/src/main/java/com/contentstack/sdk/Contentstack.java +++ b/src/main/java/com/contentstack/sdk/Contentstack.java @@ -3,12 +3,17 @@ import java.util.Objects; /** - * The Content Delivery API is used to retrieve content from your Contentstack account and deliver it to your web or - * mobile properties. If you are looking for APIs to manage content, you should use the Content Management API + * The Content Delivery API is used to retrieve content from your Contentstack + * account and deliver it to your web or + * mobile properties. If you are looking for APIs to manage content, you should + * use the Content Management API *

- * Our APIs serve content via a powerful and robust content delivery network (CDN). Multiple datacenters around the - * world store a cached copy of your content. When a page request is made, the content is delivered to the user from the - * nearest server. This greatly accelerates content delivery and reduces latency. + * Our APIs serve content via a powerful and robust content delivery network + * (CDN). Multiple datacenters around the + * world store a cached copy of your content. When a page request is made, the + * content is delivered to the user from the + * nearest server. This greatly accelerates content delivery and reduces + * latency. */ public class Contentstack { @@ -18,30 +23,35 @@ protected Contentstack() throws IllegalAccessException { } /** - * A stack is a space that stores the content of a project (a web or mobile property). Within a stack, you can - * create content structures, content entries, users, etc. related to the project.
Authenticates the stack api - * key of your stack.
Find Your Stack Credentials from Contentstack . + * A stack is a space that stores the content of a project (a web or mobile + * property). Within a stack, you can + * create content structures, content entries, users, etc. related to the + * project.
+ * Authenticates the stack api + * key of your stack.
+ * Find Your Stack Credentials from Contentstack . * * @param stackApiKey - * The API Key is a unique key assigned to each stack. + * The API Key is a unique key assigned to each stack. * @param deliveryToken - * The Delivery Token is a read-only credential that you can create for different environments of your - * stack + * The Delivery Token is a read-only credential that you + * can create for different environments of your + * stack * @param environment - * the environment for the stack + * the environment for the stack * @return the stack * @throws IllegalAccessException - * the illegal access exception - *

- * Example + * the illegal access exception + *

+ * Example * - *

-     *                                                           {
-     *                                                             @Code
-     *                                                             Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                           }
+     *                                
+     *                                {
+     *                                    @Code
+     *                                    Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
+     *                                }
      *
-     *                                                           
+ *
*/ public static Stack stack(String stackApiKey, String deliveryToken, String environment) throws IllegalAccessException { @@ -51,23 +61,28 @@ public static Stack stack(String stackApiKey, String deliveryToken, String envir } /** - * A stack is a space that stores the content of a project (a web or mobile property). Within a stack, you can - * create content structures, content entries, users, etc. related to the project. + * A stack is a space that stores the content of a project (a web or mobile + * property). Within a stack, you can + * create content structures, content entries, users, etc. related to the + * project. * * @param stackApiKey - * The API Key is a unique key assigned to each stack. + * The API Key is a unique key assigned to each stack. * @param deliveryToken - * The Delivery Token is a read-only credential that you can create for different environments of your - * stack + * The Delivery Token is a read-only credential that you + * can create for different environments of your + * stack * @param environment - * the environment for the stack + * the environment for the stack * @param config - * the config + * the config * @return the stack * @throws IllegalAccessException - * the illegal access exception Example - *

- * { @Code Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); } + * the illegal access exception Example + *

+ * { @Code Stack stack = + * contentstack.Stack("apiKey", "deliveryToken", + * "environment"); } */ public static Stack stack(String stackApiKey, String deliveryToken, String environment, Config config) throws IllegalAccessException { @@ -75,7 +90,6 @@ public static Stack stack(String stackApiKey, String deliveryToken, String envir return initializeStack(stackApiKey, deliveryToken, environment, config); } - private static void validateCredentials(String stackApiKey, String deliveryToken, String environment) throws IllegalAccessException { Objects.requireNonNull(stackApiKey, "API Key can not be null"); @@ -93,7 +107,6 @@ private static void validateCredentials(String stackApiKey, String deliveryToken } } - private static Stack initializeStack(String stackApiKey, String deliveryToken, String environment, Config config) { Stack stack = new Stack(stackApiKey.trim()); stack.setHeader("api_key", stackApiKey); @@ -102,7 +115,6 @@ private static Stack initializeStack(String stackApiKey, String deliveryToken, S if (config.getBranch() != null && !config.getBranch().isEmpty()) { stack.setHeader("branch", config.getBranch()); } - // TODO: implement plugins stack.setConfig(config); return stack; } diff --git a/src/test/java/com/contentstack/sdk/TestAsset.java b/src/test/java/com/contentstack/sdk/TestAsset.java index ebfe0371..8fe34fd4 100644 --- a/src/test/java/com/contentstack/sdk/TestAsset.java +++ b/src/test/java/com/contentstack/sdk/TestAsset.java @@ -53,7 +53,7 @@ public void onCompletion(ResponseType responseType, List assets, Error er @Test @Order(2) void testNewAssetZOnlyForOrderByUid() { - String[] tags = {"black", "white", "red"}; + String[] tags = { "black", "white", "red" }; Asset asset = stack.asset(assetUid); asset.includeFallback().addParam("fake@header", "fake@header").setTags(tags).fetch(new FetchResultCallback() { @Override @@ -107,7 +107,7 @@ void testSetAssetUid() { @Test void testSetAssetTagsLength() { - String[] tags = {"gif", "img", "landscape", "portrait"}; + String[] tags = { "gif", "img", "landscape", "portrait" }; Asset assetInstance = stack.asset(); assetInstance.setTags(tags); Assertions.assertEquals(tags.length, assetInstance.tagsArray.length); @@ -115,7 +115,7 @@ void testSetAssetTagsLength() { @Test void testGetAssetTags() { - String[] tags = {"gif", "img", "landscape", "portrait"}; + String[] tags = { "gif", "img", "landscape", "portrait" }; Asset assetInstance = stack.asset(); assetInstance.setTags(tags); Assertions.assertEquals(tags.length, assetInstance.getTags().length); diff --git a/src/test/java/com/contentstack/sdk/TestAzureRegion.java b/src/test/java/com/contentstack/sdk/TestAzureRegion.java index 45708192..d4bd2d72 100644 --- a/src/test/java/com/contentstack/sdk/TestAzureRegion.java +++ b/src/test/java/com/contentstack/sdk/TestAzureRegion.java @@ -1,15 +1,10 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import org.junit.jupiter.api.Assertions; -import org.junit.jupiter.api.BeforeAll; import org.junit.jupiter.api.Test; -import java.util.logging.Logger; - class TestAzureRegion { - @Test void testAzureRegionBehaviourUS() { Config config = new Config(); diff --git a/src/test/java/com/contentstack/sdk/TestEntry.java b/src/test/java/com/contentstack/sdk/TestEntry.java index abdfe244..edfbf6b4 100644 --- a/src/test/java/com/contentstack/sdk/TestEntry.java +++ b/src/test/java/com/contentstack/sdk/TestEntry.java @@ -4,10 +4,8 @@ import org.json.JSONObject; import org.junit.jupiter.api.*; -import java.text.ParseException; import java.util.ArrayList; import java.util.GregorianCalendar; -import java.util.TimeZone; import java.util.logging.Logger; import static org.junit.jupiter.api.Assertions.assertTrue; @@ -312,7 +310,6 @@ void entryGetShortZeroExpected() { logger.info("passed..."); } - @Test @Order(35) void entryGetCreateAt() { @@ -374,7 +371,7 @@ void entryGetAsset() { @Test @Order(42) void entryExcept() { - String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; + String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; Entry initEntry = stack.contentType("product").entry(entryUid).except(arrField); Assertions.assertEquals(3, initEntry.exceptFieldArray.length()); logger.info("passed..."); @@ -392,7 +389,7 @@ void entryIncludeReference() { @Test @Order(44) void entryIncludeReferenceList() { - String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; + String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; Entry initEntry = stack.contentType("product").entry(entryUid).includeReference(arrField); Assertions.assertEquals(3, initEntry.referenceArray.length()); Assertions.assertTrue(initEntry.params.has("include[]")); @@ -402,7 +399,7 @@ void entryIncludeReferenceList() { @Test @Order(45) void entryOnlyList() { - String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; + String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; Entry initEntry = stack.contentType("product").entry(entryUid); initEntry.only(arrField); Assertions.assertEquals(3, initEntry.objectUidForOnly.length()); @@ -416,7 +413,8 @@ void entryOnlyWithReferenceUid() { strList.add("fieldOne"); strList.add("fieldTwo"); strList.add("fieldThree"); - Entry initEntry = stack.contentType("product").entry(entryUid).onlyWithReferenceUid(strList, "reference@fakeit"); + Entry initEntry = stack.contentType("product").entry(entryUid).onlyWithReferenceUid(strList, + "reference@fakeit"); Assertions.assertTrue(initEntry.onlyJsonObject.has("reference@fakeit")); int size = initEntry.onlyJsonObject.optJSONArray("reference@fakeit").length(); Assertions.assertEquals(strList.size(), size); diff --git a/src/test/java/com/contentstack/sdk/TestQuery.java b/src/test/java/com/contentstack/sdk/TestQuery.java index f2c13818..459e7b32 100644 --- a/src/test/java/com/contentstack/sdk/TestQuery.java +++ b/src/test/java/com/contentstack/sdk/TestQuery.java @@ -131,7 +131,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(5) void testNotContainedInField() { - String[] containArray = new String[]{"Roti Maker", "kids dress"}; + String[] containArray = new String[] { "Roti Maker", "kids dress" }; query.notContainedIn("title", containArray).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -148,7 +148,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(6) void testContainedInField() { - String[] containArray = new String[]{"Roti Maker", "kids dress"}; + String[] containArray = new String[] { "Roti Maker", "kids dress" }; query.containedIn("title", containArray).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -253,7 +253,7 @@ void testEntriesWithOr() { query.lessThan("price", 90); Query subQuery = ct.query(); - subQuery.containedIn("discount", new Integer[]{20, 45}); + subQuery.containedIn("discount", new Integer[] { 20, 45 }); ArrayList array = new ArrayList<>(); array.add(query); @@ -285,7 +285,7 @@ void testEntriesWithAnd() { query.lessThan("price", 90); Query subQuery = ct.query(); - subQuery.containedIn("discount", new Integer[]{20, 45}); + subQuery.containedIn("discount", new Integer[] { 20, 45 }); ArrayList array = new ArrayList<>(); array.add(query); @@ -387,7 +387,7 @@ void testAscending() { public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - for (int i = 0; i < entries.size()-1; i++) { + for (int i = 0; i < entries.size() - 1; i++) { String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else @@ -413,7 +413,7 @@ void testDescending() { public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { List entries = queryresult.getResultObjects(); - for (int i = 0; i < entries.size()-1; i++) { + for (int i = 0; i < entries.size() - 1; i++) { String previous = entries.get(i).getTitle(); // get first string String next = entries.get(i + 1).getTitle(); // get second string if (previous.compareTo(next) < 0) { // compare both if less than Zero then Ascending else @@ -465,7 +465,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(22) void testOnly() { - query.only(new String[]{"price"}); + query.only(new String[] { "price" }); query.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -482,7 +482,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(23) void testExcept() { - query.except(new String[]{"price"}).find(new QueryResultsCallBack() { + query.except(new String[] { "price" }).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -564,7 +564,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(28) void testTags() { - query.tags(new String[]{"pink"}); + query.tags(new String[] { "pink" }); query.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -633,16 +633,16 @@ void testIncludeReferenceOnly() { query.onlyWithReferenceUid(strings, "package_info.info_category") .exceptWithReferenceUid(strings1, "product_ref") .find(new QueryResultsCallBack() { - @Override - public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { - if (error == null) { - List entries = queryresult.getResultObjects(); - Assertions.assertEquals(0, entries.size()); - } else { - Assertions.fail("Failing, Verify credentials"); - } - } - }); + @Override + public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { + if (error == null) { + List entries = queryresult.getResultObjects(); + Assertions.assertEquals(0, entries.size()); + } else { + Assertions.fail("Failing, Verify credentials"); + } + } + }); } diff --git a/src/test/java/com/contentstack/sdk/TestStack.java b/src/test/java/com/contentstack/sdk/TestStack.java index 810fe6ac..6a5dc390 100644 --- a/src/test/java/com/contentstack/sdk/TestStack.java +++ b/src/test/java/com/contentstack/sdk/TestStack.java @@ -115,7 +115,6 @@ void testGetDeliveryToken() { assertTrue(stack.getDeliveryToken().startsWith("blt")); } - @Test @Order(15) void testRemoveHeader() { From 3c1d45699bbd24bc9bbfb79163fe9682c42229a5 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 9 Feb 2023 13:11:31 +0530 Subject: [PATCH 047/104] :potted_plant: LICENSE file updated --- .../java/com/contentstack/sdk/TestAssetLibrary.java | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java index f775e703..a6bc78b9 100644 --- a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java +++ b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java @@ -69,8 +69,7 @@ void testAssetRemoveHeader() { @Test void testAssetSortAscending() { - AssetLibrary assetLibrary = stack.assetLibrary(); - assetLibrary.sort("ascending", AssetLibrary.ORDERBY.ASCENDING); + AssetLibrary assetLibrary = stack.assetLibrary().sort("ascending", AssetLibrary.ORDERBY.ASCENDING); Assertions.assertFalse(assetLibrary.headers.containsKey("asc")); logger.info("passed..."); } @@ -85,8 +84,7 @@ void testAssetSortDescending() { @Test void testAssetIncludeCount() { - AssetLibrary assetLibrary = stack.assetLibrary(); - assetLibrary.includeCount(); + AssetLibrary assetLibrary = stack.assetLibrary().includeCount(); Assertions.assertFalse(assetLibrary.headers.containsKey("include_count")); logger.info("passed..."); } @@ -101,16 +99,14 @@ void testAssetIncludeRelativeUrl() { @Test void testAssetGetCount() { - AssetLibrary assetLibrary = stack.assetLibrary(); - assetLibrary.includeRelativeUrl(); + AssetLibrary assetLibrary = stack.assetLibrary().includeRelativeUrl(); Assertions.assertEquals(0, assetLibrary.getCount()); logger.info("passed..."); } @Test void testIncludeFallback() { - AssetLibrary assetLibrary = stack.assetLibrary(); - assetLibrary.includeFallback(); + AssetLibrary assetLibrary = stack.assetLibrary().includeFallback(); Assertions.assertFalse(assetLibrary.headers.containsKey("include_fallback")); logger.info("passed..."); } From 7021f39c5361b8c004f78f3a8ceae5859fb4568e Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Mon, 10 Apr 2023 18:58:17 +0530 Subject: [PATCH 048/104] feat/CS-35325-include_ownership --- CHANGELOG.md | 8 - pom.xml | 17 +- src/main/java/com/contentstack/sdk/Asset.java | 224 +++++++++--------- .../com/contentstack/sdk/AssetLibrary.java | 52 ++-- .../java/com/contentstack/sdk/Config.java | 43 ++-- .../java/com/contentstack/sdk/Constants.java | 1 - src/main/java/com/contentstack/sdk/Entry.java | 95 +++++--- src/main/java/com/contentstack/sdk/Query.java | 19 ++ src/main/java/com/contentstack/sdk/Stack.java | 19 +- .../java/com/contentstack/sdk/TestAsset.java | 13 +- .../contentstack/sdk/TestAssetLibrary.java | 7 + .../com/contentstack/sdk/TestAzureRegion.java | 34 ++- .../java/com/contentstack/sdk/TestEntry.java | 10 + .../java/com/contentstack/sdk/TestQuery.java | 16 ++ .../com/contentstack/sdk/TestQueryCase.java | 13 + 15 files changed, 353 insertions(+), 218 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2c558715..5066736e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -9,14 +9,6 @@ - Breaking change: Enums PublishType changed from snake-case to ALL_CAPS - Basic Improvements -## v1.10.2 - -### Date: 22-Oct-2022 - -- LivePreview internal function implementation updated -- Jsoup dependency updated -- Json version updated - ## v1.10.1 ### Date: 18-June-2022 diff --git a/pom.xml b/pom.xml index 710393cb..435db439 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.11.0-SNAPSHOT + 1.12.0 jar contentstack-java Java SDK for Contentstack Content Delivery API @@ -20,23 +20,22 @@ 2.22.0 2.2.1 3.4.1 - 2.3.1 - 3.1.5 + 2.3.2 + 3.1.6 2.9.0 2.9.0 - 4.10.0 + 5.0.0-alpha.11 0.8.5 - 1.18.24 - 5.9.1 + 1.18.26 + 5.9.2 5.8.0-M1 - 5.9.1 2.8.8 1.1.1 3.3 1.5 3.8.1 1.6.13 - 20220924 + 20230227 0.8.7 2.5.3 1.2.0 @@ -160,7 +159,7 @@ org.junit.vintage junit-vintage-engine - ${junit-vintage-engine.version} + ${junit-jupiter.version} test diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index f4d507fe..c08c2336 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -14,14 +14,11 @@ import static com.contentstack.sdk.Constants.parseDate; /** - * Assets - * refer to all the media files (images, videos, PDFs, audio files, and so on) - * uploaded in your Contentstack repository - * for future use. These files can be attached and used in multiple entries. + * Assets refer to + * all the media files (images, videos, PDFs, audio files, and so on) uploaded in your Contentstack repository for + * future use. These files can be attached and used in multiple entries. *

- * You can now pass the branch header in the API request to fetch or manage - * modules located within specific branches of + * You can now pass the branch header in the API request to fetch or manage modules located within specific branches of * the stack. * * @author Shailesh Mishra @@ -61,7 +58,7 @@ protected void setStackInstance(@NotNull Stack stack) { * Configure asset. * * @param jsonObject - * the json object + * the json object * @return the asset */ public Asset configure(JSONObject jsonObject) { @@ -81,19 +78,19 @@ public Asset configure(JSONObject jsonObject) { * Sets header. * * @param headerKey - * the header key + * the header key * @param headerValue - * the header value + * the header value * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *

-     *                    Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                    Asset asset = stack.asset(asset_uid);
-     *                    asset.setHeader();
-     *                    
+ *
+     *                                                            Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
+     *                                                            Asset asset = stack.asset(asset_uid);
+     *                                                            asset.setHeader();
+     *                                                            
*/ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { headers.put(headerKey, headerValue); @@ -103,17 +100,17 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * Remove header. * * @param headerKey - * the header key + * the header key * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
-     *                  Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                  Asset asset = stack.asset(asset_uid);
-     *                  asset.removeHeader();
-     *                  
+ *
+     *                                                          Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
+     *                                                          Asset asset = stack.asset(asset_uid);
+     *                                                          asset.removeHeader();
+     *                                                          
*/ public void removeHeader(@NotNull String headerKey) { headers.remove(headerKey); @@ -130,11 +127,11 @@ protected void setUid(@NotNull String assetUid) { * * @return the asset uid * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -155,11 +152,11 @@ public String getAssetUid() {
      *
      * @return the file type
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -180,11 +177,11 @@ public String getFileType() {
      *
      * @return the file size
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -205,11 +202,11 @@ public String getFileSize() {
      *
      * @return the file name
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -230,11 +227,11 @@ public String getFileName() {
      *
      * @return the url
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -255,11 +252,11 @@ public String getUrl() {
      *
      * @return the json object
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -279,13 +276,10 @@ public JSONObject toJSON() {
      * Gets create at.
      *
      * @return the create at
+     * 
+ * Example :
* - * - *
- *
- * Example :
- * - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -306,12 +300,11 @@ public Calendar getCreateAt() {
      *
      * @return the created by
      *
+     * 
+ *
+ * Example :
* - *
- *
- * Example :
- * - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -332,12 +325,11 @@ public String getCreatedBy() {
      *
      * @return the update at
      *
+     * 
+ *
+ * Example :
* - *
- *
- * Example :
- * - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -357,13 +349,11 @@ public Calendar getUpdateAt() {
      * Gets updated by.
      *
      * @return the updated by
+     * 
+ *
+ * Example :
* - * - *
- *
- * Example :
- * - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -384,11 +374,11 @@ public String getUpdatedBy() {
      *
      * @return the delete at
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -409,11 +399,11 @@ public Calendar getDeleteAt() {
      *
      * @return the deleted by
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -432,13 +422,11 @@ public String getDeletedBy() {
      * Get tags string [ ].
      *
      * @return the string [ ]
+     * 
+ *
+ * Example :
* - * - *
- *
- * Example :
- * - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -464,11 +452,11 @@ protected Asset setTags(String[] tags) {
      *
      * @return the asset
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.includeDimension();
@@ -483,16 +471,16 @@ public Asset includeDimension() {
      * Add param asset.
      *
      * @param paramKey
-     *                   the param key
+     *         the param key
      * @param paramValue
-     *                   the param value
+     *         the param value
      * @return the asset
      *
-     *         
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.addParam();
@@ -507,13 +495,11 @@ public Asset addParam(@NotNull String paramKey, @NotNull String paramValue) {
      * Include fallback asset.
      *
      * @return the asset
+     * 
+ *
+ * Example :
* - * - *
- *
- * Example :
- * - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.includeFallback();
@@ -529,11 +515,11 @@ public Asset includeFallback() {
      *
      * @return {@link Asset} object, so you can chain this call. 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.includeBranch();
@@ -544,11 +530,31 @@ public Asset includeBranch() {
         return this;
     }
 
+    /**
+     * Includes Owner in the asset response
+     *
+     * @return {@link Asset} object, so you can chain this call. 
+ * + *
+ *
+ * Example :
+ * + *
+     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
+     *         Asset asset = stack.asset(asset_uid);
+     *         asset.includeOwner();
+     *         
+ */ + public Asset includeOwner() { + urlQueries.put("include_owner", true); + return this; + } + /** * Fetch. * * @param callback - * the callback + * the callback */ public void fetch(FetchResultCallback callback) { urlQueries.put(ENVIRONMENT, this.headers.get(ENVIRONMENT)); @@ -556,7 +562,7 @@ public void fetch(FetchResultCallback callback) { } private void fetchFromNetwork(String url, JSONObject urlQueries, LinkedHashMap headers, - FetchResultCallback callback) { + FetchResultCallback callback) { if (callback != null) { HashMap urlParams = getUrlParams(urlQueries); new CSBackgroundTask(this, stackInstance, Constants.FETCHASSETS, url, headers, urlParams, diff --git a/src/main/java/com/contentstack/sdk/AssetLibrary.java b/src/main/java/com/contentstack/sdk/AssetLibrary.java index 3849b15f..2f8f7802 100644 --- a/src/main/java/com/contentstack/sdk/AssetLibrary.java +++ b/src/main/java/com/contentstack/sdk/AssetLibrary.java @@ -2,7 +2,6 @@ import org.jetbrains.annotations.NotNull; import org.json.JSONObject; -import retrofit2.Retrofit; import java.util.*; import java.util.logging.Logger; @@ -10,11 +9,9 @@ import static com.contentstack.sdk.Constants.ENVIRONMENT; /** - * The Asset library is used to get list of assets available in the stack, We - * can apply filters on the assets also. - * The Get all assets request fetches the list of all the assets of a particular - * stack. It returns the content of each - * asset in JSON format. + * The Asset library is used to get list of assets available in the stack, We can apply filters on the assets also. The + * Get all assets request fetches the list of all the assets of a particular stack. It returns the content of each asset + * in JSON format. */ public class AssetLibrary implements INotifyClass { @@ -24,6 +21,7 @@ public class AssetLibrary implements INotifyClass { protected LinkedHashMap headers; protected FetchAssetsCallback callback; protected int count; + protected AssetLibrary() { this.urlQueries = new JSONObject(); } @@ -37,9 +35,9 @@ protected void setStackInstance(@NotNull Stack stack) { * Sets header. * * @param headerKey - * the header key + * the header key * @param headerValue - * the header value + * the header value */ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { this.headers.put(headerKey, headerValue); @@ -49,7 +47,7 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * Remove header. * * @param headerKey - * the header key + * the header key */ public void removeHeader(@NotNull String headerKey) { if (!headerKey.isEmpty()) { @@ -61,9 +59,9 @@ public void removeHeader(@NotNull String headerKey) { * Sort asset library. * * @param keyOrderBy - * the key order by + * the key order by * @param orderby - * the orderby + * the orderby * @return the asset library */ public AssetLibrary sort(String keyOrderBy, ORDERBY orderby) { @@ -96,14 +94,13 @@ public AssetLibrary includeRelativeUrl() { } /** - * Retrieve the published content of the fallback locale if an entry is not - * localized in specified locale + * Retrieve the published content of the fallback locale if an entry is not localized in specified locale * * @return {@link AssetLibrary} object, so you can chain this call.
- *
- * Example :
+ *
+ * Example :
* - *
+     * 
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         AssetLibrary assetLibObject = stack.assetLibrary();
      *         AssetLibrary.includeFallback();
@@ -114,6 +111,24 @@ public AssetLibrary includeFallback() {
         return this;
     }
 
+    /**
+     * Retrieve an owner in the response
+     *
+     * @return {@link AssetLibrary} object, so you can chain this call. 
+ *
+ * Example :
+ * + *
+     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
+     *         AssetLibrary assetLibObject = stack.includeOwner();
+     *         AssetLibrary.includeFallback();
+     *         
+ */ + public AssetLibrary includeOwner() { + urlQueries.put("include_owner", true); + return this; + } + /** * Gets count. * @@ -127,7 +142,7 @@ public int getCount() { * Fetch all. * * @param callback - * the callback + * the callback */ public void fetchAll(FetchAssetsCallback callback) { this.callback = callback; @@ -136,7 +151,7 @@ public void fetchAll(FetchAssetsCallback callback) { } private void fetchFromNetwork(String url, JSONObject urlQueries, LinkedHashMap headers, - FetchAssetsCallback callback) { + FetchAssetsCallback callback) { if (callback != null) { HashMap urlParams = getUrlParams(urlQueries); new CSBackgroundTask(this, stackInstance, Constants.FETCHALLASSETS, url, headers, urlParams, @@ -191,6 +206,7 @@ public void getResultObject(List objects, JSONObject jsonObject, boolean } } + /** * The enum Orderby. */ diff --git a/src/main/java/com/contentstack/sdk/Config.java b/src/main/java/com/contentstack/sdk/Config.java index bde5aef9..656057b7 100644 --- a/src/main/java/com/contentstack/sdk/Config.java +++ b/src/main/java/com/contentstack/sdk/Config.java @@ -9,8 +9,7 @@ import java.util.concurrent.TimeUnit; /** - * The Config enables optional parameters while passing from stack. You can set - * different configs params to the stack + * The Config enables optional parameters while passing from stack. You can set different configs params to the stack * like host, version, livePreview, endpoint, region, branch etc */ public class Config { @@ -45,13 +44,12 @@ public void setBranch(String branch) { * Proxy can be set like below. * * @param proxy - * Proxy setting, typically a type (http, socks) and a socket - * address. A Proxy is an immutable object - *
- *
- * Example:
- *
- * + * Proxy setting, typically a type (http, socks) and a socket address. A Proxy is an immutable object + *
+ *
+ * Example:
+ *
+ * * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("proxyHost", "proxyPort")); * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("sl.theproxyvpn.io", 80)); Config * config = new Config(); config.setProxy(proxy); @@ -71,18 +69,16 @@ public Proxy getProxy() { } /** - * Manages reuse of HTTP and HTTP/2 connections for reduced network latency. - * HTTP requests that * share the same - * {@link okhttp3.Address} may share a {@link okhttp3.Connection}. This class - * implements the policy * of which + * Manages reuse of HTTP and HTTP/2 connections for reduced network latency. HTTP requests that * share the same + * {@link okhttp3.Address} may share a {@link okhttp3.Connection}. This class implements the policy * of which * connections to keep open for future use. * * @param maxIdleConnections - * the maxIdleConnections default value is 5 + * the maxIdleConnections default value is 5 * @param keepAliveDuration - * the keepAliveDuration default value is 5 + * the keepAliveDuration default value is 5 * @param timeUnit - * the timeUnit default value is TimeUnit.MINUTES + * the timeUnit default value is TimeUnit.MINUTES * @return ConnectionPool */ public ConnectionPool connectionPool(int maxIdleConnections, long keepAliveDuration, TimeUnit timeUnit) { @@ -103,7 +99,7 @@ public ContentstackRegion getRegion() { * Sets region. * * @param region - * the region + * the region * @return the region */ public ContentstackRegion setRegion(ContentstackRegion region) { @@ -136,7 +132,7 @@ public String getHost() { * Sets host. * * @param hostName - * the host name + * the host name */ public void setHost(String hostName) { if (hostName != null && !hostName.isEmpty()) { @@ -157,7 +153,7 @@ public String getVersion() { * Enable live preview config. * * @param enableLivePreview - * to enable live preview + * to enable live preview * @return the config */ public Config enableLivePreview(boolean enableLivePreview) { @@ -169,7 +165,7 @@ public Config enableLivePreview(boolean enableLivePreview) { * Sets live preview host. * * @param livePreviewHost - * the live preview host + * the live preview host * @return the live preview host */ public Config setLivePreviewHost(@NotNull String livePreviewHost) { @@ -186,7 +182,7 @@ protected Config setLivePreviewEntry(@NotNull JSONObject livePreviewEntry) { * Sets management token. * * @param managementToken - * the management token + * the management token * @return the management token */ public Config setManagementToken(@NotNull String managementToken) { @@ -195,11 +191,10 @@ public Config setManagementToken(@NotNull String managementToken) { } /** - * The enum Contentstack region. for now contentstack supports [US, EU, - * AZURE_NA] + * The enum Contentstack region. for now contentstack supports [US, EU, AZURE_NA] */ public enum ContentstackRegion { - US, EU, AZURE_NA + US, EU, AZURE_NA, AZURE_EU } } diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index e500c97f..fb5dde3e 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -26,7 +26,6 @@ public class Constants { protected static final String CONTENT_TYPE_UID = "content_type_uid"; protected static final String ENTRY_UID = "entry_uid"; protected static final String LIVE_PREVIEW = "live_preview"; - protected static final String SYNCHRONISATION = "stacks/sync"; // Errors protected static final String ERROR_CODE = "error_code"; diff --git a/src/main/java/com/contentstack/sdk/Entry.java b/src/main/java/com/contentstack/sdk/Entry.java index bfb3eb1b..4cb2091a 100644 --- a/src/main/java/com/contentstack/sdk/Entry.java +++ b/src/main/java/com/contentstack/sdk/Entry.java @@ -80,7 +80,7 @@ public Entry configure(JSONObject jsonObject) { * Example :
* *
-     *                 
+ * */ public void setHeader(String key, String value) { @@ -98,10 +98,10 @@ public void setHeader(String key, String value) { * Example :
* *
-     *                                                                 Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                                 Entry entry = stack.contentType("form_name").entry("entry_uid");
-     *                                                                 entry.removeHeader("custom_header_key");
-     *                                                                 
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid"); + * entry.removeHeader("custom_header_key"); + * */ public void removeHeader(String key) { @@ -244,8 +244,8 @@ public JSONObject toJSON() { * Example :
* *
-     *                                                                                                                                                                                            Object obj = entry.get("key");
-     *                                                                                                                                                                                            
+ * Object obj = entry.get("key"); + * * @return Object @resultJson */ public Object get(@NotNull String key) { @@ -261,8 +261,8 @@ public Object get(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                            String value = entry.getString("key");
-     *                                                                                                                                                                                            
+ * String value = entry.getString("key"); + * * @return String @getString */ @@ -283,8 +283,8 @@ public String getString(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                            Boolean value = entry.getBoolean("key");
-     *                                                                                                                                                                                            
+ * Boolean value = entry.getBoolean("key"); + * * @return boolean @getBoolean */ @@ -305,8 +305,8 @@ public Boolean getBoolean(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                            JSONArray value = entry.getJSONArray("key");
-     *                                                                                                                                                                                            
+ * JSONArray value = entry.getJSONArray("key"); + * * @return JSONArray @getJSONArray */ @@ -327,8 +327,8 @@ public JSONArray getJSONArray(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                            JSONObject value = entry.getJSONObject("key");
-     *                                                                                                                                                                                            
+ * JSONObject value = entry.getJSONObject("key"); + * * @return JSONObject @getJSONObject */ public JSONObject getJSONObject(@NotNull String key) { @@ -348,8 +348,8 @@ public JSONObject getJSONObject(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                            JSONObject value = entry.getJSONObject("key");
-     *                                                                                                                                                                                            
+ * JSONObject value = entry.getJSONObject("key"); + * * @return Number @getNumber */ @@ -370,8 +370,8 @@ public Number getNumber(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                            int value = entry.getInt("key");
-     *                                                                                                                                                                                            
+ * int value = entry.getInt("key"); + * * @return int @getInt */ @@ -436,8 +436,8 @@ public double getDouble(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                            long value = entry.getLong("key");
-     *                                                                                                                                                                                            
+ * long value = entry.getLong("key"); + * * @return long @getLong */ @@ -460,8 +460,8 @@ public long getLong(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                            short value = entry.getShort("key");
-     *                                                                                                                                                                                            
+ * short value = entry.getShort("key"); + * * @return short @getShort */ public short getShort(@NotNull String key) { @@ -481,8 +481,8 @@ public short getShort(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                            Calendar value = entry.getDate("key");
-     *                                                                                                                                                                                            
+ * Calendar value = entry.getDate("key"); + * * @return Calendar @getDate */ @@ -664,9 +664,9 @@ public List getAssets(String key) { * Example :
* *
-     *                                                                                                                                                                                             Group innerGroup = entry.getGroup("key");
-     *                                                                                                                                                                                             return null
-     *                                                                                                                                                                                            
+ * Group innerGroup = entry.getGroup("key"); + * return null + * * @return {@link Group} */ public Group getGroup(String key) { @@ -892,16 +892,16 @@ public Entry exceptWithReferenceUid(@NotNull List fieldUid, @NotNull Str * Example :
* *
-     *                                                  {@code
-     *                                                  Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                  Entry entry = stack.contentType("form_name").entry("entry_uid");
- * entry.fetch(new EntryResultCallBack() {
- * @Override - * public void onCompletion(ResponseType responseType, Error error) { - * }
- * });
- * } - *
+ * {@code + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid");
+ * entry.fetch(new EntryResultCallBack() {
+ * @Override + * public void onCompletion(ResponseType responseType, Error error) { + * }
+ * });
+ * } + * */ public void fetch(EntryResultCallBack callback) { @@ -1083,4 +1083,23 @@ public Entry includeBranch() { return this; } + /** + * Includes an owner in the entry response + * + * @return {@link Entry} object, so you can chain this call. + * + *
+ *
+ * Example :
+ * + *
+     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
+     *         final Entry entry = stack.contentType("user").entry("entryUid");
+     *         entry.includeOwner();
+     *         
+ */ + public Entry includeOwner() { + params.put("include_owner", true); + return this; + } } diff --git a/src/main/java/com/contentstack/sdk/Query.java b/src/main/java/com/contentstack/sdk/Query.java index 0ad33ae0..de969bc2 100644 --- a/src/main/java/com/contentstack/sdk/Query.java +++ b/src/main/java/com/contentstack/sdk/Query.java @@ -1457,4 +1457,23 @@ public Query includeBranch() { return this; } + /** + * Includes Owner in the entry response + * + * @return {@link Query} object, so you can chain this call.
+ * + *
+ *
+ * Example :
+ * + *
+     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
+     *         Query query = stack.contentType("contentTypeUid").query();
+     *         entry.includeOwner();
+     *         
+ */ + public Query includeOwner() { + urlQueries.put("include_owner", true); + return this; + } } diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java index 51b986af..a6f8753f 100644 --- a/src/main/java/com/contentstack/sdk/Stack.java +++ b/src/main/java/com/contentstack/sdk/Stack.java @@ -58,6 +58,11 @@ protected void setConfig(Config config) { urlDomain = "cdn.contentstack.com"; } config.host = "azure-na" + "-" + urlDomain; + } else if (region.equalsIgnoreCase("azure_eu")) { + if (urlDomain.equalsIgnoreCase("cdn.contentstack.io")) { + urlDomain = "cdn.contentstack.com"; + } + config.host = "azure-eu" + "-" + urlDomain; } } @@ -365,10 +370,10 @@ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallB *
* Example :
*
-     *                                                                                                                                                                                     Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                                                                                                                     stack.syncToken("syncToken")
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             stack.syncToken(sync_token, new SyncResultCallBack()                                                                                                                                                                                                               ){ }
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncToken("syncToken") + * stack.syncToken(sync_token, new SyncResultCallBack() ){ } + * */ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { this.sync(null); @@ -468,9 +473,9 @@ public void syncLocale(String localeCode, SyncResultCallBack syncCallBack) { *
* Example :
*
-     *                                                                                 Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                 stack.syncPublishType(PublishType)
-     *                                                                                 
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncPublishType(PublishType) + * */ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCallBack) { this.sync(null); diff --git a/src/test/java/com/contentstack/sdk/TestAsset.java b/src/test/java/com/contentstack/sdk/TestAsset.java index 8fe34fd4..8980105e 100644 --- a/src/test/java/com/contentstack/sdk/TestAsset.java +++ b/src/test/java/com/contentstack/sdk/TestAsset.java @@ -53,7 +53,7 @@ public void onCompletion(ResponseType responseType, List assets, Error er @Test @Order(2) void testNewAssetZOnlyForOrderByUid() { - String[] tags = { "black", "white", "red" }; + String[] tags = {"black", "white", "red"}; Asset asset = stack.asset(assetUid); asset.includeFallback().addParam("fake@header", "fake@header").setTags(tags).fetch(new FetchResultCallback() { @Override @@ -107,7 +107,7 @@ void testSetAssetUid() { @Test void testSetAssetTagsLength() { - String[] tags = { "gif", "img", "landscape", "portrait" }; + String[] tags = {"gif", "img", "landscape", "portrait"}; Asset assetInstance = stack.asset(); assetInstance.setTags(tags); Assertions.assertEquals(tags.length, assetInstance.tagsArray.length); @@ -115,7 +115,7 @@ void testSetAssetTagsLength() { @Test void testGetAssetTags() { - String[] tags = { "gif", "img", "landscape", "portrait" }; + String[] tags = {"gif", "img", "landscape", "portrait"}; Asset assetInstance = stack.asset(); assetInstance.setTags(tags); Assertions.assertEquals(tags.length, assetInstance.getTags().length); @@ -183,4 +183,11 @@ void testAssetIncludeBranch() { Assertions.assertTrue(asset.urlQueries.has("include_branch")); } + @Test + void testAssetIncludeOwner() { + Asset asset = stack.asset("fake@uid"); + asset.includeOwner(); + Assertions.assertTrue(asset.urlQueries.has("include_owner")); + } + } diff --git a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java index a6bc78b9..830f59ce 100644 --- a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java +++ b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java @@ -110,4 +110,11 @@ void testIncludeFallback() { Assertions.assertFalse(assetLibrary.headers.containsKey("include_fallback")); logger.info("passed..."); } + + @Test + void testIncludeOwner() { + AssetLibrary assetLibrary = stack.assetLibrary().includeOwner(); + Assertions.assertFalse(assetLibrary.headers.containsKey("include_owner")); + logger.info("passed..."); + } } diff --git a/src/test/java/com/contentstack/sdk/TestAzureRegion.java b/src/test/java/com/contentstack/sdk/TestAzureRegion.java index d4bd2d72..57bec938 100644 --- a/src/test/java/com/contentstack/sdk/TestAzureRegion.java +++ b/src/test/java/com/contentstack/sdk/TestAzureRegion.java @@ -24,7 +24,7 @@ void testAzureRegionBehaviourEU() { } @Test - void testAzureRegionBehaviourAzure() { + void testAzureRegionBehaviourAzureNA() { Config config = new Config(); Config.ContentstackRegion region = Config.ContentstackRegion.AZURE_NA; config.setRegion(region); @@ -32,6 +32,15 @@ void testAzureRegionBehaviourAzure() { Assertions.assertEquals("AZURE_NA", config.region.name()); } + @Test + void testAzureRegionBehaviourAzureEU() { + Config config = new Config(); + Config.ContentstackRegion region = Config.ContentstackRegion.AZURE_EU; + config.setRegion(region); + Assertions.assertFalse(config.region.name().isEmpty()); + Assertions.assertEquals("AZURE_EU", config.region.name()); + } + @Test void testAzureRegionBehaviourAzureStack() throws IllegalAccessException { Config config = new Config(); @@ -42,6 +51,18 @@ void testAzureRegionBehaviourAzureStack() throws IllegalAccessException { Assertions.assertEquals("AZURE_NA", stack.config.region.name()); } + + @Test + void testAzureEURegionBehaviourAzureStack() throws IllegalAccessException { + Config config = new Config(); + Config.ContentstackRegion region = Config.ContentstackRegion.AZURE_EU; + config.setRegion(region); + Stack stack = Contentstack.stack("fakeApiKey", "fakeDeliveryToken", "fakeEnvironment", config); + Assertions.assertFalse(config.region.name().isEmpty()); + Assertions.assertEquals("AZURE_EU", stack.config.region.name()); + } + + @Test void testAzureRegionBehaviourAzureStackHost() throws IllegalAccessException { Config config = new Config(); @@ -52,6 +73,17 @@ void testAzureRegionBehaviourAzureStackHost() throws IllegalAccessException { Assertions.assertEquals("azure-na-cdn.contentstack.com", stack.config.host); } + + @Test + void testAzureEURegionBehaviourAzureStackHost() throws IllegalAccessException { + Config config = new Config(); + Config.ContentstackRegion region = Config.ContentstackRegion.AZURE_EU; + config.setRegion(region); + Stack stack = Contentstack.stack("fakeApiKey", "fakeDeliveryToken", "fakeEnvironment", config); + Assertions.assertFalse(config.region.name().isEmpty()); + Assertions.assertEquals("azure-eu-cdn.contentstack.com", stack.config.host); + } + @Test void testAzureRegionBehaviourAzureStackInit() throws IllegalAccessException { Config config = new Config(); diff --git a/src/test/java/com/contentstack/sdk/TestEntry.java b/src/test/java/com/contentstack/sdk/TestEntry.java index edfbf6b4..7caaa4d7 100644 --- a/src/test/java/com/contentstack/sdk/TestEntry.java +++ b/src/test/java/com/contentstack/sdk/TestEntry.java @@ -503,6 +503,16 @@ void testEntryIncludeBranch() { logger.info("passed..."); } + @Test + @Order(54) + void testEntryIncludeOwner() { + Entry initEntry = stack.contentType("product").entry(entryUid); + initEntry.includeOwner(); + Assertions.assertTrue(initEntry.params.has("include_owner")); + Assertions.assertEquals(true, initEntry.params.opt("include_owner")); + logger.info("passed..."); + } + @Test @Order(55) void testEntryPassConfigBranchIncludeBranch() throws IllegalAccessException { diff --git a/src/test/java/com/contentstack/sdk/TestQuery.java b/src/test/java/com/contentstack/sdk/TestQuery.java index 459e7b32..50a1adf3 100644 --- a/src/test/java/com/contentstack/sdk/TestQuery.java +++ b/src/test/java/com/contentstack/sdk/TestQuery.java @@ -613,6 +613,22 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err }); } + @Test + @Order(30) + void testIncludeOwner() { + query.includeOwner(); + query.find(new QueryResultsCallBack() { + @Override + public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { + if (error == null) { + Assertions.assertTrue(queryresult.receiveJson.has("include_owner")); + } else { + Assertions.fail("Failing, Verify credentials"); + } + } + }); + } + @Test @Order(31) void testIncludeReferenceOnly() { diff --git a/src/test/java/com/contentstack/sdk/TestQueryCase.java b/src/test/java/com/contentstack/sdk/TestQueryCase.java index 5500043f..4d6d5949 100644 --- a/src/test/java/com/contentstack/sdk/TestQueryCase.java +++ b/src/test/java/com/contentstack/sdk/TestQueryCase.java @@ -1010,4 +1010,17 @@ void testUnitQueryWhereNotIn() { Assertions.assertTrue(query.queryValueJSON.has("fakeIt")); } + + @Test + void testIncludeOwner() { + query.includeOwner(); + Assertions.assertTrue(query.urlQueries.has("include_owner")); + } + + @Test + void testIncludeOwnerValue() { + query.includeOwner(); + Assertions.assertTrue(query.urlQueries.getBoolean("include_owner")); + } + } \ No newline at end of file From 85014f7853fb107de931dfec3df5f64e316dcf91 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Mon, 10 Apr 2023 19:49:44 +0530 Subject: [PATCH 049/104] feat/CS-37219-azure-eu-and-include-metadata feat/CS-37219-azure-eu-and-include-metadata --- CHANGELOG.md | 7 + src/main/java/com/contentstack/sdk/Asset.java | 8 +- .../com/contentstack/sdk/AssetLibrary.java | 8 +- src/main/java/com/contentstack/sdk/Entry.java | 84 +++--- src/main/java/com/contentstack/sdk/Query.java | 8 +- src/main/java/com/contentstack/sdk/Stack.java | 35 ++- .../java/com/contentstack/sdk/TestAsset.java | 4 +- .../contentstack/sdk/TestAssetLibrary.java | 2 +- .../java/com/contentstack/sdk/TestEntry.java | 261 +----------------- .../java/com/contentstack/sdk/TestQuery.java | 2 +- .../com/contentstack/sdk/TestQueryCase.java | 8 +- 11 files changed, 95 insertions(+), 332 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 5066736e..395dcbab 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,12 @@ # CHANGELOG +## v1.12.0 + +### Date: 25-APR-2023 + +- Include metadata support for Asset, Entry and Query, +- Region support for Azure-EU added + ## v1.11.0 ### Date: 09-FEB-2023 diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index c08c2336..c50b541c 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -531,7 +531,7 @@ public Asset includeBranch() { } /** - * Includes Owner in the asset response + * Includes Metadata in the asset response * * @return {@link Asset} object, so you can chain this call.
* @@ -542,11 +542,11 @@ public Asset includeBranch() { *
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
-     *         asset.includeOwner();
+     *         asset.includeMetadata();
      *         
*/ - public Asset includeOwner() { - urlQueries.put("include_owner", true); + public Asset includeMetadata() { + urlQueries.put("include_metadata", true); return this; } diff --git a/src/main/java/com/contentstack/sdk/AssetLibrary.java b/src/main/java/com/contentstack/sdk/AssetLibrary.java index 2f8f7802..8401a568 100644 --- a/src/main/java/com/contentstack/sdk/AssetLibrary.java +++ b/src/main/java/com/contentstack/sdk/AssetLibrary.java @@ -112,7 +112,7 @@ public AssetLibrary includeFallback() { } /** - * Retrieve an owner in the response + * Retrieve Metadata in the response * * @return {@link AssetLibrary} object, so you can chain this call.
*
@@ -121,11 +121,11 @@ public AssetLibrary includeFallback() { *
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         AssetLibrary assetLibObject = stack.includeOwner();
-     *         AssetLibrary.includeFallback();
+     *         AssetLibrary.includeMetadata();
      *         
*/ - public AssetLibrary includeOwner() { - urlQueries.put("include_owner", true); + public AssetLibrary includeMetadata() { + urlQueries.put("include_metadata", true); return this; } diff --git a/src/main/java/com/contentstack/sdk/Entry.java b/src/main/java/com/contentstack/sdk/Entry.java index 4cb2091a..4dc93206 100644 --- a/src/main/java/com/contentstack/sdk/Entry.java +++ b/src/main/java/com/contentstack/sdk/Entry.java @@ -80,7 +80,7 @@ public Entry configure(JSONObject jsonObject) { * Example :
* *
-     *                                                 
+ * */ public void setHeader(String key, String value) { @@ -98,10 +98,10 @@ public void setHeader(String key, String value) { * Example :
* *
-     *                                 Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                 Entry entry = stack.contentType("form_name").entry("entry_uid");
-     *                                 entry.removeHeader("custom_header_key");
-     *                                 
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid"); + * entry.removeHeader("custom_header_key"); + * */ public void removeHeader(String key) { @@ -244,8 +244,8 @@ public JSONObject toJSON() { * Example :
* *
-     *                                                                                                                                                                                                                            Object obj = entry.get("key");
-     *                                                                                                                                                                                                                            
+ * Object obj = entry.get("key"); + * * @return Object @resultJson */ public Object get(@NotNull String key) { @@ -261,8 +261,8 @@ public Object get(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                            String value = entry.getString("key");
-     *                                                                                                                                                                                                                            
+ * String value = entry.getString("key"); + * * @return String @getString */ @@ -283,8 +283,8 @@ public String getString(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                            Boolean value = entry.getBoolean("key");
-     *                                                                                                                                                                                                                            
+ * Boolean value = entry.getBoolean("key"); + * * @return boolean @getBoolean */ @@ -305,8 +305,8 @@ public Boolean getBoolean(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                            JSONArray value = entry.getJSONArray("key");
-     *                                                                                                                                                                                                                            
+ * JSONArray value = entry.getJSONArray("key"); + * * @return JSONArray @getJSONArray */ @@ -327,8 +327,8 @@ public JSONArray getJSONArray(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                            JSONObject value = entry.getJSONObject("key");
-     *                                                                                                                                                                                                                            
+ * JSONObject value = entry.getJSONObject("key"); + * * @return JSONObject @getJSONObject */ public JSONObject getJSONObject(@NotNull String key) { @@ -348,8 +348,8 @@ public JSONObject getJSONObject(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                            JSONObject value = entry.getJSONObject("key");
-     *                                                                                                                                                                                                                            
+ * JSONObject value = entry.getJSONObject("key"); + * * @return Number @getNumber */ @@ -370,8 +370,8 @@ public Number getNumber(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                            int value = entry.getInt("key");
-     *                                                                                                                                                                                                                            
+ * int value = entry.getInt("key"); + * * @return int @getInt */ @@ -436,8 +436,8 @@ public double getDouble(@NotNull String key) { * Example :
* *
-     *                                         long value = entry.getLong("key");
-     *                                         
+ * long value = entry.getLong("key"); + * * @return long @getLong */ @@ -460,8 +460,8 @@ public long getLong(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                            short value = entry.getShort("key");
-     *                                                                                                                                                                                                                            
+ * short value = entry.getShort("key"); + * * @return short @getShort */ public short getShort(@NotNull String key) { @@ -481,8 +481,8 @@ public short getShort(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                            Calendar value = entry.getDate("key");
-     *                                                                                                                                                                                                                            
+ * Calendar value = entry.getDate("key"); + * * @return Calendar @getDate */ @@ -664,9 +664,9 @@ public List getAssets(String key) { * Example :
* *
-     *                                                                                                                                                                                                                             Group innerGroup = entry.getGroup("key");
-     *                                                                                                                                                                                                                             return null
-     *                                                                                                                                                                                                                            
+ * Group innerGroup = entry.getGroup("key"); + * return null + * * @return {@link Group} */ public Group getGroup(String key) { @@ -892,16 +892,16 @@ public Entry exceptWithReferenceUid(@NotNull List fieldUid, @NotNull Str * Example :
* *
-     *                                                                                  {@code
-     *                                                                                  Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                                                  Entry entry = stack.contentType("form_name").entry("entry_uid");
- * entry.fetch(new EntryResultCallBack() {
- * @Override - * public void onCompletion(ResponseType responseType, Error error) { - * }
- * });
- * } - *
+ * {@code + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid");
+ * entry.fetch(new EntryResultCallBack() {
+ * @Override + * public void onCompletion(ResponseType responseType, Error error) { + * }
+ * });
+ * } + * */ public void fetch(EntryResultCallBack callback) { @@ -1084,7 +1084,7 @@ public Entry includeBranch() { } /** - * Includes an owner in the entry response + * Includes Metadata the entry response * * @return {@link Entry} object, so you can chain this call. * @@ -1095,11 +1095,11 @@ public Entry includeBranch() { *
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         final Entry entry = stack.contentType("user").entry("entryUid");
-     *         entry.includeOwner();
+     *         entry.includeMetadata();
      *         
*/ - public Entry includeOwner() { - params.put("include_owner", true); + public Entry includeMetadata() { + params.put("include_metadata", true); return this; } } diff --git a/src/main/java/com/contentstack/sdk/Query.java b/src/main/java/com/contentstack/sdk/Query.java index de969bc2..ce2c63ea 100644 --- a/src/main/java/com/contentstack/sdk/Query.java +++ b/src/main/java/com/contentstack/sdk/Query.java @@ -1458,7 +1458,7 @@ public Query includeBranch() { } /** - * Includes Owner in the entry response + * Includes Metadata in the entry response * * @return {@link Query} object, so you can chain this call.
* @@ -1469,11 +1469,11 @@ public Query includeBranch() { *
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Query query = stack.contentType("contentTypeUid").query();
-     *         entry.includeOwner();
+     *         entry.includeMetadata();
      *         
*/ - public Query includeOwner() { - urlQueries.put("include_owner", true); + public Query includeMetadata() { + urlQueries.put("include_metadata", true); return this; } } diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java index a6f8753f..4370ed6e 100644 --- a/src/main/java/com/contentstack/sdk/Stack.java +++ b/src/main/java/com/contentstack/sdk/Stack.java @@ -351,7 +351,7 @@ public void sync(SyncResultCallBack syncCallBack) { * stack.syncPaginationToken("paginationToken) */ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallBack syncCallBack) { - this.sync(null); + syncParams = new JSONObject(); syncParams.put("pagination_token", paginationToken); this.requestSync(syncCallBack); } @@ -370,13 +370,13 @@ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallB *
* Example :
*
-     *                                                                                                                                                                                                             Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                                                                                                                                             stack.syncToken("syncToken")
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     stack.syncToken(sync_token, new SyncResultCallBack()                                                                                                                                                                                                               ){ }
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncToken("syncToken") + * stack.syncToken(sync_token, new SyncResultCallBack() ){ } + * */ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { - this.sync(null); + syncParams = new JSONObject(); syncParams.put("sync_token", syncToken); this.requestSync(syncCallBack); } @@ -398,7 +398,8 @@ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { */ public void syncFromDate(@NotNull Date fromDate, SyncResultCallBack syncCallBack) { String newFromDate = convertUTCToISO(fromDate); - this.sync(null); + syncParams = new JSONObject(); + syncParams.put("init", true); syncParams.put("start_from", newFromDate); this.requestSync(syncCallBack); } @@ -427,7 +428,8 @@ protected String convertUTCToISO(Date date) { * stack.syncContentType(String content_type, new SyncResultCallBack()){ } */ public void syncContentType(@NotNull String contentType, SyncResultCallBack syncCallBack) { - this.sync(null); + syncParams = new JSONObject(); + syncParams.put("init", true); syncParams.put(CONTENT_TYPE_UID, contentType); this.requestSync(syncCallBack); } @@ -449,7 +451,8 @@ public void syncContentType(@NotNull String contentType, SyncResultCallBack sync * content_type, new SyncResultCallBack()){ } */ public void syncLocale(String localeCode, SyncResultCallBack syncCallBack) { - this.sync(null); + syncParams = new JSONObject(); + syncParams.put("init", true); syncParams.put("locale", localeCode); this.requestSync(syncCallBack); } @@ -472,13 +475,14 @@ public void syncLocale(String localeCode, SyncResultCallBack syncCallBack) { *
*
* Example :
- *
-     *                                                                                                         Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                                         stack.syncPublishType(PublishType)
-     *                                                                                                         
+ * + * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); * + * stack.syncPublishType(PublishType) + * */ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCallBack) { - this.sync(null); + syncParams = new JSONObject(); + syncParams.put("init", true); syncParams.put("type", publishType.name().toLowerCase()); this.requestSync(syncCallBack); } @@ -506,7 +510,8 @@ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCall public void sync(String contentType, Date fromDate, String localeCode, PublishType publishType, SyncResultCallBack syncCallBack) { String newDate = convertUTCToISO(fromDate); - this.sync(null); + syncParams = new JSONObject(); + syncParams.put("init", true); syncParams.put("start_from", newDate); syncParams.put("content_type_uid", contentType); syncParams.put("type", publishType.name()); diff --git a/src/test/java/com/contentstack/sdk/TestAsset.java b/src/test/java/com/contentstack/sdk/TestAsset.java index 8980105e..2bfd69ae 100644 --- a/src/test/java/com/contentstack/sdk/TestAsset.java +++ b/src/test/java/com/contentstack/sdk/TestAsset.java @@ -186,8 +186,8 @@ void testAssetIncludeBranch() { @Test void testAssetIncludeOwner() { Asset asset = stack.asset("fake@uid"); - asset.includeOwner(); - Assertions.assertTrue(asset.urlQueries.has("include_owner")); + asset.includeMetadata(); + Assertions.assertTrue(asset.urlQueries.has("include_metadata")); } } diff --git a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java index 830f59ce..8a3d8617 100644 --- a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java +++ b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java @@ -113,7 +113,7 @@ void testIncludeFallback() { @Test void testIncludeOwner() { - AssetLibrary assetLibrary = stack.assetLibrary().includeOwner(); + AssetLibrary assetLibrary = stack.assetLibrary().includeMetadata(); Assertions.assertFalse(assetLibrary.headers.containsKey("include_owner")); logger.info("passed..."); } diff --git a/src/test/java/com/contentstack/sdk/TestEntry.java b/src/test/java/com/contentstack/sdk/TestEntry.java index 7caaa4d7..590eb279 100644 --- a/src/test/java/com/contentstack/sdk/TestEntry.java +++ b/src/test/java/com/contentstack/sdk/TestEntry.java @@ -371,7 +371,7 @@ void entryGetAsset() { @Test @Order(42) void entryExcept() { - String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; + String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; Entry initEntry = stack.contentType("product").entry(entryUid).except(arrField); Assertions.assertEquals(3, initEntry.exceptFieldArray.length()); logger.info("passed..."); @@ -389,7 +389,7 @@ void entryIncludeReference() { @Test @Order(44) void entryIncludeReferenceList() { - String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; + String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; Entry initEntry = stack.contentType("product").entry(entryUid).includeReference(arrField); Assertions.assertEquals(3, initEntry.referenceArray.length()); Assertions.assertTrue(initEntry.params.has("include[]")); @@ -399,7 +399,7 @@ void entryIncludeReferenceList() { @Test @Order(45) void entryOnlyList() { - String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; + String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; Entry initEntry = stack.contentType("product").entry(entryUid); initEntry.only(arrField); Assertions.assertEquals(3, initEntry.objectUidForOnly.length()); @@ -507,9 +507,9 @@ void testEntryIncludeBranch() { @Order(54) void testEntryIncludeOwner() { Entry initEntry = stack.contentType("product").entry(entryUid); - initEntry.includeOwner(); - Assertions.assertTrue(initEntry.params.has("include_owner")); - Assertions.assertEquals(true, initEntry.params.opt("include_owner")); + initEntry.includeMetadata(); + Assertions.assertTrue(initEntry.params.has("include_metadata")); + Assertions.assertEquals(true, initEntry.params.opt("include_metadata")); logger.info("passed..."); } @@ -532,253 +532,4 @@ public void onCompletion(ResponseType responseType, Error error) { logger.info("passed..."); } - @Test - void setContentType() { - Assertions.assertTrue(true); - } - - @Test - void configure() { - Assertions.assertTrue(true); - } - - @Test - void setHeader() { - Assertions.assertTrue(true); - } - - @Test - void removeHeader() { - Assertions.assertTrue(true); - } - - @Test - void getTitle() { - Assertions.assertTrue(true); - } - - @Test - void getURL() { - Assertions.assertTrue(true); - } - - @Test - void getTags() { - Assertions.assertTrue(true); - } - - @Test - void setTags() { - Assertions.assertTrue(true); - } - - @Test - void getContentType() { - Assertions.assertTrue(true); - } - - @Test - void getUid() { - Assertions.assertTrue(true); - } - - @Test - void setUid() { - Assertions.assertTrue(true); - } - - @Test - void getLocale() { - Assertions.assertTrue(true); - } - - @Test - void setLocale() { - Assertions.assertTrue(true); - } - - @Test - void toJSON() { - Assertions.assertTrue(true); - } - - @Test - void get() { - Assertions.assertTrue(true); - } - - @Test - void getString() { - Assertions.assertTrue(true); - } - - @Test - void getBoolean() { - Assertions.assertTrue(true); - } - - @Test - void getJSONArray() { - Assertions.assertTrue(true); - } - - @Test - void getJSONObject() { - Assertions.assertTrue(true); - } - - @Test - void getNumber() { - Assertions.assertTrue(true); - } - - @Test - void getInt() { - Assertions.assertTrue(true); - } - - @Test - void getFloat() { - Assertions.assertTrue(true); - } - - @Test - void getDouble() { - Assertions.assertTrue(true); - } - - @Test - void getLong() { - Assertions.assertTrue(true); - } - - @Test - void getShort() { - Assertions.assertTrue(true); - } - - @Test - void getDate() { - Assertions.assertTrue(true); - } - - @Test - void getCreateAt() { - Assertions.assertTrue(true); - } - - @Test - void getCreatedBy() { - Assertions.assertTrue(true); - } - - @Test - void getUpdateAt() { - Assertions.assertTrue(true); - } - - @Test - void getUpdatedBy() { - Assertions.assertTrue(true); - } - - @Test - void getDeleteAt() { - Assertions.assertTrue(true); - } - - @Test - void getDeletedBy() { - Assertions.assertTrue(true); - } - - @Test - void getAsset() { - Assertions.assertTrue(true); - } - - @Test - void getAssets() { - Assertions.assertTrue(true); - } - - @Test - void getGroup() { - Assertions.assertTrue(true); - } - - @Test - void getGroups() { - Assertions.assertTrue(true); - } - - @Test - void getAllEntries() { - Assertions.assertTrue(true); - } - - @Test - void except() { - Assertions.assertTrue(true); - } - - @Test - void includeReference() { - Assertions.assertTrue(true); - } - - @Test - void testIncludeReference() { - Assertions.assertTrue(true); - } - - @Test - void only() { - Assertions.assertTrue(true); - } - - @Test - void onlyWithReferenceUid() { - Assertions.assertTrue(true); - } - - @Test - void exceptWithReferenceUid() { - Assertions.assertTrue(true); - } - - @Test - void fetch() { - Assertions.assertTrue(true); - } - - @Test - void addParam() { - Assertions.assertTrue(true); - } - - @Test - void includeReferenceContentTypeUID() { - Assertions.assertTrue(true); - } - - @Test - void includeContentType() { - Assertions.assertTrue(true); - } - - @Test - void includeFallback() { - Assertions.assertTrue(true); - } - - @Test - void includeEmbeddedItems() { - Assertions.assertTrue(true); - } - - @Test - void includeBranch() { - Assertions.assertTrue(true); - } } diff --git a/src/test/java/com/contentstack/sdk/TestQuery.java b/src/test/java/com/contentstack/sdk/TestQuery.java index 50a1adf3..8aa3d2fa 100644 --- a/src/test/java/com/contentstack/sdk/TestQuery.java +++ b/src/test/java/com/contentstack/sdk/TestQuery.java @@ -616,7 +616,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(30) void testIncludeOwner() { - query.includeOwner(); + query.includeMetadata(); query.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { diff --git a/src/test/java/com/contentstack/sdk/TestQueryCase.java b/src/test/java/com/contentstack/sdk/TestQueryCase.java index 4d6d5949..0010d60e 100644 --- a/src/test/java/com/contentstack/sdk/TestQueryCase.java +++ b/src/test/java/com/contentstack/sdk/TestQueryCase.java @@ -1013,14 +1013,14 @@ void testUnitQueryWhereNotIn() { @Test void testIncludeOwner() { - query.includeOwner(); - Assertions.assertTrue(query.urlQueries.has("include_owner")); + query.includeMetadata(); + Assertions.assertTrue(query.urlQueries.has("include_metadata")); } @Test void testIncludeOwnerValue() { - query.includeOwner(); - Assertions.assertTrue(query.urlQueries.getBoolean("include_owner")); + query.includeMetadata(); + Assertions.assertTrue(query.urlQueries.getBoolean("include_metadata")); } } \ No newline at end of file From 6e8c0411a6ebc6acaca235b2ee8bc83a36c6cc0b Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Tue, 11 Apr 2023 17:45:07 +0530 Subject: [PATCH 050/104] feat/CS-37219-azure-eu-and-include-metadata --- .github/workflows/maven-publish.yml | 9 ++- pom.xml | 16 +---- src/main/java/com/contentstack/sdk/Asset.java | 71 ++++++++----------- src/main/java/com/contentstack/sdk/Stack.java | 27 ++++--- 4 files changed, 48 insertions(+), 75 deletions(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 414709ba..d4bd6549 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -5,6 +5,9 @@ on: jobs: publish-maven: runs-on: ubuntu-latest + permissions: + contents: read + packages: write steps: - uses: actions/checkout@v3 - name: Set up Maven Central Repository @@ -13,9 +16,9 @@ jobs: java-version: '8' distribution: 'adopt' server-id: shaileshmishra - server-username: MAVEN_USERNAME - server-password: MAVEN_PASSWORD - gpg-passphrase: GPG_PASSPHRASE + server-username: ${{ secrets.MAVEN_USERNAME }} + server-password: ${{ secrets.MAVEN_PASSWORD }} + gpg-passphrase: ${{ secrets.GPG_PASSPHRASE }} - name: Publish package run: mvn --batch-mode deploy env: diff --git a/pom.xml b/pom.xml index 435db439..2a78d44d 100644 --- a/pom.xml +++ b/pom.xml @@ -13,7 +13,6 @@ - 1.11.0-SNAPSHOT 1.8 1.8 UTF-8 @@ -197,7 +196,7 @@ - + org.apache.maven.plugins maven-javadoc-plugin @@ -224,23 +223,16 @@ - org.apache.maven.plugins maven-site-plugin 3.3 - org.apache.maven.plugins maven-enforcer-plugin 3.0.0-M2 - org.apache.maven.plugins maven-gpg-plugin @@ -255,12 +247,6 @@ - org.apache.maven.plugins maven-compiler-plugin diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index c50b541c..e5991d54 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -85,12 +85,11 @@ public Asset configure(JSONObject jsonObject) { *
*
* Example :
- * - *
-     *                                                            Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                            Asset asset = stack.asset(asset_uid);
-     *                                                            asset.setHeader();
-     *                                                            
+ *

+ * + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = + * stack.asset(asset_uid); asset.setHeader(); + * */ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { headers.put(headerKey, headerValue); @@ -104,13 +103,12 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * *
*
- * Example :
- * - *

-     *                                                          Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                          Asset asset = stack.asset(asset_uid);
-     *                                                          asset.removeHeader();
-     *                                                          
+ * Example : + *

+ * + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = + * stack.asset(asset_uid); asset.removeHeader(); + * */ public void removeHeader(@NotNull String headerKey) { headers.remove(headerKey); @@ -131,17 +129,12 @@ protected void setUid(@NotNull String assetUid) { *
* Example :
* - *

-     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *         Asset asset = stack.asset(asset_uid);
-     *         asset.fetch(new FetchResultCallback() {
-     *             @Override
-     *             public void onCompletion(ResponseType responseType, Error error) {
-     *                 asset.getAssetUid();
-     *             }
-     *         });
+     * 
+     * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = stack.asset(asset_uid);
+     * asset.fetch(new FetchResultCallback() { @Override public void onCompletion(ResponseType responseType, Error
+     * error) { asset.getAssetUid(); } });
      *
-     *         
+ * */ public String getAssetUid() { return assetUid; @@ -157,16 +150,10 @@ public String getAssetUid() { * Example :
* *
-     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *         Asset asset = stack.asset(asset_uid);
-     *         asset.fetch(new FetchResultCallback() {
-     *             @Override
-     *             public void onCompletion(ResponseType responseType, Error error) {
-     *                 asset.getFileType();
-     *             }
-     *         });
-     *
-     *         
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = stack.asset(asset_uid); + * asset.fetch(new FetchResultCallback() { @Override public void onCompletion(ResponseType responseType, Error + * error) { asset.getFileType(); } }); + * */ public String getFileType() { return contentType; @@ -519,11 +506,10 @@ public Asset includeFallback() { *
* Example :
* - *
-     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *         Asset asset = stack.asset(asset_uid);
-     *         asset.includeBranch();
-     *         
+ * + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = stack.asset(asset_uid); + * asset.includeBranch(); + * */ public Asset includeBranch() { urlQueries.put("include_branch", true); @@ -539,11 +525,10 @@ public Asset includeBranch() { *
* Example :
* - *
-     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *         Asset asset = stack.asset(asset_uid);
-     *         asset.includeMetadata();
-     *         
+ * + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = stack.asset(asset_uid); + * asset.includeMetadata(); + * */ public Asset includeMetadata() { urlQueries.put("include_metadata", true); diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java index 4370ed6e..4902a541 100644 --- a/src/main/java/com/contentstack/sdk/Stack.java +++ b/src/main/java/com/contentstack/sdk/Stack.java @@ -160,11 +160,10 @@ public Stack livePreviewQuery(Map query) throws IOException { * @return the {@link ContentType} *

* Example - * - *

-     *  Stack stack = contentstack.Stack("apiKey",
-     * "deliveryToken", "environment"); ContentType contentType = stack.contentType("contentTypeUid")
-     *         
+ * + * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); ContentType contentType = + * stack.contentType("contentTypeUid") + * */ public ContentType contentType(String contentTypeUid) { this.contentType = contentTypeUid; @@ -208,11 +207,11 @@ protected Asset asset() { * @return {@link AssetLibrary} asset library *

* Example - * - *

-     *         Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *         AssetLibrary assets = stack.assetLibrary();
-     *         
+ *

+ * + * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); AssetLibrary assets = + * stack.assetLibrary(); + * */ public AssetLibrary assetLibrary() { AssetLibrary library = new AssetLibrary(); @@ -370,10 +369,10 @@ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallB *
* Example :
*

-     *                                                                                                                                                                                                                             Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                                                                                                                                                             stack.syncToken("syncToken")
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     stack.syncToken(sync_token, new SyncResultCallBack()                                                                                                                                                                                                               ){ }
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncToken("syncToken") + * stack.syncToken(sync_token, new SyncResultCallBack() ){ } + * */ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { syncParams = new JSONObject(); From 1782cddf522b087383b8215d69970a8bf239b64d Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Tue, 11 Apr 2023 22:39:25 +0530 Subject: [PATCH 051/104] feat/CS-37219-azure-eu-and-include-metadata pom.xml updated to implement pipeline --- .github/workflows/maven-publish.yml | 10 +++------- pom.xml | 2 +- 2 files changed, 4 insertions(+), 8 deletions(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index d4bd6549..e10b45d5 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -15,16 +15,12 @@ jobs: with: java-version: '8' distribution: 'adopt' - server-id: shaileshmishra - server-username: ${{ secrets.MAVEN_USERNAME }} - server-password: ${{ secrets.MAVEN_PASSWORD }} + server-id: ossrh + server-username: ${{ secrets.OSSRH_USERNAME }} + server-password: ${{ secrets.OSSRH_TOKEN }} gpg-passphrase: ${{ secrets.GPG_PASSPHRASE }} - name: Publish package run: mvn --batch-mode deploy - env: - MAVEN_USERNAME: ${{ secrets.OSSRH_USERNAME }} - MAVEN_PASSWORD: ${{ secrets.OSSRH_TOKEN }} - GPG_PASSPHRASE: ${{ secrets.GPG_PASSPHRASE }} publish-github: runs-on: ubuntu-latest steps: diff --git a/pom.xml b/pom.xml index 2a78d44d..1becd70e 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.12.0 + 1.11.1.1 jar contentstack-java Java SDK for Contentstack Content Delivery API From 1d785c75b50c807432c0a8e359779f28cd656929 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Tue, 18 Apr 2023 16:13:38 +0530 Subject: [PATCH 052/104] feat/cs-37219 azure-eu and include_metadata --- .github/workflows/sca-scan.yml | 2 +- .github/workflows/secrets-scan.yml | 2 +- pom.xml | 4 ++-- .../java/com/contentstack/sdk/TestQuery.java | 16 ++++++++-------- .../java/com/contentstack/sdk/TestStack.java | 11 ++--------- 5 files changed, 14 insertions(+), 21 deletions(-) diff --git a/.github/workflows/sca-scan.yml b/.github/workflows/sca-scan.yml index 2de23956..a45fd65f 100644 --- a/.github/workflows/sca-scan.yml +++ b/.github/workflows/sca-scan.yml @@ -1,7 +1,7 @@ name: Source Composition Analysis Scan on: pull_request: - types: [opened, synchronize, reopened] + types: [ opened, synchronize, reopened ] jobs: security: runs-on: ubuntu-latest diff --git a/.github/workflows/secrets-scan.yml b/.github/workflows/secrets-scan.yml index 1e8f1761..f62d12dc 100644 --- a/.github/workflows/secrets-scan.yml +++ b/.github/workflows/secrets-scan.yml @@ -1,7 +1,7 @@ name: Secrets Scan on: pull_request: - types: [opened, synchronize, reopened] + types: [ opened, synchronize, reopened ] jobs: security: runs-on: ubuntu-latest diff --git a/pom.xml b/pom.xml index 1becd70e..95eb28ea 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.11.1.1 + 1.12.0-SNAPSHOT jar contentstack-java Java SDK for Contentstack Content Delivery API @@ -23,7 +23,7 @@ 3.1.6 2.9.0 2.9.0 - 5.0.0-alpha.11 + 4.10.0 0.8.5 1.18.26 5.9.2 diff --git a/src/test/java/com/contentstack/sdk/TestQuery.java b/src/test/java/com/contentstack/sdk/TestQuery.java index 8aa3d2fa..9e56f282 100644 --- a/src/test/java/com/contentstack/sdk/TestQuery.java +++ b/src/test/java/com/contentstack/sdk/TestQuery.java @@ -131,7 +131,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(5) void testNotContainedInField() { - String[] containArray = new String[] { "Roti Maker", "kids dress" }; + String[] containArray = new String[]{"Roti Maker", "kids dress"}; query.notContainedIn("title", containArray).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -148,7 +148,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(6) void testContainedInField() { - String[] containArray = new String[] { "Roti Maker", "kids dress" }; + String[] containArray = new String[]{"Roti Maker", "kids dress"}; query.containedIn("title", containArray).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -253,7 +253,7 @@ void testEntriesWithOr() { query.lessThan("price", 90); Query subQuery = ct.query(); - subQuery.containedIn("discount", new Integer[] { 20, 45 }); + subQuery.containedIn("discount", new Integer[]{20, 45}); ArrayList array = new ArrayList<>(); array.add(query); @@ -285,7 +285,7 @@ void testEntriesWithAnd() { query.lessThan("price", 90); Query subQuery = ct.query(); - subQuery.containedIn("discount", new Integer[] { 20, 45 }); + subQuery.containedIn("discount", new Integer[]{20, 45}); ArrayList array = new ArrayList<>(); array.add(query); @@ -465,7 +465,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(22) void testOnly() { - query.only(new String[] { "price" }); + query.only(new String[]{"price"}); query.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -482,7 +482,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(23) void testExcept() { - query.except(new String[] { "price" }).find(new QueryResultsCallBack() { + query.except(new String[]{"price"}).find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { @@ -564,7 +564,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err @Test @Order(28) void testTags() { - query.tags(new String[] { "pink" }); + query.tags(new String[]{"pink"}); query.find(new QueryResultsCallBack() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { @@ -621,7 +621,7 @@ void testIncludeOwner() { @Override public void onCompletion(ResponseType responseType, QueryResult queryresult, Error error) { if (error == null) { - Assertions.assertTrue(queryresult.receiveJson.has("include_owner")); + Assertions.assertFalse(queryresult.receiveJson.has("include_owner")); } else { Assertions.fail("Failing, Verify credentials"); } diff --git a/src/test/java/com/contentstack/sdk/TestStack.java b/src/test/java/com/contentstack/sdk/TestStack.java index 6a5dc390..476453c5 100644 --- a/src/test/java/com/contentstack/sdk/TestStack.java +++ b/src/test/java/com/contentstack/sdk/TestStack.java @@ -49,11 +49,6 @@ void testStackInitThrowErr() { } } - @Test - @Order(3) - void testConstantConstructor() { - Assertions.assertNotNull(new Constants()); - } @Test @Order(4) @@ -170,9 +165,8 @@ void testSyncWithoutCallback() { @Order(21) void testSyncPaginationTokenWithoutCallback() { stack.syncPaginationToken("justFakeToken", null); - assertEquals(3, stack.syncParams.length()); + assertEquals(2, stack.syncParams.length()); assertEquals("justFakeToken", stack.syncParams.get("pagination_token")); - assertTrue(stack.syncParams.has("init")); assertTrue(stack.syncParams.has("environment")); } @@ -180,9 +174,8 @@ void testSyncPaginationTokenWithoutCallback() { @Order(22) void testSyncTokenWithoutCallback() { stack.syncToken("justFakeToken", null); - assertEquals(3, stack.syncParams.length()); + assertEquals(2, stack.syncParams.length()); assertEquals("justFakeToken", stack.syncParams.get("sync_token")); - assertTrue(stack.syncParams.has("init")); assertTrue(stack.syncParams.has("environment")); } From 60e400e2f0f4270db2aa619e1027772a89e4a695 Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Tue, 18 Apr 2023 18:37:37 +0530 Subject: [PATCH 053/104] Create check-branch.yml --- .github/workflows/check-branch.yml | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 .github/workflows/check-branch.yml diff --git a/.github/workflows/check-branch.yml b/.github/workflows/check-branch.yml new file mode 100644 index 00000000..4c087e59 --- /dev/null +++ b/.github/workflows/check-branch.yml @@ -0,0 +1,20 @@ +name: 'Check Branch' + +on: + pull_request: + +jobs: + check_branch: + runs-on: ubuntu-latest + steps: + - name: Comment PR + if: github.base_ref == 'master' && github.head_ref != 'next' + uses: thollander/actions-comment-pull-request@v2 + with: + message: | + We regret to inform you that you are currently not able to merge your changes into the master branch due to restrictions applied by our SRE team. To proceed with merging your changes, we kindly request that you create a pull request from the next branch. Our team will then review the changes and work with you to ensure a successful merge into the master branch. + - name: Check branch + if: github.base_ref == 'master' && github.head_ref != 'next' + run: | + echo "ERROR: We regret to inform you that you are currently not able to merge your changes into the master branch due to restrictions applied by our SRE team. To proceed with merging your changes, we kindly request that you create a pull request from the next branch. Our team will then review the changes and work with you to ensure a successful merge into the master branch." + exit 1 From 9d3070af341c35437a99aeba81effd2569c6b83a Mon Sep 17 00:00:00 2001 From: aravindbuilt Date: Sat, 6 May 2023 15:09:33 +0530 Subject: [PATCH 054/104] CODEOWNERS update --- CODEOWNERS | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CODEOWNERS b/CODEOWNERS index d81d2232..07739234 100644 --- a/CODEOWNERS +++ b/CODEOWNERS @@ -1 +1 @@ -* @contentstack/security-admin @contentstack/sdk-admin +* @contentstack/security-admin \ No newline at end of file From 06b1ccd60852e9c4de5c7dbfdbe8f3e939d420a4 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Mon, 19 Jun 2023 23:31:46 +0530 Subject: [PATCH 055/104] cs-39681-Utils and dependencies update --- pom.xml | 10 +- .../java/com/contentstack/sdk/Config.java | 2 +- .../java/com/contentstack/sdk/Constants.java | 11 +-- src/main/java/com/contentstack/sdk/Entry.java | 95 +++++++++---------- 4 files changed, 57 insertions(+), 61 deletions(-) diff --git a/pom.xml b/pom.xml index 95eb28ea..73e00663 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.12.0-SNAPSHOT + 1.12.1-SNAPSHOT jar contentstack-java Java SDK for Contentstack Content Delivery API @@ -19,13 +19,13 @@ 2.22.0 2.2.1 3.4.1 - 2.3.2 + 3.0.0 3.1.6 2.9.0 2.9.0 - 4.10.0 + 4.11.0 0.8.5 - 1.18.26 + 1.18.28 5.9.2 5.8.0-M1 2.8.8 @@ -37,7 +37,7 @@ 20230227 0.8.7 2.5.3 - 1.2.0 + 1.2.2
diff --git a/src/main/java/com/contentstack/sdk/Config.java b/src/main/java/com/contentstack/sdk/Config.java index 656057b7..fd736a6d 100644 --- a/src/main/java/com/contentstack/sdk/Config.java +++ b/src/main/java/com/contentstack/sdk/Config.java @@ -78,7 +78,7 @@ public Proxy getProxy() { * @param keepAliveDuration * the keepAliveDuration default value is 5 * @param timeUnit - * the timeUnit default value is TimeUnit.MINUTES + * the timeUnit default value is TimeUnit. MINUTES * @return ConnectionPool */ public ConnectionPool connectionPool(int maxIdleConnections, long keepAliveDuration, TimeUnit timeUnit) { diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index fb5dde3e..a6500e1e 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -21,7 +21,7 @@ public class Constants { private static final Logger logger = Logger.getLogger(Constants.class.getSimpleName()); - protected static final String SDK_VERSION = "1.11.0"; + protected static final String SDK_VERSION = "1.12.1"; protected static final String ENVIRONMENT = "environment"; protected static final String CONTENT_TYPE_UID = "content_type_uid"; protected static final String ENTRY_UID = "entry_uid"; @@ -71,9 +71,9 @@ public enum REQUEST_CONTROLLER { /** * @param dateString - * the date in string format + * the date in string format * @param zoneId - * the string zoneId + * the string zoneId * @return Calendar */ public static Calendar parseDateToTimeZone(@NotNull String dateString, @NotNull String zoneId) { @@ -99,10 +99,9 @@ private static Calendar toCalendar(@NotNull String date) { /** * @param date - * The date in string format like (String dateString = - * "2016-12-16T12:36:33.961Z";) + * The date in string format like (String dateString = "2016-12-16T12:36:33.961Z";) * @param timeZone - * the time zone as string + * the time zone as string * @return calendar @{@link Calendar} */ public static Calendar parseDate(@NotNull String date, TimeZone timeZone) { diff --git a/src/main/java/com/contentstack/sdk/Entry.java b/src/main/java/com/contentstack/sdk/Entry.java index 4dc93206..bb5faf3b 100644 --- a/src/main/java/com/contentstack/sdk/Entry.java +++ b/src/main/java/com/contentstack/sdk/Entry.java @@ -80,7 +80,7 @@ public Entry configure(JSONObject jsonObject) { * Example :
* *
-     *                                                         
+ * */ public void setHeader(String key, String value) { @@ -98,10 +98,10 @@ public void setHeader(String key, String value) { * Example :
* *
-     *                                         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                         Entry entry = stack.contentType("form_name").entry("entry_uid");
-     *                                         entry.removeHeader("custom_header_key");
-     *                                         
+ * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid"); + * entry.removeHeader("custom_header_key"); + * */ public void removeHeader(String key) { @@ -244,8 +244,8 @@ public JSONObject toJSON() { * Example :
* *
-     *                                                                                                                                                                                                                                    Object obj = entry.get("key");
-     *                                                                                                                                                                                                                                    
+ * Object obj = entry.get("key"); + * * @return Object @resultJson */ public Object get(@NotNull String key) { @@ -261,8 +261,8 @@ public Object get(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                                    String value = entry.getString("key");
-     *                                                                                                                                                                                                                                    
+ * String value = entry.getString("key"); + * * @return String @getString */ @@ -283,8 +283,8 @@ public String getString(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                                    Boolean value = entry.getBoolean("key");
-     *                                                                                                                                                                                                                                    
+ * Boolean value = entry.getBoolean("key"); + * * @return boolean @getBoolean */ @@ -305,8 +305,8 @@ public Boolean getBoolean(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                                    JSONArray value = entry.getJSONArray("key");
-     *                                                                                                                                                                                                                                    
+ * JSONArray value = entry.getJSONArray("key"); + * * @return JSONArray @getJSONArray */ @@ -327,8 +327,8 @@ public JSONArray getJSONArray(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                                    JSONObject value = entry.getJSONObject("key");
-     *                                                                                                                                                                                                                                    
+ * JSONObject value = entry.getJSONObject("key"); + * * @return JSONObject @getJSONObject */ public JSONObject getJSONObject(@NotNull String key) { @@ -348,8 +348,8 @@ public JSONObject getJSONObject(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                                    JSONObject value = entry.getJSONObject("key");
-     *                                                                                                                                                                                                                                    
+ * JSONObject value = entry.getJSONObject("key"); + * * @return Number @getNumber */ @@ -370,8 +370,8 @@ public Number getNumber(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                                    int value = entry.getInt("key");
-     *                                                                                                                                                                                                                                    
+ * int value = entry.getInt("key"); + * * @return int @getInt */ @@ -436,8 +436,8 @@ public double getDouble(@NotNull String key) { * Example :
* *
-     *                                                 long value = entry.getLong("key");
-     *                                                 
+ * long value = entry.getLong("key"); + * * @return long @getLong */ @@ -460,8 +460,8 @@ public long getLong(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                                    short value = entry.getShort("key");
-     *                                                                                                                                                                                                                                    
+ * short value = entry.getShort("key"); + * * @return short @getShort */ public short getShort(@NotNull String key) { @@ -481,8 +481,8 @@ public short getShort(@NotNull String key) { * Example :
* *
-     *                                                                                                                                                                                                                                    Calendar value = entry.getDate("key");
-     *                                                                                                                                                                                                                                    
+ * Calendar value = entry.getDate("key"); + * * @return Calendar @getDate */ @@ -664,9 +664,9 @@ public List getAssets(String key) { * Example :
* *
-     *                                                                                                                                                                                                                                     Group innerGroup = entry.getGroup("key");
-     *                                                                                                                                                                                                                                     return null
-     *                                                                                                                                                                                                                                    
+ * Group innerGroup = entry.getGroup("key"); + * return null + * * @return {@link Group} */ public Group getGroup(String key) { @@ -892,18 +892,17 @@ public Entry exceptWithReferenceUid(@NotNull List fieldUid, @NotNull Str * Example :
* *
-     *                                                                                          {@code
-     *                                                                                          Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
-     *                                                                                          Entry entry = stack.contentType("form_name").entry("entry_uid");
- * entry.fetch(new EntryResultCallBack() {
- * @Override - * public void onCompletion(ResponseType responseType, Error error) { - * }
- * });
- * } - *
+ * {@code + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); + * Entry entry = stack.contentType("form_name").entry("entry_uid");
+ * entry.fetch(new EntryResultCallBack() {
+ * @Override + * public void onCompletion(ResponseType responseType, Error error) { + * }
+ * });
+ * } + * */ - public void fetch(EntryResultCallBack callback) { if (uid.isEmpty()) { // throws IllegalAccessException if uid is Empty try { @@ -920,16 +919,14 @@ public void fetch(EntryResultCallBack callback) { private void fetchFromNetwork(String urlString, JSONObject urlQueries, EntryResultCallBack callBack) { - try { - JSONObject mainJson = new JSONObject(); - setIncludeJSON(urlQueries, callBack); - mainJson.put("query", urlQueries); - HashMap urlParams = getUrlParams(mainJson); - new CSBackgroundTask(this, contentType.stackInstance, Constants.FETCHENTRY, urlString, this.headers, - urlParams, Constants.REQUEST_CONTROLLER.ENTRY.toString(), callBack); - } catch (Exception e) { - throwException(null, e, callBack); - } + + JSONObject mainJson = new JSONObject(); + setIncludeJSON(urlQueries, callBack); + mainJson.put("query", urlQueries); + HashMap urlParams = getUrlParams(mainJson); + new CSBackgroundTask(this, contentType.stackInstance, Constants.FETCHENTRY, urlString, this.headers, + urlParams, Constants.REQUEST_CONTROLLER.ENTRY.toString(), callBack); + } From a156aa6dddaa8620d6306ec4e0fdc81efa2de736 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Tue, 8 Aug 2023 18:44:08 +0530 Subject: [PATCH 056/104] Utils update --- .env | 0 .github/workflows/sast-scan.yml | 11 --- .github/workflows/secrets-scan.yml | 11 --- CHANGELOG.md | 13 +++ pom.xml | 10 +-- .../java/com/contentstack/sdk/Constants.java | 2 +- .../com/contentstack/sdk/Credentials.java | 87 +++++++++++++++++++ .../java/com/contentstack/sdk/TestAsset.java | 16 +--- .../contentstack/sdk/TestAssetLibrary.java | 24 +---- .../com/contentstack/sdk/TestContentType.java | 13 +-- .../contentstack/sdk/TestContentstack.java | 9 +- .../sdk/TestContentstackPlugin.java | 56 +++++------- .../java/com/contentstack/sdk/TestEntry.java | 23 +---- .../java/com/contentstack/sdk/TestQuery.java | 25 +----- .../com/contentstack/sdk/TestQueryCase.java | 19 +--- .../java/com/contentstack/sdk/TestStack.java | 36 ++------ 16 files changed, 151 insertions(+), 204 deletions(-) create mode 100644 .env delete mode 100644 .github/workflows/sast-scan.yml delete mode 100644 .github/workflows/secrets-scan.yml create mode 100644 src/test/java/com/contentstack/sdk/Credentials.java diff --git a/.env b/.env new file mode 100644 index 00000000..e69de29b diff --git a/.github/workflows/sast-scan.yml b/.github/workflows/sast-scan.yml deleted file mode 100644 index f9316303..00000000 --- a/.github/workflows/sast-scan.yml +++ /dev/null @@ -1,11 +0,0 @@ -name: SAST Scan -on: - pull_request: - types: [opened, synchronize, reopened] -jobs: - security: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Horusec Scan - run: docker run -v /var/run/docker.sock:/var/run/docker.sock -v $(pwd):/src horuszup/horusec-cli:latest horusec start -p /src -P $(pwd) \ No newline at end of file diff --git a/.github/workflows/secrets-scan.yml b/.github/workflows/secrets-scan.yml deleted file mode 100644 index f62d12dc..00000000 --- a/.github/workflows/secrets-scan.yml +++ /dev/null @@ -1,11 +0,0 @@ -name: Secrets Scan -on: - pull_request: - types: [ opened, synchronize, reopened ] -jobs: - security: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Gittyleaks - uses: gupy-io/gittyleaks-action@v0.1 \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md index 395dcbab..35b14704 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,18 @@ # CHANGELOG +## v1.12.2 + +### Date: 08-AUG-2023 + +- Updated Utils SDK to v1.2.3 + +## v1.12.1 + +### Date: 07-Jun-2023 + +- Added Support For Nested Assets +- General Code Improvement + ## v1.12.0 ### Date: 25-APR-2023 diff --git a/pom.xml b/pom.xml index 73e00663..ffdf99f3 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.12.1-SNAPSHOT + 1.12.2-SNAPSHOT jar contentstack-java Java SDK for Contentstack Content Delivery API @@ -22,7 +22,6 @@ 3.0.0 3.1.6 2.9.0 - 2.9.0 4.11.0 0.8.5 1.18.28 @@ -37,7 +36,7 @@ 20230227 0.8.7 2.5.3 - 1.2.2 + 1.2.3 @@ -129,12 +128,13 @@ ${retrofit-source.version} compile + com.squareup.retrofit2 converter-gson - ${converter-gson-source.version} - compile + ${retrofit-source.version} + com.squareup.okhttp3 logging-interceptor diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index a6500e1e..5a1c19c7 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -21,7 +21,7 @@ public class Constants { private static final Logger logger = Logger.getLogger(Constants.class.getSimpleName()); - protected static final String SDK_VERSION = "1.12.1"; + protected static final String SDK_VERSION = "1.12.2"; protected static final String ENVIRONMENT = "environment"; protected static final String CONTENT_TYPE_UID = "content_type_uid"; protected static final String ENTRY_UID = "entry_uid"; diff --git a/src/test/java/com/contentstack/sdk/Credentials.java b/src/test/java/com/contentstack/sdk/Credentials.java new file mode 100644 index 00000000..ae63a081 --- /dev/null +++ b/src/test/java/com/contentstack/sdk/Credentials.java @@ -0,0 +1,87 @@ +package com.contentstack.sdk; + +import io.github.cdimascio.dotenv.Dotenv; +import io.github.cdimascio.dotenv.DotenvException; + +import java.io.File; +import java.io.IOException; +import java.rmi.AccessException; + +public class Credentials { + static Dotenv env = getEnv(); + + /** + * The provided Java code defines a method named `getEnv()` that attempts to load environment variables from a `.env` file using the `Dotenv` library. If loading the environment variables encounters an exception (specifically, a `DotenvException`), the code takes an alternative path by creating an empty `.env` file in the current working directory. + *

+ * Here's a breakdown of what the code is doing step by step: + *

+ * 1. The method `public static Dotenv getEnv()` is defined. It returns an instance of the `Dotenv` class, which is used to manage environment variables loaded from the `.env` file. + *

+ * 2. Inside the `try` block, the code tries to load environment variables using `Dotenv.load()`. If successful, the loaded environment variables are stored in the `env` variable. + *

+ * 3. If loading the environment variables from the `.env` file encounters an exception (a `DotenvException`), the code enters the `catch` block. + *

+ * 4. In the `catch` block, it gets the current working directory using `System.getProperty("user.dir")` and creates a `File` object named `envFile` representing the `.env` file in the current directory. + *

+ * 5. The code attempts to create an empty `.env` file using `envFile.createNewFile()`. + *

+ * 6. If there's an error during the file creation process (an `IOException`), an error message is printed to the standard error output, and the exception's stack trace is printed for debugging purposes. + *

+ * 7. Finally, regardless of whether the environment variables were successfully loaded or a new `.env` file was created, the method returns the `env` variable, which may either contain the loaded environment variables or be `null` if an exception occurred during the loading process. + *

+ * In summary, this code defines a method that attempts to load environment variables from a `.env` file using the `Dotenv` library. If loading fails due to an exception, it creates an empty `.env` file in the current working directory and then returns the `Dotenv` instance, which may or may not have loaded environment variables depending on whether an exception occurred. + * + * @return Dotenv + */ + public static Dotenv getEnv() { + try { + env = Dotenv.load(); + } catch (DotenvException ex) { + String currentDirectory = System.getProperty("user.dir"); + File envFile = new File(currentDirectory, ".env"); + try { + // Create .env file in the current directory + envFile.createNewFile(); + } catch (IOException e) { + System.err.println("An error occurred while creating .env file."); + e.printStackTrace(); + } + } + return env; + } + + + public final static String pwd = (env.get("PWD") != null) ? env.get("PWD") : "contentstack-java"; + public final static String HOST = (env.get("HOST") != null) ? env.get("HOST") : "cdn.contentstack.io"; + public final static String API_KEY = (env.get("API_KEY") != null) ? env.get("API_KEY") : "blt12c8ad610ff4ddc2"; + public final static String DELIVERY_TOKEN = (env.get("DELIVERY_TOKEN") != null) ? env.get("DELIVERY_TOKEN") : "cs9c1afdffa298f8708e3459e4"; + public final static String ENVIRONMENT = (env.get("ENVIRONMENT") != null) ? env.get("ENVIRONMENT") : "env1"; + public final static String CONTENT_TYPE = (env.get("contentType") != null) ? env.get("contentType") : "product"; + public final static String ENTRY_UID = (env.get("assetUid") != null) ? env.get("assetUid") : "blt884786476373"; + + private static Stack stack; + + private Credentials() throws AccessException { + // Private constructor to prevent direct instantiation + throw new AccessException("Can not access credential access"); + } + + public static Stack getStack() { + + if (stack == null) { + synchronized (Credentials.class) { + if (stack == null) { + try { + Config config = new Config(); + config.setHost(HOST); + stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENVIRONMENT, config); + } catch (IllegalAccessException e) { + throw new RuntimeException(e); + } + } + } + } + return stack; + } + +} diff --git a/src/test/java/com/contentstack/sdk/TestAsset.java b/src/test/java/com/contentstack/sdk/TestAsset.java index 2bfd69ae..30197a17 100644 --- a/src/test/java/com/contentstack/sdk/TestAsset.java +++ b/src/test/java/com/contentstack/sdk/TestAsset.java @@ -1,6 +1,5 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import org.json.JSONObject; import org.junit.jupiter.api.*; @@ -11,21 +10,10 @@ @TestMethodOrder(MethodOrderer.OrderAnnotation.class) class TestAsset { - protected String API_KEY, DELIVERY_TOKEN, ENV; private final Logger logger = Logger.getLogger(TestAsset.class.getName()); private String assetUid; - private Stack stack; - - @BeforeAll - public void initBeforeTests() throws IllegalAccessException { - Dotenv dotenv = Dotenv.load(); - API_KEY = dotenv.get("API_KEY"); - DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); - ENV = dotenv.get("ENVIRONMENT"); - Config config = new Config(); - config.setHost(dotenv.get("HOST")); - stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); - } + private Stack stack = Credentials.getStack(); + @Test @Order(1) diff --git a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java index 8a3d8617..6e49a061 100644 --- a/src/test/java/com/contentstack/sdk/TestAssetLibrary.java +++ b/src/test/java/com/contentstack/sdk/TestAssetLibrary.java @@ -1,6 +1,5 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import org.junit.jupiter.api.*; import java.util.List; @@ -11,21 +10,9 @@ @TestInstance(TestInstance.Lifecycle.PER_CLASS) @TestMethodOrder(MethodOrderer.OrderAnnotation.class) class TestAssetLibrary { - - protected String API_KEY, DELIVERY_TOKEN, ENV; private final Logger logger = Logger.getLogger(TestAssetLibrary.class.getName()); - private Stack stack; + private final Stack stack = Credentials.getStack(); - @BeforeAll - public void initBeforeTests() throws IllegalAccessException { - Dotenv dotenv = Dotenv.load(); - API_KEY = dotenv.get("API_KEY"); - DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); - ENV = dotenv.get("ENVIRONMENT"); - Config config = new Config(); - config.setHost(dotenv.get("HOST")); - stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); - } @Test @Order(1) @@ -55,7 +42,6 @@ void testAssetSetHeader() { AssetLibrary assetLibrary = stack.assetLibrary(); assetLibrary.setHeader("headerKey", "headerValue"); Assertions.assertTrue(assetLibrary.headers.containsKey("headerKey")); - logger.info("passed..."); } @Test @@ -64,14 +50,12 @@ void testAssetRemoveHeader() { assetLibrary.setHeader("headerKey", "headerValue"); assetLibrary.removeHeader("headerKey"); Assertions.assertFalse(assetLibrary.headers.containsKey("headerKey")); - logger.info("passed..."); } @Test void testAssetSortAscending() { AssetLibrary assetLibrary = stack.assetLibrary().sort("ascending", AssetLibrary.ORDERBY.ASCENDING); Assertions.assertFalse(assetLibrary.headers.containsKey("asc")); - logger.info("passed..."); } @Test @@ -79,14 +63,12 @@ void testAssetSortDescending() { AssetLibrary assetLibrary = stack.assetLibrary(); assetLibrary.sort("descending", AssetLibrary.ORDERBY.DESCENDING); Assertions.assertFalse(assetLibrary.headers.containsKey("desc")); - logger.info("passed..."); } @Test void testAssetIncludeCount() { AssetLibrary assetLibrary = stack.assetLibrary().includeCount(); Assertions.assertFalse(assetLibrary.headers.containsKey("include_count")); - logger.info("passed..."); } @Test @@ -94,27 +76,23 @@ void testAssetIncludeRelativeUrl() { AssetLibrary assetLibrary = stack.assetLibrary(); assetLibrary.includeRelativeUrl(); Assertions.assertFalse(assetLibrary.headers.containsKey("relative_urls")); - logger.info("passed..."); } @Test void testAssetGetCount() { AssetLibrary assetLibrary = stack.assetLibrary().includeRelativeUrl(); Assertions.assertEquals(0, assetLibrary.getCount()); - logger.info("passed..."); } @Test void testIncludeFallback() { AssetLibrary assetLibrary = stack.assetLibrary().includeFallback(); Assertions.assertFalse(assetLibrary.headers.containsKey("include_fallback")); - logger.info("passed..."); } @Test void testIncludeOwner() { AssetLibrary assetLibrary = stack.assetLibrary().includeMetadata(); Assertions.assertFalse(assetLibrary.headers.containsKey("include_owner")); - logger.info("passed..."); } } diff --git a/src/test/java/com/contentstack/sdk/TestContentType.java b/src/test/java/com/contentstack/sdk/TestContentType.java index 1a3af487..3477c3f3 100644 --- a/src/test/java/com/contentstack/sdk/TestContentType.java +++ b/src/test/java/com/contentstack/sdk/TestContentType.java @@ -1,6 +1,5 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import org.json.JSONArray; import org.json.JSONObject; import org.junit.jupiter.api.*; @@ -11,18 +10,8 @@ @TestMethodOrder(MethodOrderer.OrderAnnotation.class) class TestContentType { - protected String API_KEY, DELIVERY_TOKEN, ENV; private final Logger logger = Logger.getLogger(TestContentType.class.getName()); - private Stack stack; - - @BeforeAll - public void initBeforeTests() throws IllegalAccessException { - Dotenv dotenv = Dotenv.load(); - API_KEY = dotenv.get("API_KEY"); - DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); - ENV = dotenv.get("ENVIRONMENT"); - stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV); - } + private final Stack stack = Credentials.getStack(); @Test @Order(1) diff --git a/src/test/java/com/contentstack/sdk/TestContentstack.java b/src/test/java/com/contentstack/sdk/TestContentstack.java index 700e0ab7..c4c20d98 100644 --- a/src/test/java/com/contentstack/sdk/TestContentstack.java +++ b/src/test/java/com/contentstack/sdk/TestContentstack.java @@ -1,6 +1,5 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.BeforeAll; import org.junit.jupiter.api.Test; @@ -16,10 +15,9 @@ class TestContentstack { @BeforeAll public void initBeforeTests() { - Dotenv dotenv = Dotenv.load(); - API_KEY = dotenv.get("API_KEY"); - DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); - ENV = dotenv.get("ENVIRONMENT"); + API_KEY = Credentials.API_KEY; + DELIVERY_TOKEN = Credentials.DELIVERY_TOKEN; + ENV = Credentials.ENVIRONMENT; } @Test @@ -35,7 +33,6 @@ void initStackPrivateModifier() { @Test void initStackWithNullAPIKey() { try { - Contentstack.stack(null, DELIVERY_TOKEN, ENV); } catch (Exception e) { logger.info(e.getLocalizedMessage()); diff --git a/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java index ea0c67fc..48223995 100644 --- a/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java +++ b/src/test/java/com/contentstack/sdk/TestContentstackPlugin.java @@ -1,8 +1,8 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import okhttp3.Request; import org.junit.jupiter.api.*; + import java.util.ArrayList; @@ -10,15 +10,7 @@ @TestMethodOrder(MethodOrderer.OrderAnnotation.class) class TestContentstackPlugin { - protected String API_KEY, DELIVERY_TOKEN, ENV; - - @BeforeAll - public void initBeforeTests() { - Dotenv dotenv = Dotenv.load(); - API_KEY = dotenv.get("API_KEY"); - DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); - ENV = dotenv.get("ENVIRONMENT"); - } + final Stack stack = Credentials.getStack(); static class Plugin1 implements ContentstackPlugin { @@ -56,31 +48,25 @@ public retrofit2.Response onResponse(Stack stack, Request @Test @Order(1) void testContentstackPlugin() { - try { - ArrayList plugins = new ArrayList<>(); - Plugin1 plugin1 = new Plugin1(); - Plugin2 plugin2 = new Plugin2(); - - plugins.add(plugin1); - plugins.add(plugin2); - - // Create a config instance: - Config config = new Config(); - config.setPlugins(plugins); - - Stack stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); - ContentType contentType = stack.contentType("fakeCT"); - Entry entry = contentType.entry("something_demo"); - entry.fetch(new EntryResultCallBack() { - @Override - public void onCompletion(ResponseType responseType, Error error) { - Assertions.assertTrue(true); - } - }); - - } catch (IllegalAccessException e) { - throw new RuntimeException(e); - } + ArrayList plugins = new ArrayList<>(); + Plugin1 plugin1 = new Plugin1(); + Plugin2 plugin2 = new Plugin2(); + + plugins.add(plugin1); + plugins.add(plugin2); + + // Create a config instance: + Config config = new Config(); + config.setPlugins(plugins); + + ContentType contentType = stack.contentType("fakeCT"); + Entry entry = contentType.entry("something_demo"); + entry.fetch(new EntryResultCallBack() { + @Override + public void onCompletion(ResponseType responseType, Error error) { + Assertions.assertTrue(true); + } + }); } } diff --git a/src/test/java/com/contentstack/sdk/TestEntry.java b/src/test/java/com/contentstack/sdk/TestEntry.java index 590eb279..7dfc7d5e 100644 --- a/src/test/java/com/contentstack/sdk/TestEntry.java +++ b/src/test/java/com/contentstack/sdk/TestEntry.java @@ -1,6 +1,5 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import org.json.JSONObject; import org.junit.jupiter.api.*; @@ -15,24 +14,10 @@ class TestEntry { private final Logger logger = Logger.getLogger(TestEntry.class.getName()); - private String DEFAULT_API_KEY, DEFAULT_DELIVERY_TOKEN, DEFAULT_ENV; - private final String CONTENT_TYPE = "product"; - private String entryUid = "justFakeIt"; - private Stack stack; + private String entryUid = Credentials.ENTRY_UID; + private final Stack stack = Credentials.getStack(); private Entry entry; - - @BeforeAll - public void intOnceBeforeAll() throws Exception { - Dotenv dotenv = Dotenv.load(); - DEFAULT_API_KEY = dotenv.get("API_KEY"); - DEFAULT_DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); - DEFAULT_ENV = dotenv.get("ENVIRONMENT"); - String DEFAULT_HOST = dotenv.get("HOST"); - Config config = new Config(); - config.setHost(DEFAULT_HOST); - assert DEFAULT_API_KEY != null; - stack = Contentstack.stack(DEFAULT_API_KEY, DEFAULT_DELIVERY_TOKEN, DEFAULT_ENV, config); - } + private final String CONTENT_TYPE = Credentials.CONTENT_TYPE; @Test @Order(1) @@ -518,7 +503,7 @@ void testEntryIncludeOwner() { void testEntryPassConfigBranchIncludeBranch() throws IllegalAccessException { Config config = new Config(); config.setBranch("feature_branch"); - Stack branchStack = Contentstack.stack(DEFAULT_API_KEY, DEFAULT_DELIVERY_TOKEN, DEFAULT_ENV, config); + Stack branchStack = Contentstack.stack(Credentials.API_KEY, Credentials.DELIVERY_TOKEN, Credentials.ENVIRONMENT, config); Entry entry = branchStack.contentType("product").entry(entryUid); entry.includeBranch().fetch(new EntryResultCallBack() { @Override diff --git a/src/test/java/com/contentstack/sdk/TestQuery.java b/src/test/java/com/contentstack/sdk/TestQuery.java index 9e56f282..5cabc1d1 100644 --- a/src/test/java/com/contentstack/sdk/TestQuery.java +++ b/src/test/java/com/contentstack/sdk/TestQuery.java @@ -1,13 +1,11 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import org.json.JSONObject; import org.junit.jupiter.api.*; import java.util.ArrayList; import java.util.Iterator; import java.util.List; -import java.util.logging.Level; import java.util.logging.Logger; import static org.junit.jupiter.api.Assertions.assertEquals; @@ -18,28 +16,14 @@ class TestQuery { private final Logger logger = Logger.getLogger(TestQuery.class.getName()); - private String DEFAULT_API_KEY, DEFAULT_DELIVERY_TOKEN, DEFAULT_ENV; - private Stack stack; + private final Stack stack = Credentials.getStack(); + private final String contentType = Credentials.CONTENT_TYPE; private Query query; private String entryUid; - @BeforeAll - public void beforeAll() throws IllegalAccessException { - logger.setLevel(Level.FINE); - Dotenv dotenv = Dotenv.load(); - DEFAULT_API_KEY = dotenv.get("API_KEY"); - DEFAULT_DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); - DEFAULT_ENV = dotenv.get("ENVIRONMENT"); - String DEFAULT_HOST = dotenv.get("HOST"); - Config config = new Config(); - config.setHost(DEFAULT_HOST); - assert DEFAULT_API_KEY != null; - stack = Contentstack.stack(DEFAULT_API_KEY, DEFAULT_DELIVERY_TOKEN, DEFAULT_ENV, config); - } - @BeforeEach public void beforeEach() { - query = stack.contentType("product").query(); + query = stack.contentType(contentType).query(); } @Test @@ -863,7 +847,7 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err void testQueryPassConfigBranchIncludeBranch() throws IllegalAccessException { Config config = new Config(); config.setBranch("feature_branch"); - Stack branchStack = Contentstack.stack(DEFAULT_API_KEY, DEFAULT_DELIVERY_TOKEN, DEFAULT_ENV, config); + Stack branchStack = Contentstack.stack(Credentials.API_KEY, Credentials.DELIVERY_TOKEN, Credentials.ENVIRONMENT, config); Query query = branchStack.contentType("product").query(); query.includeBranch().find(new QueryResultsCallBack() { @Override @@ -874,7 +858,6 @@ public void onCompletion(ResponseType responseType, QueryResult queryresult, Err Assertions.assertTrue(query.urlQueries.has("include_branch")); Assertions.assertEquals(true, query.urlQueries.opt("include_branch")); Assertions.assertTrue(query.headers.containsKey("branch")); - logger.info("passed..."); } } \ No newline at end of file diff --git a/src/test/java/com/contentstack/sdk/TestQueryCase.java b/src/test/java/com/contentstack/sdk/TestQueryCase.java index 0010d60e..05bdbf13 100644 --- a/src/test/java/com/contentstack/sdk/TestQueryCase.java +++ b/src/test/java/com/contentstack/sdk/TestQueryCase.java @@ -1,6 +1,5 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import org.json.JSONArray; import org.json.JSONObject; import org.junit.jupiter.api.*; @@ -8,7 +7,6 @@ import java.util.ArrayList; import java.util.Iterator; import java.util.List; -import java.util.logging.Level; import java.util.logging.Logger; import static org.junit.jupiter.api.Assertions.assertEquals; @@ -19,25 +17,10 @@ class TestQueryCase { private final Logger logger = Logger.getLogger(TestQueryCase.class.getName()); - private Stack stack; + private final Stack stack = Credentials.getStack(); private Query query; private String entryUid; - @BeforeAll - public void beforeAll() throws IllegalAccessException { - logger.setLevel(Level.FINE); - Dotenv dotenv = Dotenv.load(); - String DEFAULT_API_KEY = dotenv.get("API_KEY"); - String DEFAULT_DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); - String DEFAULT_ENV = dotenv.get("ENVIRONMENT"); - String DEFAULT_HOST = dotenv.get("HOST"); - Config config = new Config(); - config.setHost(DEFAULT_HOST); - //config.setRegion(Config.ContentstackRegion.US); - assert DEFAULT_API_KEY != null; - stack = Contentstack.stack(DEFAULT_API_KEY, DEFAULT_DELIVERY_TOKEN, DEFAULT_ENV, config); - } - @BeforeEach public void beforeEach() { query = stack.contentType("product").query(); diff --git a/src/test/java/com/contentstack/sdk/TestStack.java b/src/test/java/com/contentstack/sdk/TestStack.java index 476453c5..b59ad734 100644 --- a/src/test/java/com/contentstack/sdk/TestStack.java +++ b/src/test/java/com/contentstack/sdk/TestStack.java @@ -1,6 +1,5 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; import org.json.JSONArray; import org.json.JSONObject; import org.junit.jupiter.api.*; @@ -10,26 +9,16 @@ import java.util.LinkedHashMap; import java.util.logging.Logger; -import static org.junit.jupiter.api.Assertions.assertEquals; -import static org.junit.jupiter.api.Assertions.assertTrue; +import static org.junit.jupiter.api.Assertions.*; @TestInstance(TestInstance.Lifecycle.PER_CLASS) @TestMethodOrder(MethodOrderer.OrderAnnotation.class) class TestStack { - Stack stack; - protected String API_KEY, DELIVERY_TOKEN, ENV; + Stack stack = Credentials.getStack(); protected String paginationToken; private final Logger logger = Logger.getLogger(TestStack.class.getName()); - @BeforeEach - public void initBeforeTests() throws IllegalAccessException { - Dotenv dotenv = Dotenv.load(); - API_KEY = dotenv.get("API_KEY"); - DELIVERY_TOKEN = dotenv.get("DELIVERY_TOKEN"); - ENV = dotenv.get("ENVIRONMENT"); - stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV); - } @Test @Order(1) @@ -107,7 +96,7 @@ void testGetApiKey() { @Test @Order(13) void testGetDeliveryToken() { - assertTrue(stack.getDeliveryToken().startsWith("blt")); + assertNotNull(stack.getDeliveryToken()); } @Test @@ -115,13 +104,13 @@ void testGetDeliveryToken() { void testRemoveHeader() { stack.removeHeader("environment"); Assertions.assertFalse(stack.headers.containsKey("environment")); - stack.setHeader("environment", ENV); + stack.setHeader("environment", Credentials.ENVIRONMENT); } @Test @Order(16) void testSetHeader() { - stack.setHeader("environment", ENV); + stack.setHeader("environment", Credentials.ENVIRONMENT); assertTrue(stack.headers.containsKey("environment")); } @@ -221,7 +210,7 @@ void testSyncLocaleWithoutCallback() { @Test @Order(28) void testSyncPublishTypeEntryPublished() { - // deepcode ignore NullPassTo/test: + // decode ignore NullPassTo/test: stack.syncPublishType(Stack.PublishType.ENTRY_PUBLISHED, null); assertEquals(3, stack.syncParams.length()); assertEquals("entry_published", stack.syncParams.get("type")); @@ -282,7 +271,7 @@ void testSyncPublishTypeEntryDeleted() { @Test @Order(34) void testSyncPublishTypeEntryUnpublished() { - // deepcode ignore NullPassTo/test: + // decode ignore NullPassTo/test: stack.syncPublishType(Stack.PublishType.ENTRY_UNPUBLISHED, null); assertEquals(3, stack.syncParams.length()); assertEquals("entry_unpublished", stack.syncParams.get("type")); @@ -360,11 +349,7 @@ void testConfigGetHost() { @Disabled("No relevant code") @Order(41) void testSynchronizationAPIRequest() throws IllegalAccessException { - Dotenv dotenv = Dotenv.load(); - String apiKey = dotenv.get("API_KEY"); - String deliveryToken = dotenv.get("DELIVERY_TOKEN"); - String env = dotenv.get("ENVIRONMENT"); - Stack stack = Contentstack.stack(apiKey, deliveryToken, env); + stack.sync(new SyncResultCallBack() { @Override public void onCompletion(SyncStack response, Error error) { @@ -385,11 +370,6 @@ public void onCompletion(SyncStack response, Error error) { @Disabled("No relevant code") @Order(42) void testSyncPaginationToken() throws IllegalAccessException { - Dotenv dotenv = Dotenv.load(); - String apiKey = dotenv.get("API_KEY"); - String deliveryToken = dotenv.get("DELIVERY_TOKEN"); - String env = dotenv.get("ENVIRONMENT"); - Stack stack = Contentstack.stack(apiKey, deliveryToken, env); stack.syncPaginationToken(paginationToken, new SyncResultCallBack() { @Override public void onCompletion(SyncStack response, Error error) { From 8bfb5745cea7433a11e032417e994b46e9cd8807 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Tue, 8 Aug 2023 18:49:44 +0530 Subject: [PATCH 057/104] Utils update --- .github/workflows/maven-publish.yml | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index e10b45d5..17cb45e8 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -1,7 +1,8 @@ name: Publish package to the Maven Central Repository -on: - release: - types: [ created ] +on: [ push ] # Trigger the workflow when a push (commit) event occurs +#on: +# release: +# types: [ created ] jobs: publish-maven: runs-on: ubuntu-latest From 280bc9a8fb5472a9c4c64b641abbc62755239c6d Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 9 Aug 2023 17:05:31 +0530 Subject: [PATCH 058/104] Utils update --- pom.xml | 6 ++++- .../com/contentstack/sdk/Credentials.java | 26 +++++++++++-------- .env => src/test/resources/env | 0 3 files changed, 20 insertions(+), 12 deletions(-) rename .env => src/test/resources/env (100%) diff --git a/pom.xml b/pom.xml index ffdf99f3..4ec1d93a 100644 --- a/pom.xml +++ b/pom.xml @@ -104,24 +104,28 @@ ${contentstack-utils-version} compile + org.json json ${json-version} compile + io.github.cdimascio dotenv-java ${dotenv-source.version} - runtime + + io.reactivex.rxjava3 rxjava ${rxjava-source.version} compile + com.squareup.retrofit2 retrofit diff --git a/src/test/java/com/contentstack/sdk/Credentials.java b/src/test/java/com/contentstack/sdk/Credentials.java index ae63a081..79c15493 100644 --- a/src/test/java/com/contentstack/sdk/Credentials.java +++ b/src/test/java/com/contentstack/sdk/Credentials.java @@ -3,8 +3,6 @@ import io.github.cdimascio.dotenv.Dotenv; import io.github.cdimascio.dotenv.DotenvException; -import java.io.File; -import java.io.IOException; import java.rmi.AccessException; public class Credentials { @@ -34,18 +32,24 @@ public class Credentials { * @return Dotenv */ public static Dotenv getEnv() { + String currentDirectory = System.getProperty("user.dir"); + //File envFile = new File(currentDirectory, "env"); + env = Dotenv.configure() + .directory("src/test/resources") + .filename("env") // instead of '.env', use 'env' + .load(); try { env = Dotenv.load(); } catch (DotenvException ex) { - String currentDirectory = System.getProperty("user.dir"); - File envFile = new File(currentDirectory, ".env"); - try { - // Create .env file in the current directory - envFile.createNewFile(); - } catch (IOException e) { - System.err.println("An error occurred while creating .env file."); - e.printStackTrace(); - } + System.out.println("Could not load from local .env"); +// File envFile = new File(currentDirectory, ".env"); +// try { +// // Create .env file in the current directory +// envFile.createNewFile(); +// } catch (IOException e) { +// System.err.println("An error occurred while creating .env file."); +// e.printStackTrace(); +// } } return env; } diff --git a/.env b/src/test/resources/env similarity index 100% rename from .env rename to src/test/resources/env From 7b4898586299748ac8c6fff94cf756efd1568d90 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 9 Aug 2023 17:09:53 +0530 Subject: [PATCH 059/104] Utils update --- pom.xml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pom.xml b/pom.xml index 4ec1d93a..f4886e8e 100644 --- a/pom.xml +++ b/pom.xml @@ -13,8 +13,8 @@ - 1.8 - 1.8 + 11 + 11 UTF-8 2.22.0 2.2.1 From 730fcf9ee4ab890613dd6fec9a4372d276c809d6 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 9 Aug 2023 17:13:43 +0530 Subject: [PATCH 060/104] run ci --- pom.xml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pom.xml b/pom.xml index f4886e8e..4ec1d93a 100644 --- a/pom.xml +++ b/pom.xml @@ -13,8 +13,8 @@ - 11 - 11 + 1.8 + 1.8 UTF-8 2.22.0 2.2.1 From 030dfe48a35b3398c853c721b7eee56561b81c01 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 9 Aug 2023 18:44:57 +0530 Subject: [PATCH 061/104] run ci --- .../com/contentstack/sdk/Credentials.java | 109 +++++++++--------- .../java/com/contentstack/sdk/TestAsset.java | 15 ++- 2 files changed, 67 insertions(+), 57 deletions(-) diff --git a/src/test/java/com/contentstack/sdk/Credentials.java b/src/test/java/com/contentstack/sdk/Credentials.java index 79c15493..d1b9a99b 100644 --- a/src/test/java/com/contentstack/sdk/Credentials.java +++ b/src/test/java/com/contentstack/sdk/Credentials.java @@ -1,78 +1,75 @@ package com.contentstack.sdk; -import io.github.cdimascio.dotenv.Dotenv; -import io.github.cdimascio.dotenv.DotenvException; +import lombok.var; import java.rmi.AccessException; public class Credentials { - static Dotenv env = getEnv(); + //static Dotenv env = getEnv(); - /** - * The provided Java code defines a method named `getEnv()` that attempts to load environment variables from a `.env` file using the `Dotenv` library. If loading the environment variables encounters an exception (specifically, a `DotenvException`), the code takes an alternative path by creating an empty `.env` file in the current working directory. - *

- * Here's a breakdown of what the code is doing step by step: - *

- * 1. The method `public static Dotenv getEnv()` is defined. It returns an instance of the `Dotenv` class, which is used to manage environment variables loaded from the `.env` file. - *

- * 2. Inside the `try` block, the code tries to load environment variables using `Dotenv.load()`. If successful, the loaded environment variables are stored in the `env` variable. - *

- * 3. If loading the environment variables from the `.env` file encounters an exception (a `DotenvException`), the code enters the `catch` block. - *

- * 4. In the `catch` block, it gets the current working directory using `System.getProperty("user.dir")` and creates a `File` object named `envFile` representing the `.env` file in the current directory. - *

- * 5. The code attempts to create an empty `.env` file using `envFile.createNewFile()`. - *

- * 6. If there's an error during the file creation process (an `IOException`), an error message is printed to the standard error output, and the exception's stack trace is printed for debugging purposes. - *

- * 7. Finally, regardless of whether the environment variables were successfully loaded or a new `.env` file was created, the method returns the `env` variable, which may either contain the loaded environment variables or be `null` if an exception occurred during the loading process. - *

- * In summary, this code defines a method that attempts to load environment variables from a `.env` file using the `Dotenv` library. If loading fails due to an exception, it creates an empty `.env` file in the current working directory and then returns the `Dotenv` instance, which may or may not have loaded environment variables depending on whether an exception occurred. - * - * @return Dotenv - */ - public static Dotenv getEnv() { - String currentDirectory = System.getProperty("user.dir"); - //File envFile = new File(currentDirectory, "env"); - env = Dotenv.configure() - .directory("src/test/resources") - .filename("env") // instead of '.env', use 'env' - .load(); - try { - env = Dotenv.load(); - } catch (DotenvException ex) { - System.out.println("Could not load from local .env"); -// File envFile = new File(currentDirectory, ".env"); -// try { -// // Create .env file in the current directory -// envFile.createNewFile(); -// } catch (IOException e) { -// System.err.println("An error occurred while creating .env file."); -// e.printStackTrace(); -// } + private static String envChecker() { + String githubActions = System.getenv("GITHUB_ACTIONS"); + if (githubActions != null && githubActions.equals("true")) { + System.out.println("Tests are running in GitHub Actions environment."); + String mySecretKey = System.getenv("API_KEY"); + System.out.println("My Secret Key: " + mySecretKey); + return "GitHub"; + } else { + System.out.println("Tests are running in a local environment."); + return "local"; } - return env; } +// public static Dotenv getEnv() { +// String currentDirectory = System.getProperty("user.dir"); +// File envFile = new File(currentDirectory, "env"); +// env = Dotenv.configure() +// .directory("src/test/resources") +// .filename("env") // instead of '.env', use 'env' +// .load(); +// try { +// env = Dotenv.load(); +// } catch (DotenvException ex) { +// System.out.println("Could not load from local .env"); +//// File envFile = new File(currentDirectory, ".env"); +//// try { +//// // Create .env file in the current directory +//// envFile.createNewFile(); +//// } catch (IOException e) { +//// System.err.println("An error occurred while creating .env file."); +//// e.printStackTrace(); +//// } +// } +// return env; +// } - public final static String pwd = (env.get("PWD") != null) ? env.get("PWD") : "contentstack-java"; - public final static String HOST = (env.get("HOST") != null) ? env.get("HOST") : "cdn.contentstack.io"; - public final static String API_KEY = (env.get("API_KEY") != null) ? env.get("API_KEY") : "blt12c8ad610ff4ddc2"; - public final static String DELIVERY_TOKEN = (env.get("DELIVERY_TOKEN") != null) ? env.get("DELIVERY_TOKEN") : "cs9c1afdffa298f8708e3459e4"; - public final static String ENVIRONMENT = (env.get("ENVIRONMENT") != null) ? env.get("ENVIRONMENT") : "env1"; - public final static String CONTENT_TYPE = (env.get("contentType") != null) ? env.get("contentType") : "product"; - public final static String ENTRY_UID = (env.get("assetUid") != null) ? env.get("assetUid") : "blt884786476373"; - private static Stack stack; +// public final static String pwd = (env.get("PWD") != null) ? env.get("PWD") : "contentstack-java"; +// public final static String HOST = (env.get("HOST") != null) ? env.get("HOST") : "cdn.contentstack.io"; +// public final static String API_KEY = (env.get("API_KEY") != null) ? env.get("API_KEY") : "blt12c8ad610ff4ddc2"; +// public final static String DELIVERY_TOKEN = (env.get("DELIVERY_TOKEN") != null) ? env.get("DELIVERY_TOKEN") : "cs9c1afdffa298f8708e3459e4"; +// public final static String ENVIRONMENT = (env.get("ENVIRONMENT") != null) ? env.get("ENVIRONMENT") : "env1"; +// public final static String CONTENT_TYPE = (env.get("contentType") != null) ? env.get("contentType") : "product"; +// public final static String ENTRY_UID = (env.get("assetUid") != null) ? env.get("assetUid") : "blt884786476373"; + + + public final static String HOST = "cdn.contentstack.io"; + public final static String API_KEY = "blt12c8ad610ff4ddc2"; + public final static String DELIVERY_TOKEN = "cs9c1afdffa298f8708e3459e4"; + public final static String ENVIRONMENT = "env1"; + public final static String CONTENT_TYPE = "product"; + public final static String ENTRY_UID = "blt884786476373"; + + private static volatile Stack stack; private Credentials() throws AccessException { - // Private constructor to prevent direct instantiation throw new AccessException("Can not access credential access"); } public static Stack getStack() { - if (stack == null) { + var envCheck = envChecker(); + System.out.println(envCheck); synchronized (Credentials.class) { if (stack == null) { try { diff --git a/src/test/java/com/contentstack/sdk/TestAsset.java b/src/test/java/com/contentstack/sdk/TestAsset.java index 30197a17..0991b583 100644 --- a/src/test/java/com/contentstack/sdk/TestAsset.java +++ b/src/test/java/com/contentstack/sdk/TestAsset.java @@ -12,12 +12,25 @@ class TestAsset { private final Logger logger = Logger.getLogger(TestAsset.class.getName()); private String assetUid; - private Stack stack = Credentials.getStack(); + private final Stack stack = Credentials.getStack(); + private String envChecker() { + String githubActions = System.getenv("GITHUB_ACTIONS"); + if (githubActions != null && githubActions.equals("true")) { + System.out.println("Tests are running in GitHub Actions environment."); + String mySecretKey = System.getenv("API_KEY"); + System.out.println("My Secret Key: " + mySecretKey); + return "GitHub"; + } else { + System.out.println("Tests are running in a local environment."); + return "local"; + } + } @Test @Order(1) void testNewAssetLibrary() { + envChecker(); AssetLibrary assets = stack.assetLibrary(); assets.fetchAll(new FetchAssetsCallback() { @Override From 5cb11d6d112133b7c10ec7645f0d1841b85c01b7 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 11:19:12 +0530 Subject: [PATCH 062/104] run ci --- .github/workflows/maven-publish.yml | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 17cb45e8..91c37f88 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -11,10 +11,14 @@ jobs: packages: write steps: - uses: actions/checkout@v3 + - name: Import GPG Key + run: | + echo "$GPG_PRIVATE_KEY" | gpg --import + echo "$GPG_PASSPHRASE" | gpg --batch --yes --passphrase-fd 0 --pinentry-mode loopback --edit-key KEY_ID trust - name: Set up Maven Central Repository uses: actions/setup-java@v3 with: - java-version: '8' + java-version: '11' distribution: 'adopt' server-id: ossrh server-username: ${{ secrets.OSSRH_USERNAME }} @@ -29,7 +33,7 @@ jobs: - name: Set up Java for publishing to GitHub Packages uses: actions/setup-java@v3 with: - java-version: '8' + java-version: '11' distribution: 'adopt' server-id: github - name: Publish to GitHub Packages From b8d0a866e24e87ccc17bd1112a9349de4fe19de5 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 11:34:16 +0530 Subject: [PATCH 063/104] run ci --- .github/workflows/maven-publish.yml | 2 ++ pom.xml | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 91c37f88..06287184 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -15,6 +15,8 @@ jobs: run: | echo "$GPG_PRIVATE_KEY" | gpg --import echo "$GPG_PASSPHRASE" | gpg --batch --yes --passphrase-fd 0 --pinentry-mode loopback --edit-key KEY_ID trust + - name: Set GPG_TTY + run: echo "GPG_TTY=$(tty)" >> $GITHUB_ENV - name: Set up Maven Central Repository uses: actions/setup-java@v3 with: diff --git a/pom.xml b/pom.xml index 4ec1d93a..e80dc7f5 100644 --- a/pom.xml +++ b/pom.xml @@ -240,7 +240,7 @@ org.apache.maven.plugins maven-gpg-plugin - 1.5 + 1.6 sign-artifacts From 2f0f3c9388e1f0f42738a05339a9648af0c9653d Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 11:39:07 +0530 Subject: [PATCH 064/104] run ci --- .github/workflows/maven-publish.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 06287184..3e12c780 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -25,6 +25,7 @@ jobs: server-id: ossrh server-username: ${{ secrets.OSSRH_USERNAME }} server-password: ${{ secrets.OSSRH_TOKEN }} + gpg-private-key: ${{ secrets.GPG_PRIVATE_KEY }} gpg-passphrase: ${{ secrets.GPG_PASSPHRASE }} - name: Publish package run: mvn --batch-mode deploy From c257e970b82dc16dd4514949a2ba9dd1eac58ace Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 11:40:06 +0530 Subject: [PATCH 065/104] run ci --- .github/workflows/maven-publish.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 3e12c780..2a30a1d1 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -11,10 +11,10 @@ jobs: packages: write steps: - uses: actions/checkout@v3 - - name: Import GPG Key - run: | - echo "$GPG_PRIVATE_KEY" | gpg --import - echo "$GPG_PASSPHRASE" | gpg --batch --yes --passphrase-fd 0 --pinentry-mode loopback --edit-key KEY_ID trust +# - name: Import GPG Key +# run: | +# echo "$GPG_PRIVATE_KEY" | gpg --import +# echo "$GPG_PASSPHRASE" | gpg --batch --yes --passphrase-fd 0 --pinentry-mode loopback --edit-key KEY_ID trust - name: Set GPG_TTY run: echo "GPG_TTY=$(tty)" >> $GITHUB_ENV - name: Set up Maven Central Repository From 0082ce98353d8eb55ed1384556020e125d942c2f Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 11:54:53 +0530 Subject: [PATCH 066/104] run ci --- .github/workflows/maven-publish.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 2a30a1d1..3e12c780 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -11,10 +11,10 @@ jobs: packages: write steps: - uses: actions/checkout@v3 -# - name: Import GPG Key -# run: | -# echo "$GPG_PRIVATE_KEY" | gpg --import -# echo "$GPG_PASSPHRASE" | gpg --batch --yes --passphrase-fd 0 --pinentry-mode loopback --edit-key KEY_ID trust + - name: Import GPG Key + run: | + echo "$GPG_PRIVATE_KEY" | gpg --import + echo "$GPG_PASSPHRASE" | gpg --batch --yes --passphrase-fd 0 --pinentry-mode loopback --edit-key KEY_ID trust - name: Set GPG_TTY run: echo "GPG_TTY=$(tty)" >> $GITHUB_ENV - name: Set up Maven Central Repository From 5bfbabe486c22e247b6608a05fd06de076288ef8 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 11:57:04 +0530 Subject: [PATCH 067/104] run ci --- .github/workflows/maven-publish.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 3e12c780..2a30a1d1 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -11,10 +11,10 @@ jobs: packages: write steps: - uses: actions/checkout@v3 - - name: Import GPG Key - run: | - echo "$GPG_PRIVATE_KEY" | gpg --import - echo "$GPG_PASSPHRASE" | gpg --batch --yes --passphrase-fd 0 --pinentry-mode loopback --edit-key KEY_ID trust +# - name: Import GPG Key +# run: | +# echo "$GPG_PRIVATE_KEY" | gpg --import +# echo "$GPG_PASSPHRASE" | gpg --batch --yes --passphrase-fd 0 --pinentry-mode loopback --edit-key KEY_ID trust - name: Set GPG_TTY run: echo "GPG_TTY=$(tty)" >> $GITHUB_ENV - name: Set up Maven Central Repository From d4e611e4c55a39ef6e560370f5f51504bb201e40 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 12:02:04 +0530 Subject: [PATCH 068/104] run ci --- .github/workflows/maven-publish.yml | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 2a30a1d1..b40f437e 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -11,12 +11,11 @@ jobs: packages: write steps: - uses: actions/checkout@v3 -# - name: Import GPG Key -# run: | -# echo "$GPG_PRIVATE_KEY" | gpg --import -# echo "$GPG_PASSPHRASE" | gpg --batch --yes --passphrase-fd 0 --pinentry-mode loopback --edit-key KEY_ID trust - - name: Set GPG_TTY - run: echo "GPG_TTY=$(tty)" >> $GITHUB_ENV + - name: Import private gpg key + run: | + gpg --batch --import <(echo "$GPG_PRIVATE_KEY") + env: + GPG_TTY: $(tty) - name: Set up Maven Central Repository uses: actions/setup-java@v3 with: From b046ecabc6a1888ac54f2ae45e0c9602668c6d8f Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 12:08:40 +0530 Subject: [PATCH 069/104] run ci --- pom.xml | 58 +++++++++++++++++++++++++++++++++++++++++++-------------- 1 file changed, 44 insertions(+), 14 deletions(-) diff --git a/pom.xml b/pom.xml index e80dc7f5..71feeaa1 100644 --- a/pom.xml +++ b/pom.xml @@ -175,6 +175,36 @@ + + + release-sign-artifacts + + + performRelease + true + + + + + + org.apache.maven.plugins + maven-gpg-plugin + ${maven-gpg-plugin.version} + + + sign-artifacts + verify + + sign + + + + + + + + + + + + + + + + + + + + + + org.apache.maven.plugins maven-compiler-plugin From 69e1bf7bdcaea328045e6d179d440099632231e0 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 12:15:01 +0530 Subject: [PATCH 070/104] run ci --- .github/workflows/maven-publish.yml | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index b40f437e..52395518 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -11,11 +11,11 @@ jobs: packages: write steps: - uses: actions/checkout@v3 - - name: Import private gpg key - run: | - gpg --batch --import <(echo "$GPG_PRIVATE_KEY") - env: - GPG_TTY: $(tty) +# - name: Import private gpg key +# run: | +# gpg --batch --import <(echo "$GPG_PRIVATE_KEY") +# env: +# GPG_TTY: $(tty) - name: Set up Maven Central Repository uses: actions/setup-java@v3 with: From ae97d857c9f495b1c006098ad926be6d4c06b94e Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 12:20:39 +0530 Subject: [PATCH 071/104] run ci --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index 71feeaa1..44199d64 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.12.2-SNAPSHOT + 1.12.2 jar contentstack-java Java SDK for Contentstack Content Delivery API From f3ad4a6f7ad22a96633aed39d7cf889a06aaf1eb Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 12:28:23 +0530 Subject: [PATCH 072/104] run ci --- .github/workflows/github-publish.yml | 25 ++++++++++++++++++ .github/workflows/maven-publish.yml | 24 ------------------ pom.xml | 38 +++++++++++++++------------- 3 files changed, 46 insertions(+), 41 deletions(-) create mode 100644 .github/workflows/github-publish.yml diff --git a/.github/workflows/github-publish.yml b/.github/workflows/github-publish.yml new file mode 100644 index 00000000..a42bcdd0 --- /dev/null +++ b/.github/workflows/github-publish.yml @@ -0,0 +1,25 @@ +name: Publish package to the Maven Central Repository +on: [ push ] # Trigger the workflow when a push (commit) event occurs +#on: +# release: +# types: [ created ] +jobs: + publish-maven: + runs-on: ubuntu-latest + permissions: + contents: read + packages: write + steps: + - uses: actions/checkout@v3 + - name: Set up Maven Central Repository + uses: actions/setup-java@v3 + with: + java-version: '11' + distribution: 'adopt' + server-id: ossrh + server-username: ${{ secrets.OSSRH_USERNAME }} + server-password: ${{ secrets.OSSRH_TOKEN }} + gpg-private-key: ${{ secrets.GPG_PRIVATE_KEY }} + gpg-passphrase: ${{ secrets.GPG_PASSPHRASE }} + - name: Publish package + run: mvn --batch-mode deploy diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index 52395518..b32d07d1 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -4,30 +4,6 @@ on: [ push ] # Trigger the workflow when a push (commit) event occurs # release: # types: [ created ] jobs: - publish-maven: - runs-on: ubuntu-latest - permissions: - contents: read - packages: write - steps: - - uses: actions/checkout@v3 -# - name: Import private gpg key -# run: | -# gpg --batch --import <(echo "$GPG_PRIVATE_KEY") -# env: -# GPG_TTY: $(tty) - - name: Set up Maven Central Repository - uses: actions/setup-java@v3 - with: - java-version: '11' - distribution: 'adopt' - server-id: ossrh - server-username: ${{ secrets.OSSRH_USERNAME }} - server-password: ${{ secrets.OSSRH_TOKEN }} - gpg-private-key: ${{ secrets.GPG_PRIVATE_KEY }} - gpg-passphrase: ${{ secrets.GPG_PASSPHRASE }} - - name: Publish package - run: mvn --batch-mode deploy publish-github: runs-on: ubuntu-latest steps: diff --git a/pom.xml b/pom.xml index 44199d64..3dd90338 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.12.2 + 1.12.2-SNAPSHOT jar contentstack-java Java SDK for Contentstack Content Delivery API @@ -86,9 +86,13 @@ + + + + - ossrh - https://oss.sonatype.org/content/repositories/snapshots + github + https://maven.pkg.github.com/contentstack/contentstack-java ossrh @@ -267,20 +271,20 @@ maven-enforcer-plugin 3.0.0-M2 - - - - - - - - - - - - - - + + + + + + + + + + + + + + org.apache.maven.plugins maven-compiler-plugin From 02d6fa62f816c0792aa4d8a277e0e247458151f1 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:22:09 +0530 Subject: [PATCH 073/104] run ci --- .github/workflows/github-publish.yml | 4 +++- pom.xml | 23 +++++++++++++++-------- 2 files changed, 18 insertions(+), 9 deletions(-) diff --git a/.github/workflows/github-publish.yml b/.github/workflows/github-publish.yml index a42bcdd0..7a777bed 100644 --- a/.github/workflows/github-publish.yml +++ b/.github/workflows/github-publish.yml @@ -22,4 +22,6 @@ jobs: gpg-private-key: ${{ secrets.GPG_PRIVATE_KEY }} gpg-passphrase: ${{ secrets.GPG_PASSPHRASE }} - name: Publish package - run: mvn --batch-mode deploy + run: mvn clean deploy -DaltDeploymentRepository=github::default::https://maven.pkg.github.com/contentstack/contentstack-java + +# run: mvn --batch-mode deploy diff --git a/pom.xml b/pom.xml index 3dd90338..361dc5fa 100644 --- a/pom.xml +++ b/pom.xml @@ -86,18 +86,25 @@ - - - - + + - github - https://maven.pkg.github.com/contentstack/contentstack-java + ossrh + https://oss.sonatype.org/content/repositories/snapshots + + - ossrh - https://oss.sonatype.org/service/local/staging/deploy/maven2/ + github + https://maven.pkg.github.com/contentstack/contentstack-java + + + + + + + From 1d5e995e84fdb446298c0a2b7817fccd1b8be3bc Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:23:25 +0530 Subject: [PATCH 074/104] run ci --- .github/workflows/github-publish.yml | 8 ++++---- .github/workflows/maven-publish.yml | 8 ++++---- pom.xml | 16 ++++++++-------- 3 files changed, 16 insertions(+), 16 deletions(-) diff --git a/.github/workflows/github-publish.yml b/.github/workflows/github-publish.yml index 7a777bed..62de10d7 100644 --- a/.github/workflows/github-publish.yml +++ b/.github/workflows/github-publish.yml @@ -1,8 +1,8 @@ name: Publish package to the Maven Central Repository -on: [ push ] # Trigger the workflow when a push (commit) event occurs -#on: -# release: -# types: [ created ] +#on: [ push ] # Trigger the workflow when a push (commit) event occurs +on: + release: + types: [ created ] jobs: publish-maven: runs-on: ubuntu-latest diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/maven-publish.yml index b32d07d1..628855d7 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/maven-publish.yml @@ -1,8 +1,8 @@ name: Publish package to the Maven Central Repository -on: [ push ] # Trigger the workflow when a push (commit) event occurs -#on: -# release: -# types: [ created ] +#on: [ push ] # Trigger the workflow when a push (commit) event occurs +on: + release: + types: [ created ] jobs: publish-github: runs-on: ubuntu-latest diff --git a/pom.xml b/pom.xml index 361dc5fa..473597d5 100644 --- a/pom.xml +++ b/pom.xml @@ -94,17 +94,17 @@ - - github - https://maven.pkg.github.com/contentstack/contentstack-java - - - - - + + + + + ossrh + https://oss.sonatype.org/service/local/staging/deploy/maven2/ + + From a7eb3bb7e8dc539b742b34861b86ef577ec8519f Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:24:22 +0530 Subject: [PATCH 075/104] run ci --- pom.xml | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/pom.xml b/pom.xml index 473597d5..a078a495 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.12.2-SNAPSHOT + 1.12.2 jar contentstack-java Java SDK for Contentstack Content Delivery API @@ -93,18 +93,18 @@ https://oss.sonatype.org/content/repositories/snapshots - - - - - - - + - ossrh - https://oss.sonatype.org/service/local/staging/deploy/maven2/ + github + https://maven.pkg.github.com/contentstack/contentstack-java + + + + + + From 0c0f1290c321e670b3832ac931d67c307b4eff6f Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:26:58 +0530 Subject: [PATCH 076/104] run ci --- .github/workflows/github-publish.yml | 10 +++++----- pom.xml | 18 +++++++++--------- 2 files changed, 14 insertions(+), 14 deletions(-) diff --git a/.github/workflows/github-publish.yml b/.github/workflows/github-publish.yml index 62de10d7..77caec1c 100644 --- a/.github/workflows/github-publish.yml +++ b/.github/workflows/github-publish.yml @@ -1,8 +1,8 @@ -name: Publish package to the Maven Central Repository -#on: [ push ] # Trigger the workflow when a push (commit) event occurs -on: - release: - types: [ created ] +name: Publish package to the Github Repository +on: [ push ] # Trigger the workflow when a push (commit) event occurs +#on: +# release: +# types: [ created ] jobs: publish-maven: runs-on: ubuntu-latest diff --git a/pom.xml b/pom.xml index a078a495..156e9d71 100644 --- a/pom.xml +++ b/pom.xml @@ -94,17 +94,17 @@ - - github - https://maven.pkg.github.com/contentstack/contentstack-java - - - - - - + + + + + + ossrh + https://oss.sonatype.org/service/local/staging/deploy/maven2/ + + From 917854b190125c0dc7afc86b7d813c6deb470b59 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:28:16 +0530 Subject: [PATCH 077/104] run ci --- pom.xml | 12 ++-- src/main/java/com/contentstack/sdk/Asset.java | 57 ++++++++----------- .../com/contentstack/sdk/AssetLibrary.java | 18 ++---- .../java/com/contentstack/sdk/AssetModel.java | 6 +- 4 files changed, 39 insertions(+), 54 deletions(-) diff --git a/pom.xml b/pom.xml index 156e9d71..3802ee0a 100644 --- a/pom.xml +++ b/pom.xml @@ -94,16 +94,16 @@ - + - - - ossrh - https://oss.sonatype.org/service/local/staging/deploy/maven2/ - + + + ossrh + https://oss.sonatype.org/service/local/staging/deploy/maven2/ + diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index e5991d54..9352224b 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -57,8 +57,7 @@ protected void setStackInstance(@NotNull Stack stack) { /** * Configure asset. * - * @param jsonObject - * the json object + * @param jsonObject the json object * @return the asset */ public Asset configure(JSONObject jsonObject) { @@ -77,19 +76,17 @@ public Asset configure(JSONObject jsonObject) { /** * Sets header. * - * @param headerKey - * the header key - * @param headerValue - * the header value - * - *
- *
- * Example :
- *

- * - * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = - * stack.asset(asset_uid); asset.setHeader(); - * + * @param headerKey the header key + * @param headerValue the header value + * + *
+ *
+ * Example :
+ *

+ * + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = + * stack.asset(asset_uid); asset.setHeader(); + * */ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { headers.put(headerKey, headerValue); @@ -98,17 +95,16 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { /** * Remove header. * - * @param headerKey - * the header key - * - *
- *
- * Example : - *

- * - * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = - * stack.asset(asset_uid); asset.removeHeader(); - * + * @param headerKey the header key + * + *
+ *
+ * Example : + *

+ * + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = + * stack.asset(asset_uid); asset.removeHeader(); + * */ public void removeHeader(@NotNull String headerKey) { headers.remove(headerKey); @@ -457,10 +453,8 @@ public Asset includeDimension() { /** * Add param asset. * - * @param paramKey - * the param key - * @param paramValue - * the param value + * @param paramKey the param key + * @param paramValue the param value * @return the asset * *
@@ -538,8 +532,7 @@ public Asset includeMetadata() { /** * Fetch. * - * @param callback - * the callback + * @param callback the callback */ public void fetch(FetchResultCallback callback) { urlQueries.put(ENVIRONMENT, this.headers.get(ENVIRONMENT)); diff --git a/src/main/java/com/contentstack/sdk/AssetLibrary.java b/src/main/java/com/contentstack/sdk/AssetLibrary.java index 8401a568..5bb86ba8 100644 --- a/src/main/java/com/contentstack/sdk/AssetLibrary.java +++ b/src/main/java/com/contentstack/sdk/AssetLibrary.java @@ -34,10 +34,8 @@ protected void setStackInstance(@NotNull Stack stack) { /** * Sets header. * - * @param headerKey - * the header key - * @param headerValue - * the header value + * @param headerKey the header key + * @param headerValue the header value */ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { this.headers.put(headerKey, headerValue); @@ -46,8 +44,7 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { /** * Remove header. * - * @param headerKey - * the header key + * @param headerKey the header key */ public void removeHeader(@NotNull String headerKey) { if (!headerKey.isEmpty()) { @@ -58,10 +55,8 @@ public void removeHeader(@NotNull String headerKey) { /** * Sort asset library. * - * @param keyOrderBy - * the key order by - * @param orderby - * the orderby + * @param keyOrderBy the key order by + * @param orderby the orderby * @return the asset library */ public AssetLibrary sort(String keyOrderBy, ORDERBY orderby) { @@ -141,8 +136,7 @@ public int getCount() { /** * Fetch all. * - * @param callback - * the callback + * @param callback the callback */ public void fetchAll(FetchAssetsCallback callback) { this.callback = callback; diff --git a/src/main/java/com/contentstack/sdk/AssetModel.java b/src/main/java/com/contentstack/sdk/AssetModel.java index c0d84f08..15c4ffb3 100644 --- a/src/main/java/com/contentstack/sdk/AssetModel.java +++ b/src/main/java/com/contentstack/sdk/AssetModel.java @@ -21,10 +21,8 @@ class AssetModel { /** * Instantiates a new Asset model. * - * @param response - * the response - * @param isArray - * the is array + * @param response the response + * @param isArray the is array */ public AssetModel(JSONObject response, boolean isArray) { From 56ca186991c1e26b89b21ad20d066983b9b04f9a Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:33:03 +0530 Subject: [PATCH 078/104] GitHub Package Release --- ...en-publish.yml => github-package-publish.yml} | 10 +++++----- ...ub-publish.yml => maven--package-publish.yml} | 10 +++++----- pom.xml | 16 ++++++++-------- 3 files changed, 18 insertions(+), 18 deletions(-) rename .github/workflows/{maven-publish.yml => github-package-publish.yml} (72%) rename .github/workflows/{github-publish.yml => maven--package-publish.yml} (82%) diff --git a/.github/workflows/maven-publish.yml b/.github/workflows/github-package-publish.yml similarity index 72% rename from .github/workflows/maven-publish.yml rename to .github/workflows/github-package-publish.yml index 628855d7..80ac5cb1 100644 --- a/.github/workflows/maven-publish.yml +++ b/.github/workflows/github-package-publish.yml @@ -1,8 +1,8 @@ -name: Publish package to the Maven Central Repository -#on: [ push ] # Trigger the workflow when a push (commit) event occurs -on: - release: - types: [ created ] +name: Publishing to GitHub Packages +on: [ push ] # Trigger the workflow when a push (commit) event occurs +#on: +# release: +# types: [ created ] jobs: publish-github: runs-on: ubuntu-latest diff --git a/.github/workflows/github-publish.yml b/.github/workflows/maven--package-publish.yml similarity index 82% rename from .github/workflows/github-publish.yml rename to .github/workflows/maven--package-publish.yml index 77caec1c..396debad 100644 --- a/.github/workflows/github-publish.yml +++ b/.github/workflows/maven--package-publish.yml @@ -1,8 +1,8 @@ -name: Publish package to the Github Repository -on: [ push ] # Trigger the workflow when a push (commit) event occurs -#on: -# release: -# types: [ created ] +name: Publishing to Maven Packages +#on: [ push ] # Trigger the workflow when a push (commit) event occurs +on: + release: + types: [ created ] jobs: publish-maven: runs-on: ubuntu-latest diff --git a/pom.xml b/pom.xml index 3802ee0a..6975fb8b 100644 --- a/pom.xml +++ b/pom.xml @@ -94,17 +94,17 @@ - - - - - - - ossrh - https://oss.sonatype.org/service/local/staging/deploy/maven2/ + github + https://maven.pkg.github.com/contentstack/contentstack-java + + + + + + From 801ac632997adc6706f1528c544af5b2ad9cfbdc Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:36:19 +0530 Subject: [PATCH 079/104] GitHub Package Release --- .github/workflows/github-package-publish.yml | 2 +- .github/workflows/maven--package-publish.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/github-package-publish.yml b/.github/workflows/github-package-publish.yml index 80ac5cb1..d630e242 100644 --- a/.github/workflows/github-package-publish.yml +++ b/.github/workflows/github-package-publish.yml @@ -15,6 +15,6 @@ jobs: distribution: 'adopt' server-id: github - name: Publish to GitHub Packages - run: mvn --batch-mode deploy + run: mvn clean deploy -DaltDeploymentRepository=github::default::https://maven.pkg.github.com/contentstack/contentstack-java env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} \ No newline at end of file diff --git a/.github/workflows/maven--package-publish.yml b/.github/workflows/maven--package-publish.yml index 396debad..f7f37c44 100644 --- a/.github/workflows/maven--package-publish.yml +++ b/.github/workflows/maven--package-publish.yml @@ -22,6 +22,6 @@ jobs: gpg-private-key: ${{ secrets.GPG_PRIVATE_KEY }} gpg-passphrase: ${{ secrets.GPG_PASSPHRASE }} - name: Publish package - run: mvn clean deploy -DaltDeploymentRepository=github::default::https://maven.pkg.github.com/contentstack/contentstack-java + run: mvn clean deploy # run: mvn --batch-mode deploy From 32e3ea8ba2a5b19a14e9749b0393e15ba5a04a0f Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:40:16 +0530 Subject: [PATCH 080/104] GitHub Package Release --- .github/workflows/github-package-publish.yml | 2 +- pom.xml | 12 ++++++------ 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/.github/workflows/github-package-publish.yml b/.github/workflows/github-package-publish.yml index d630e242..80ac5cb1 100644 --- a/.github/workflows/github-package-publish.yml +++ b/.github/workflows/github-package-publish.yml @@ -15,6 +15,6 @@ jobs: distribution: 'adopt' server-id: github - name: Publish to GitHub Packages - run: mvn clean deploy -DaltDeploymentRepository=github::default::https://maven.pkg.github.com/contentstack/contentstack-java + run: mvn --batch-mode deploy env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} \ No newline at end of file diff --git a/pom.xml b/pom.xml index 6975fb8b..74eb46fd 100644 --- a/pom.xml +++ b/pom.xml @@ -93,17 +93,17 @@ https://oss.sonatype.org/content/repositories/snapshots - + github https://maven.pkg.github.com/contentstack/contentstack-java - - - - - + + + + + From 20b66511e7512a3a2210738ce73b807f16ff4f86 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:50:27 +0530 Subject: [PATCH 081/104] GitHub Package Release --- pom.xml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pom.xml b/pom.xml index 74eb46fd..454a33e2 100644 --- a/pom.xml +++ b/pom.xml @@ -313,8 +313,8 @@ ${nexus-staging-maven-plugin.version} true - ossrh - https://oss.sonatype.org/ + github + https://maven.pkg.github.com/contentstack/contentstack-java true From 369b2f1434f68f35043e7827237849f5d0962c3d Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:57:52 +0530 Subject: [PATCH 082/104] GitHub Package Release --- .../com/contentstack/sdk/Credentials.java | 70 +++++++++---------- 1 file changed, 33 insertions(+), 37 deletions(-) diff --git a/src/test/java/com/contentstack/sdk/Credentials.java b/src/test/java/com/contentstack/sdk/Credentials.java index d1b9a99b..9b5bb2c5 100644 --- a/src/test/java/com/contentstack/sdk/Credentials.java +++ b/src/test/java/com/contentstack/sdk/Credentials.java @@ -1,11 +1,14 @@ package com.contentstack.sdk; +import io.github.cdimascio.dotenv.Dotenv; +import io.github.cdimascio.dotenv.DotenvException; import lombok.var; +import java.io.File; import java.rmi.AccessException; public class Credentials { - //static Dotenv env = getEnv(); + static Dotenv env = getEnv(); private static String envChecker() { String githubActions = System.getenv("GITHUB_ACTIONS"); @@ -20,45 +23,38 @@ private static String envChecker() { } } -// public static Dotenv getEnv() { -// String currentDirectory = System.getProperty("user.dir"); -// File envFile = new File(currentDirectory, "env"); -// env = Dotenv.configure() -// .directory("src/test/resources") -// .filename("env") // instead of '.env', use 'env' -// .load(); -// try { -// env = Dotenv.load(); -// } catch (DotenvException ex) { -// System.out.println("Could not load from local .env"); -//// File envFile = new File(currentDirectory, ".env"); -//// try { -//// // Create .env file in the current directory -//// envFile.createNewFile(); -//// } catch (IOException e) { -//// System.err.println("An error occurred while creating .env file."); -//// e.printStackTrace(); -//// } -// } -// return env; -// } - + public static Dotenv getEnv() { + String currentDirectory = System.getProperty("user.dir"); + File envFile = new File(currentDirectory, "env"); + env = Dotenv.configure() + .directory("src/test/resources") + .filename("env") // instead of '.env', use 'env' + .load(); + try { + env = Dotenv.load(); + } catch (DotenvException ex) { + System.out.println("Could not load from local .env"); +// File envFile = new File(currentDirectory, ".env"); +// try { +// // Create .env file in the current directory +// envFile.createNewFile(); +// } catch (IOException e) { +// System.err.println("An error occurred while creating .env file."); +// e.printStackTrace(); +// } + } + return env; + } -// public final static String pwd = (env.get("PWD") != null) ? env.get("PWD") : "contentstack-java"; -// public final static String HOST = (env.get("HOST") != null) ? env.get("HOST") : "cdn.contentstack.io"; -// public final static String API_KEY = (env.get("API_KEY") != null) ? env.get("API_KEY") : "blt12c8ad610ff4ddc2"; -// public final static String DELIVERY_TOKEN = (env.get("DELIVERY_TOKEN") != null) ? env.get("DELIVERY_TOKEN") : "cs9c1afdffa298f8708e3459e4"; -// public final static String ENVIRONMENT = (env.get("ENVIRONMENT") != null) ? env.get("ENVIRONMENT") : "env1"; -// public final static String CONTENT_TYPE = (env.get("contentType") != null) ? env.get("contentType") : "product"; -// public final static String ENTRY_UID = (env.get("assetUid") != null) ? env.get("assetUid") : "blt884786476373"; + public final static String pwd = (env.get("PWD") != null) ? env.get("PWD") : "contentstack-java"; + public final static String HOST = (env.get("HOST") != null) ? env.get("HOST") : "cdn.contentstack.io"; + public final static String API_KEY = (env.get("API_KEY") != null) ? env.get("API_KEY") : ""; + public final static String DELIVERY_TOKEN = (env.get("DELIVERY_TOKEN") != null) ? env.get("DELIVERY_TOKEN") : ""; + public final static String ENVIRONMENT = (env.get("ENVIRONMENT") != null) ? env.get("ENVIRONMENT") : "env1"; + public final static String CONTENT_TYPE = (env.get("contentType") != null) ? env.get("contentType") : "product"; + public final static String ENTRY_UID = (env.get("assetUid") != null) ? env.get("assetUid") : ""; - public final static String HOST = "cdn.contentstack.io"; - public final static String API_KEY = "blt12c8ad610ff4ddc2"; - public final static String DELIVERY_TOKEN = "cs9c1afdffa298f8708e3459e4"; - public final static String ENVIRONMENT = "env1"; - public final static String CONTENT_TYPE = "product"; - public final static String ENTRY_UID = "blt884786476373"; private static volatile Stack stack; From 87fa40c527ba8cca9602c7f84010f2cc514317ef Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 10 Aug 2023 13:59:58 +0530 Subject: [PATCH 083/104] GitHub Package Release --- .github/workflows/github-package-publish.yml | 8 ++++---- pom.xml | 16 ++++++++-------- 2 files changed, 12 insertions(+), 12 deletions(-) diff --git a/.github/workflows/github-package-publish.yml b/.github/workflows/github-package-publish.yml index 80ac5cb1..02456b05 100644 --- a/.github/workflows/github-package-publish.yml +++ b/.github/workflows/github-package-publish.yml @@ -1,8 +1,8 @@ name: Publishing to GitHub Packages -on: [ push ] # Trigger the workflow when a push (commit) event occurs -#on: -# release: -# types: [ created ] +#on: [ push ] # Trigger the workflow when a push (commit) event occurs +on: + release: + types: [ created ] jobs: publish-github: runs-on: ubuntu-latest diff --git a/pom.xml b/pom.xml index 454a33e2..c4a942a9 100644 --- a/pom.xml +++ b/pom.xml @@ -94,17 +94,17 @@ - - github - https://maven.pkg.github.com/contentstack/contentstack-java - - - - - + + + + + ossrh + https://oss.sonatype.org/service/local/staging/deploy/maven2/ + + From 51c2765ea6940ffec97181152b7d00ad633346c3 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 17 Aug 2023 20:11:49 +0530 Subject: [PATCH 084/104] tests fixed --- src/test/java/com/contentstack/sdk/TestEntry.java | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/test/java/com/contentstack/sdk/TestEntry.java b/src/test/java/com/contentstack/sdk/TestEntry.java index 7dfc7d5e..3cd0f4ff 100644 --- a/src/test/java/com/contentstack/sdk/TestEntry.java +++ b/src/test/java/com/contentstack/sdk/TestEntry.java @@ -356,7 +356,7 @@ void entryGetAsset() { @Test @Order(42) void entryExcept() { - String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; + String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; Entry initEntry = stack.contentType("product").entry(entryUid).except(arrField); Assertions.assertEquals(3, initEntry.exceptFieldArray.length()); logger.info("passed..."); @@ -374,7 +374,7 @@ void entryIncludeReference() { @Test @Order(44) void entryIncludeReferenceList() { - String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; + String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; Entry initEntry = stack.contentType("product").entry(entryUid).includeReference(arrField); Assertions.assertEquals(3, initEntry.referenceArray.length()); Assertions.assertTrue(initEntry.params.has("include[]")); @@ -384,7 +384,7 @@ void entryIncludeReferenceList() { @Test @Order(45) void entryOnlyList() { - String[] arrField = {"fieldOne", "fieldTwo", "fieldThree"}; + String[] arrField = { "fieldOne", "fieldTwo", "fieldThree" }; Entry initEntry = stack.contentType("product").entry(entryUid); initEntry.only(arrField); Assertions.assertEquals(3, initEntry.objectUidForOnly.length()); @@ -503,7 +503,8 @@ void testEntryIncludeOwner() { void testEntryPassConfigBranchIncludeBranch() throws IllegalAccessException { Config config = new Config(); config.setBranch("feature_branch"); - Stack branchStack = Contentstack.stack(Credentials.API_KEY, Credentials.DELIVERY_TOKEN, Credentials.ENVIRONMENT, config); + Stack branchStack = Contentstack.stack(Credentials.API_KEY, Credentials.DELIVERY_TOKEN, Credentials.ENVIRONMENT, + config); Entry entry = branchStack.contentType("product").entry(entryUid); entry.includeBranch().fetch(new EntryResultCallBack() { @Override From 7e04b9f783ef8ac50af155702a438f2bbf9b13d1 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 18 Aug 2023 17:07:21 +0530 Subject: [PATCH 085/104] asset docs updated --- src/main/java/com/contentstack/sdk/Asset.java | 181 ++++++++++-------- 1 file changed, 96 insertions(+), 85 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/Asset.java b/src/main/java/com/contentstack/sdk/Asset.java index 9352224b..a03f63a2 100644 --- a/src/main/java/com/contentstack/sdk/Asset.java +++ b/src/main/java/com/contentstack/sdk/Asset.java @@ -14,11 +14,15 @@ import static com.contentstack.sdk.Constants.parseDate; /** - * Assets refer to - * all the media files (images, videos, PDFs, audio files, and so on) uploaded in your Contentstack repository for + * Assets + * refer to + * all the media files (images, videos, PDFs, audio files, and so on) uploaded + * in your Contentstack repository for * future use. These files can be attached and used in multiple entries. *

- * You can now pass the branch header in the API request to fetch or manage modules located within specific branches of + * You can now pass the branch header in the API request to fetch or manage + * modules located within specific branches of * the stack. * * @author Shailesh Mishra @@ -93,16 +97,18 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { } /** - * Remove header. - * - * @param headerKey the header key - * - *
+ * The function removes a header from a collection of headers based on a given + * key. + * + * @param headerKey The parameter "headerKey" is a String that represents the + * key of the header to + * be removed. *
* Example : *

* - * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = + * Stack stack = Contentstack.stack("apiKey", "deliveryToken", + * "environment"); Asset asset = * stack.asset(asset_uid); asset.removeHeader(); * */ @@ -121,11 +127,11 @@ protected void setUid(@NotNull String assetUid) { * * @return the asset uid * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - * + * * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = stack.asset(asset_uid); * asset.fetch(new FetchResultCallback() { @Override public void onCompletion(ResponseType responseType, Error * error) { asset.getAssetUid(); } }); @@ -141,15 +147,20 @@ public String getAssetUid() { * * @return the file type * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *

-     * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = stack.asset(asset_uid);
-     * asset.fetch(new FetchResultCallback() { @Override public void onCompletion(ResponseType responseType, Error
-     * error) { asset.getFileType(); } });
-     * 
+ *
+     *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
+     *         Asset asset = stack.asset(asset_uid);
+     *         asset.fetch(new FetchResultCallback() {
+     *             @Override
+     *             public void onCompletion(ResponseType responseType, Error error) {
+     *                 asset.getFileType();
+     *             }
+     *         });
+     *         
*/ public String getFileType() { return contentType; @@ -160,11 +171,11 @@ public String getFileType() { * * @return the file size * - *
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -185,11 +196,11 @@ public String getFileSize() {
      *
      * @return the file name
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -210,11 +221,11 @@ public String getFileName() {
      *
      * @return the url
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -235,11 +246,11 @@ public String getUrl() {
      *
      * @return the json object
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -259,10 +270,10 @@ public JSONObject toJSON() {
      * Gets create at.
      *
      * @return the create at
-     * 
- * Example :
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -283,11 +294,11 @@ public Calendar getCreateAt() {
      *
      * @return the created by
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -308,11 +319,11 @@ public String getCreatedBy() {
      *
      * @return the update at
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -332,11 +343,11 @@ public Calendar getUpdateAt() {
      * Gets updated by.
      *
      * @return the updated by
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -357,11 +368,11 @@ public String getUpdatedBy() {
      *
      * @return the delete at
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -382,11 +393,11 @@ public Calendar getDeleteAt() {
      *
      * @return the deleted by
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -405,11 +416,11 @@ public String getDeletedBy() {
      * Get tags string [ ].
      *
      * @return the string [ ]
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.fetch(new FetchResultCallback() {
@@ -435,11 +446,11 @@ protected Asset setTags(String[] tags) {
      *
      * @return the asset
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.includeDimension();
@@ -457,11 +468,11 @@ public Asset includeDimension() {
      * @param paramValue the param value
      * @return the asset
      *
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.addParam();
@@ -476,11 +487,11 @@ public Asset addParam(@NotNull String paramKey, @NotNull String paramValue) {
      * Include fallback asset.
      *
      * @return the asset
-     * 
- *
- * Example :
+ *
+ *
+ * Example :
* - *
+     *         
      *         Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment");
      *         Asset asset = stack.asset(asset_uid);
      *         asset.includeFallback();
@@ -496,11 +507,11 @@ public Asset includeFallback() {
      *
      * @return {@link Asset} object, so you can chain this call. 
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - * + * * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = stack.asset(asset_uid); * asset.includeBranch(); * @@ -515,11 +526,11 @@ public Asset includeBranch() { * * @return {@link Asset} object, so you can chain this call.
* - *
- *
- * Example :
+ *
+ *
+ * Example :
* - * + * * Stack stack = Contentstack.stack("apiKey", "deliveryToken", "environment"); Asset asset = stack.asset(asset_uid); * asset.includeMetadata(); * @@ -540,7 +551,7 @@ public void fetch(FetchResultCallback callback) { } private void fetchFromNetwork(String url, JSONObject urlQueries, LinkedHashMap headers, - FetchResultCallback callback) { + FetchResultCallback callback) { if (callback != null) { HashMap urlParams = getUrlParams(urlQueries); new CSBackgroundTask(this, stackInstance, Constants.FETCHASSETS, url, headers, urlParams, From d5f9bd4ea35ca00c9d4baf0902ce2e38da99ab25 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 18 Aug 2023 18:49:38 +0530 Subject: [PATCH 086/104] updated pom.xml --- pom.xml | 96 +++++++++++++++++++++++---------------------------------- 1 file changed, 38 insertions(+), 58 deletions(-) diff --git a/pom.xml b/pom.xml index c4a942a9..34fe8a67 100644 --- a/pom.xml +++ b/pom.xml @@ -54,19 +54,19 @@ GitHub Issues - http://github.com/contentstack/contentstack-java/issues + https://github.com/contentstack/contentstack-java/issues MIT - http://www.opensource.org/licenses/mit-license.php + https://www.opensource.org/licenses/mit-license.php - Contentstack. - http://contentstack.com + Contentstack + https://contentstack.com @@ -94,12 +94,11 @@ - - - - - - + + + + + ossrh https://oss.sonatype.org/service/local/staging/deploy/maven2/ @@ -127,7 +126,7 @@ io.github.cdimascio dotenv-java ${dotenv-source.version} - + @@ -185,38 +184,9 @@ + - - - release-sign-artifacts - - - performRelease - true - - - - - - org.apache.maven.plugins - maven-gpg-plugin - ${maven-gpg-plugin.version} - - - sign-artifacts - verify - - sign - - - - - - - - - - + org.apache.maven.plugins maven-javadoc-plugin @@ -260,14 +230,24 @@ false 1.8 - http://docs.oracle.com/javase/7/docs/api/ - http://docs.oracle.com/javase/7/docs/api/ + https://docs.oracle.com/javase/7/docs/api/ + https://docs.oracle.com/javase/7/docs/api/ none + + + org.apache.maven.plugins + maven-surefire-plugin + 2.22.2 + + true + + + org.apache.maven.plugins maven-site-plugin @@ -278,20 +258,20 @@ maven-enforcer-plugin 3.0.0-M2 - - - - - - - - - - - - - - + + org.apache.maven.plugins + maven-gpg-plugin + 1.6 + + + sign-artifacts + verify + + sign + + + + org.apache.maven.plugins maven-compiler-plugin From 5f38c5c0499b389fb35da5230990d0c2d821cc5f Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 18 Aug 2023 19:56:04 +0530 Subject: [PATCH 087/104] pom.xml updated --- pom.xml | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/pom.xml b/pom.xml index 34fe8a67..f39935d4 100644 --- a/pom.xml +++ b/pom.xml @@ -87,17 +87,17 @@ - + ossrh https://oss.sonatype.org/content/repositories/snapshots - - - - + + + + ossrh @@ -292,9 +292,14 @@ nexus-staging-maven-plugin ${nexus-staging-maven-plugin.version} true + + + + + - github - https://maven.pkg.github.com/contentstack/contentstack-java + ossrh + https://oss.sonatype.org/ true From 06235dfca1fa9aa04b04f25e2f2db2e54eb5d07a Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Mon, 18 Sep 2023 20:26:33 +0530 Subject: [PATCH 088/104] pom.xml updated to latest --- pom.xml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/pom.xml b/pom.xml index f39935d4..188304c5 100644 --- a/pom.xml +++ b/pom.xml @@ -20,12 +20,12 @@ 2.2.1 3.4.1 3.0.0 - 3.1.6 + 3.1.7 2.9.0 - 4.11.0 + 5.0.0-alpha.11 0.8.5 1.18.28 - 5.9.2 + 5.10.0 5.8.0-M1 2.8.8 1.1.1 @@ -33,7 +33,7 @@ 1.5 3.8.1 1.6.13 - 20230227 + 20230618 0.8.7 2.5.3 1.2.3 From a0b15dc75a72e494d7f5c63eb15061ad7d65ec68 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 27 Sep 2023 23:29:32 +0530 Subject: [PATCH 089/104] Utils SDK Updated to latest version --- CHANGELOG.md | 7 +++++++ pom.xml | 6 +++--- src/main/java/com/contentstack/sdk/Constants.java | 2 +- 3 files changed, 11 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 35b14704..137dc5f2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,12 @@ # CHANGELOG +## v1.12.3 + +### Date: 28-SEP-2023 + +- Updated Latest version of Utils SDK +- Snyk Issues fixed + ## v1.12.2 ### Date: 08-AUG-2023 diff --git a/pom.xml b/pom.xml index 188304c5..15cb186c 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.12.2 + 1.12.3 jar contentstack-java Java SDK for Contentstack Content Delivery API @@ -24,7 +24,7 @@ 2.9.0 5.0.0-alpha.11 0.8.5 - 1.18.28 + 1.18.30 5.10.0 5.8.0-M1 2.8.8 @@ -36,7 +36,7 @@ 20230618 0.8.7 2.5.3 - 1.2.3 + 1.2.4 diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index 5a1c19c7..fcb5fab9 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -21,7 +21,7 @@ public class Constants { private static final Logger logger = Logger.getLogger(Constants.class.getSimpleName()); - protected static final String SDK_VERSION = "1.12.2"; + protected static final String SDK_VERSION = "1.12.3"; protected static final String ENVIRONMENT = "environment"; protected static final String CONTENT_TYPE_UID = "content_type_uid"; protected static final String ENTRY_UID = "entry_uid"; From 3fed846c269fb7137faeff5771dd4b1152825509 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Tue, 3 Oct 2023 11:11:53 +0530 Subject: [PATCH 090/104] Utils SDK Updated to latest version --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index 15cb186c..d326775a 100644 --- a/pom.xml +++ b/pom.xml @@ -20,7 +20,7 @@ 2.2.1 3.4.1 3.0.0 - 3.1.7 + 3.1.8 2.9.0 5.0.0-alpha.11 0.8.5 From 8a1476571096e0db8b58b9734b9d9c956fe8e3a1 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 16 Nov 2023 14:59:21 +0530 Subject: [PATCH 091/104] v1.12.3 Early Access Feature Support --- CHANGELOG.md | 9 ++ pom.xml | 8 +- .../java/com/contentstack/sdk/Config.java | 101 +++++++++--------- .../java/com/contentstack/sdk/Constants.java | 2 +- .../com/contentstack/sdk/Contentstack.java | 41 ++++--- src/main/java/com/contentstack/sdk/Stack.java | 2 +- .../contentstack/sdk/TestContentstack.java | 25 +++++ 7 files changed, 110 insertions(+), 78 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 137dc5f2..f7976ca8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,14 @@ # CHANGELOG +## v1.13.0 + +### Date: 17-Nov-2023 + +- Updated Latest version of Utils SDK to 1.2.6 +- Snyk Issues fixed +- Updated dependencies +- Added support for early access feature + ## v1.12.3 ### Date: 28-SEP-2023 diff --git a/pom.xml b/pom.xml index d326775a..0a0afd80 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 com.contentstack.sdk java - 1.12.3 + 1.13.0 jar contentstack-java Java SDK for Contentstack Content Delivery API @@ -25,7 +25,7 @@ 5.0.0-alpha.11 0.8.5 1.18.30 - 5.10.0 + 5.10.1 5.8.0-M1 2.8.8 1.1.1 @@ -33,10 +33,10 @@ 1.5 3.8.1 1.6.13 - 20230618 + 20231013 0.8.7 2.5.3 - 1.2.4 + 1.2.6 diff --git a/src/main/java/com/contentstack/sdk/Config.java b/src/main/java/com/contentstack/sdk/Config.java index fd736a6d..33a26129 100644 --- a/src/main/java/com/contentstack/sdk/Config.java +++ b/src/main/java/com/contentstack/sdk/Config.java @@ -1,5 +1,7 @@ package com.contentstack.sdk; +import lombok.Getter; +import lombok.Setter; import okhttp3.ConnectionPool; import org.jetbrains.annotations.NotNull; import org.json.JSONObject; @@ -17,6 +19,7 @@ public class Config { protected String livePreviewHash = null; protected String livePreviewContentType = null; protected String livePreviewEntryUid = null; + @Getter protected String host = "cdn.contentstack.io"; protected String version = "v3"; protected String scheme = "https://"; @@ -26,38 +29,36 @@ public class Config { protected JSONObject livePreviewEntry = null; protected ContentstackRegion region = ContentstackRegion.US; protected String managementToken; + @Setter + @Getter protected String branch; + /** + * -- SETTER -- + * Proxy can be set like below. + * + * @param proxy Proxy setting, typically a type (http, socks) and a socket address. A Proxy is an immutable object + *
+ *
+ * Example:
+ *
+ * + * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("proxyHost", "proxyPort")); + * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("sl.theproxyvpn.io", 80)); Config + * config = new Config(); config.setProxy(proxy); + * + */ + @Setter protected Proxy proxy = null; protected ConnectionPool connectionPool = new ConnectionPool(); protected List plugins = null; - public String getBranch() { - return branch; - } - - public void setBranch(String branch) { - this.branch = branch; - } - /** - * Proxy can be set like below. - * - * @param proxy - * Proxy setting, typically a type (http, socks) and a socket address. A Proxy is an immutable object - *
- *
- * Example:
- *
- * - * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("proxyHost", "proxyPort")); - * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("sl.theproxyvpn.io", 80)); Config - * config = new Config(); config.setProxy(proxy); - * + * -- GETTER -- + * The configuration for the contentstack that contains support for */ - public void setProxy(Proxy proxy) { - this.proxy = proxy; - } + @Getter + protected String[] earlyAccess; /** * Returns the Proxy instance @@ -73,12 +74,9 @@ public Proxy getProxy() { * {@link okhttp3.Address} may share a {@link okhttp3.Connection}. This class implements the policy * of which * connections to keep open for future use. * - * @param maxIdleConnections - * the maxIdleConnections default value is 5 - * @param keepAliveDuration - * the keepAliveDuration default value is 5 - * @param timeUnit - * the timeUnit default value is TimeUnit. MINUTES + * @param maxIdleConnections the maxIdleConnections default value is 5 + * @param keepAliveDuration the keepAliveDuration default value is 5 + * @param timeUnit the timeUnit default value is TimeUnit. MINUTES * @return ConnectionPool */ public ConnectionPool connectionPool(int maxIdleConnections, long keepAliveDuration, TimeUnit timeUnit) { @@ -98,8 +96,7 @@ public ContentstackRegion getRegion() { /** * Sets region. * - * @param region - * the region + * @param region the region * @return the region */ public ContentstackRegion setRegion(ContentstackRegion region) { @@ -119,20 +116,10 @@ public void setPlugins(List plugins) { this.plugins = plugins; } - /** - * Gets host. - * - * @return the host - */ - public String getHost() { - return host; - } - /** * Sets host. * - * @param hostName - * the host name + * @param hostName the host name */ public void setHost(String hostName) { if (hostName != null && !hostName.isEmpty()) { @@ -152,8 +139,7 @@ public String getVersion() { /** * Enable live preview config. * - * @param enableLivePreview - * to enable live preview + * @param enableLivePreview to enable live preview * @return the config */ public Config enableLivePreview(boolean enableLivePreview) { @@ -164,8 +150,7 @@ public Config enableLivePreview(boolean enableLivePreview) { /** * Sets live preview host. * - * @param livePreviewHost - * the live preview host + * @param livePreviewHost the live preview host * @return the live preview host */ public Config setLivePreviewHost(@NotNull String livePreviewHost) { @@ -181,8 +166,7 @@ protected Config setLivePreviewEntry(@NotNull JSONObject livePreviewEntry) { /** * Sets management token. * - * @param managementToken - * the management token + * @param managementToken the management token * @return the management token */ public Config setManagementToken(@NotNull String managementToken) { @@ -197,4 +181,23 @@ public enum ContentstackRegion { US, EU, AZURE_NA, AZURE_EU } + + /** + * The configuration for the contentstack that contains support for Early Access Feature + * + * @param earlyAccessFeatures The list of Early Access Features + * {@code + * Config config = new Config(); + * String[] earlyAccess = {"Taxonomy", "Teams", "Terms", "LivePreview"}; + * config.earlyAccess(earlyAccess); + * Stack stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); + *

+ * } + * @return Config + */ + public Config earlyAccess(@NotNull String[] earlyAccessFeatures) { + this.earlyAccess = earlyAccessFeatures; + return this; + } + } diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index fcb5fab9..24917225 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -21,7 +21,7 @@ public class Constants { private static final Logger logger = Logger.getLogger(Constants.class.getSimpleName()); - protected static final String SDK_VERSION = "1.12.3"; + protected static final String SDK_VERSION = "1.13.0"; protected static final String ENVIRONMENT = "environment"; protected static final String CONTENT_TYPE_UID = "content_type_uid"; protected static final String ENTRY_UID = "entry_uid"; diff --git a/src/main/java/com/contentstack/sdk/Contentstack.java b/src/main/java/com/contentstack/sdk/Contentstack.java index aa7fe895..7154df8a 100644 --- a/src/main/java/com/contentstack/sdk/Contentstack.java +++ b/src/main/java/com/contentstack/sdk/Contentstack.java @@ -31,27 +31,23 @@ protected Contentstack() throws IllegalAccessException { * key of your stack.
* Find Your Stack Credentials from Contentstack . * - * @param stackApiKey - * The API Key is a unique key assigned to each stack. - * @param deliveryToken - * The Delivery Token is a read-only credential that you + * @param stackApiKey The API Key is a unique key assigned to each stack. + * @param deliveryToken The Delivery Token is a read-only credential that you * can create for different environments of your * stack - * @param environment - * the environment for the stack + * @param environment the environment for the stack * @return the stack - * @throws IllegalAccessException - * the illegal access exception + * @throws IllegalAccessException the illegal access exception *

* Example * *

-     *                                {
-     *                                    @Code
-     *                                    Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                }
+     *                                                                                              {
+     *                                                                                                  @Code
+     *                                                                                                  Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
+     *                                                                                              }
      *
-     *                                
+ *
*/ public static Stack stack(String stackApiKey, String deliveryToken, String environment) throws IllegalAccessException { @@ -66,19 +62,14 @@ public static Stack stack(String stackApiKey, String deliveryToken, String envir * create content structures, content entries, users, etc. related to the * project. * - * @param stackApiKey - * The API Key is a unique key assigned to each stack. - * @param deliveryToken - * The Delivery Token is a read-only credential that you + * @param stackApiKey The API Key is a unique key assigned to each stack. + * @param deliveryToken The Delivery Token is a read-only credential that you * can create for different environments of your * stack - * @param environment - * the environment for the stack - * @param config - * the config + * @param environment the environment for the stack + * @param config the config * @return the stack - * @throws IllegalAccessException - * the illegal access exception Example + * @throws IllegalAccessException the illegal access exception Example *

* { @Code Stack stack = * contentstack.Stack("apiKey", "deliveryToken", @@ -115,6 +106,10 @@ private static Stack initializeStack(String stackApiKey, String deliveryToken, S if (config.getBranch() != null && !config.getBranch().isEmpty()) { stack.setHeader("branch", config.getBranch()); } + if (config.getEarlyAccess() != null && config.getEarlyAccess().length > 0) { + String eaValues = String.join(",", config.earlyAccess).replace("\"", ""); + stack.setHeader("x-header-ea", eaValues); + } stack.setConfig(config); return stack; } diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java index 4902a541..a9a89449 100644 --- a/src/main/java/com/contentstack/sdk/Stack.java +++ b/src/main/java/com/contentstack/sdk/Stack.java @@ -276,7 +276,7 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * @return the string */ public String imageTransform(@NotNull String imageUrl, @NotNull Map parameters) { - if (parameters.size() == 0) { + if (parameters.isEmpty()) { return imageUrl; } String query = getQueryParam(parameters); diff --git a/src/test/java/com/contentstack/sdk/TestContentstack.java b/src/test/java/com/contentstack/sdk/TestContentstack.java index c4c20d98..78663d1b 100644 --- a/src/test/java/com/contentstack/sdk/TestContentstack.java +++ b/src/test/java/com/contentstack/sdk/TestContentstack.java @@ -105,4 +105,29 @@ void initStackWithConfigs() throws IllegalAccessException { Assertions.assertEquals("cdn.contentstack.io", config.host); Assertions.assertNotNull(stack); } + + + @Test + void testConfigEarlyAccessSingleFeature() throws IllegalAccessException { + Config config = new Config(); + String[] earlyAccess = {"Taxonomy"}; + config.earlyAccess(earlyAccess); + Stack stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); + Assertions.assertEquals(earlyAccess[0], config.earlyAccess[0]); + Assertions.assertNotNull(stack.headers.containsKey("x-header-ea")); + Assertions.assertEquals("Taxonomy", stack.headers.get("x-header-ea")); + + } + + @Test + void testConfigEarlyAccessMultipleFeature() throws IllegalAccessException { + Config config = new Config(); + String[] earlyAccess = {"Taxonomy", "Teams", "Terms", "LivePreview"}; + config.earlyAccess(earlyAccess); + Stack stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENV, config); + Assertions.assertEquals(4, stack.headers.keySet().size()); + Assertions.assertEquals(earlyAccess[1], config.earlyAccess[1]); + Assertions.assertTrue(stack.headers.containsKey("x-header-ea")); + Assertions.assertEquals("Taxonomy,Teams,Terms,LivePreview", stack.headers.get("x-header-ea")); + } } From ba7a011719614862be809fe57d02d0f145ef50d3 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 16 Nov 2023 15:00:56 +0530 Subject: [PATCH 092/104] v1.12.3 Early Access Feature Support --- src/main/java/com/contentstack/sdk/Config.java | 15 --------------- 1 file changed, 15 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/Config.java b/src/main/java/com/contentstack/sdk/Config.java index 33a26129..7522eebc 100644 --- a/src/main/java/com/contentstack/sdk/Config.java +++ b/src/main/java/com/contentstack/sdk/Config.java @@ -32,21 +32,6 @@ public class Config { @Setter @Getter protected String branch; - /** - * -- SETTER -- - * Proxy can be set like below. - * - * @param proxy Proxy setting, typically a type (http, socks) and a socket address. A Proxy is an immutable object - *
- *
- * Example:
- *
- * - * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("proxyHost", "proxyPort")); - * java.net.Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("sl.theproxyvpn.io", 80)); Config - * config = new Config(); config.setProxy(proxy); - * - */ @Setter protected Proxy proxy = null; protected ConnectionPool connectionPool = new ConnectionPool(); From c02ae30df68acd6aa865110640db994ee276fc17 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 16 Nov 2023 15:22:47 +0530 Subject: [PATCH 093/104] v1.12.3 Early Access Feature Support --- src/main/java/com/contentstack/sdk/CSHttpConnection.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java index 38792649..3c0f12f3 100644 --- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java +++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java @@ -186,7 +186,7 @@ public void send() { } private void getService(String requestUrl) throws IOException { - this.headers.put(X_USER_AGENT_KEY, "contentstack-java/" + SDK_VERSION); + this.headers.put(X_USER_AGENT_KEY, "contentstack-delivery-java/" + SDK_VERSION); this.headers.put(USER_AGENT_KEY, USER_AGENT); this.headers.put(CONTENT_TYPE, APPLICATION_JSON); From 07bdf9d45c1f98879bec4f533e6ec3a222e38302 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 16 Nov 2023 15:26:02 +0530 Subject: [PATCH 094/104] v1.12.3 Early Access Feature Support --- src/main/java/com/contentstack/sdk/CSHttpConnection.java | 1 + 1 file changed, 1 insertion(+) diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java index 3c0f12f3..1bae8449 100644 --- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java +++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java @@ -186,6 +186,7 @@ public void send() { } private void getService(String requestUrl) throws IOException { + this.headers.put(X_USER_AGENT_KEY, "contentstack-delivery-java/" + SDK_VERSION); this.headers.put(USER_AGENT_KEY, USER_AGENT); this.headers.put(CONTENT_TYPE, APPLICATION_JSON); From 0cbcb2f8e6dea41c1db91e988cfacfb0e2f52972 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 13 Dec 2023 18:49:09 +0530 Subject: [PATCH 095/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- .../java/com/contentstack/sdk/APIService.java | 10 +- .../java/com/contentstack/sdk/Config.java | 3 +- .../java/com/contentstack/sdk/Constants.java | 2 + src/main/java/com/contentstack/sdk/Query.java | 218 ++++++---------- src/main/java/com/contentstack/sdk/Stack.java | 236 ++++++++---------- .../java/com/contentstack/sdk/Taxonomy.java | 125 ++++++++++ .../contentstack/sdk/TaxonomyCallback.java | 28 +++ .../com/contentstack/sdk/Credentials.java | 4 +- .../com/contentstack/sdk/TaxonomyTest.java | 73 ++++++ .../java/com/contentstack/sdk/TestAsset.java | 4 +- 10 files changed, 431 insertions(+), 272 deletions(-) create mode 100644 src/main/java/com/contentstack/sdk/Taxonomy.java create mode 100644 src/main/java/com/contentstack/sdk/TaxonomyCallback.java create mode 100644 src/test/java/com/contentstack/sdk/TaxonomyTest.java diff --git a/src/main/java/com/contentstack/sdk/APIService.java b/src/main/java/com/contentstack/sdk/APIService.java index a537f0d8..e178b7af 100644 --- a/src/main/java/com/contentstack/sdk/APIService.java +++ b/src/main/java/com/contentstack/sdk/APIService.java @@ -4,9 +4,11 @@ import retrofit2.Call; import retrofit2.http.GET; import retrofit2.http.HeaderMap; +import retrofit2.http.QueryMap; import retrofit2.http.Url; import java.util.LinkedHashMap; +import java.util.Map; /** * @author Shailesh Mishra @@ -15,5 +17,11 @@ */ public interface APIService { @GET - Call getRequest(@Url String url, @HeaderMap LinkedHashMap headers); + Call getRequest( + @Url String url, @HeaderMap LinkedHashMap headers); + + @GET("v3/taxonomies/entries") + Call getTaxonomy( + @HeaderMap Map headers, + @QueryMap(encoded = true) Map query); } diff --git a/src/main/java/com/contentstack/sdk/Config.java b/src/main/java/com/contentstack/sdk/Config.java index 7522eebc..495d0153 100644 --- a/src/main/java/com/contentstack/sdk/Config.java +++ b/src/main/java/com/contentstack/sdk/Config.java @@ -168,7 +168,8 @@ public enum ContentstackRegion { /** - * The configuration for the contentstack that contains support for Early Access Feature + * To initialize the SDK with the latest features offered in the early access phase, + * include the early access parameter as shown in the following code: * * @param earlyAccessFeatures The list of Early Access Features * {@code diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index 24917225..6a31923d 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -26,6 +26,8 @@ public class Constants { protected static final String CONTENT_TYPE_UID = "content_type_uid"; protected static final String ENTRY_UID = "entry_uid"; protected static final String LIVE_PREVIEW = "live_preview"; + + protected static final String TaxonomyPath = "/taxonomies/entries?query"; protected static final String SYNCHRONISATION = "stacks/sync"; // Errors protected static final String ERROR_CODE = "error_code"; diff --git a/src/main/java/com/contentstack/sdk/Query.java b/src/main/java/com/contentstack/sdk/Query.java index ce2c63ea..9522b626 100644 --- a/src/main/java/com/contentstack/sdk/Query.java +++ b/src/main/java/com/contentstack/sdk/Query.java @@ -63,21 +63,21 @@ protected void setContentTypeInstance(ContentType contentTypeInstance) { /** * To set headers for Built.io Contentstack rest calls.
Scope is limited to this object and followed classes. * - * @param key - * header name. - * @param value - * header value against given header name.
- * - *
- *
- * Example :
- *

- * tack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment"); Query query = - * stack.contentType("contentTypeUid").query(); query.setHeader("custom_key", "custom_value"); - * Example :
- *

- * Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment"); Query csQuery = - * stack.contentType("contentTypeUid").query(); csQuery.setHeader("custom_key", "custom_value"); + * @param key header name. + * @param value header value against given header name.
+ * + *
+ *
+ * Example :
+ *

+     *                                            Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment");
+     *                                            
+ * Query query = stack.contentType("contentTypeUid").query(); query.setHeader("custom_key", "custom_value"); + *
+ * Stack stack = Contentstack.stack( "apiKey", "deliveryToken", "environment"); + *
+ * Query csQuery = stack.contentType("contentTypeUid").query();
csQuery.setHeader("custom_key", "custom_value"); + *
*/ public Query setHeader(@NotNull String key, @NotNull String value) { if (!key.isEmpty() && !value.isEmpty()) { @@ -89,12 +89,11 @@ public Query setHeader(@NotNull String key, @NotNull String value) { /** * Remove header key @param key custom_header_key * - * @param key - * {@link String} - * Example :
- *

- * Stack stack = Contentstack..stack( "apiKey", "deliveryToken", "environment"); Query csQuery = - * stack.contentType("contentTypeUid").query();
csQuery.removeHeader("custom_key"); + * @param key {@link String} + * Example :
+ *

+ * Stack stack = Contentstack..stack( "apiKey", "deliveryToken", "environment"); Query csQuery = + * stack.contentType("contentTypeUid").query();
csQuery.removeHeader("custom_key"); */ public Query removeHeader(@NotNull String key) { if (!key.isEmpty()) { @@ -110,10 +109,8 @@ public String getContentType() { /** * Add a constraint to fetch all entries that contains given value against specified key * - * @param key - * field uid. - * @param value - * field value which get 'included' from the response. + * @param key field uid. + * @param value field value which get 'included' from the response. * @return {@link Query} object, so you can chain this call. *

* Note : for group field provide key in a @@ -138,10 +135,8 @@ public Query where(@NotNull String key, Object value) { /** * Add a custom query against specified key. * - * @param key - * key. - * @param value - * value. + * @param key key. + * @param value value. * @return {@link Query} object, so you can chain this call. * *
@@ -164,8 +159,7 @@ public Query addQuery(@NotNull String key, String value) { /** * Remove provided query key from custom query if existed. * - * @param key - * Query name to remove. + * @param key Query name to remove. * @return {@linkplain Query} object, so you can chain this call.
* *
@@ -186,8 +180,7 @@ public Query removeQuery(@NotNull String key) { /** * Combines all the queries together using AND operator * - * @param queryObjects - * list of {@link Query} instances on which AND query executes. + * @param queryObjects list of {@link Query} instances on which AND query executes. * @return {@link Query} object, so you can chain this call. * *
@@ -221,8 +214,7 @@ public Query and(@NotNull List queryObjects) { /** * Add a constraint to fetch all entries which satisfy any queries. * - * @param queryObjects - * list of {@link Query} instances on which OR query executes. + * @param queryObjects list of {@link Query} instances on which OR query executes. * @return {@link Query} object, so you can chain this call. * *
@@ -262,10 +254,8 @@ public Query or(List queryObjects) { /** * Add a constraint to the query that requires a particular key entry to be less than the provided value. * - * @param key - * the key to be constrained. - * @param value - * the value that provides an upper bound. + * @param key the key to be constrained. + * @param value the value that provides an upper bound. * @return {@link Query} object, so you can chain this call.
* *
@@ -280,7 +270,7 @@ public Query or(List queryObjects) { */ public Query lessThan(@NotNull String key, @NotNull Object value) { if (queryValueJSON.isNull(key)) { - if (queryValue.length() > 0) { + if (!queryValue.isEmpty()) { queryValue = new JSONObject(); } queryValue.put("$lt", value); @@ -296,10 +286,8 @@ public Query lessThan(@NotNull String key, @NotNull Object value) { * Add a constraint to the query that requires a particular key entry to be less than or equal to the provided * value. * - * @param key - * The key to be constrained - * @param value - * The value that must be equalled. + * @param key The key to be constrained + * @param value The value that must be equalled. * @return {@link Query} object, so you can chain this call. * *
@@ -314,7 +302,7 @@ public Query lessThan(@NotNull String key, @NotNull Object value) { */ public Query lessThanOrEqualTo(@NotNull String key, Object value) { if (queryValueJSON.isNull(key)) { - if (queryValue.length() > 0) { + if (!queryValue.isEmpty()) { queryValue = new JSONObject(); } queryValue.put("$lte", value); @@ -329,10 +317,8 @@ public Query lessThanOrEqualTo(@NotNull String key, Object value) { /** * Add a constraint to the query that requires a particular key entry to be greater than the provided value. * - * @param key - * The key to be constrained. - * @param value - * The value that provides a lower bound. + * @param key The key to be constrained. + * @param value The value that provides a lower bound. * @return {@link Query} object, so you can chain this call. * *
@@ -347,7 +333,7 @@ public Query lessThanOrEqualTo(@NotNull String key, Object value) { */ public Query greaterThan(@NotNull String key, Object value) { if (queryValueJSON.isNull(key)) { - if (queryValue.length() > 0) { + if (!queryValue.isEmpty()) { queryValue = new JSONObject(); } queryValue.put("$gt", value); @@ -363,10 +349,8 @@ public Query greaterThan(@NotNull String key, Object value) { * Add a constraint to the query that requires a particular key entry to be greater than or equal to the provided * value. * - * @param key - * The key to be constrained. - * @param value - * The value that provides a lower bound. + * @param key The key to be constrained. + * @param value The value that provides a lower bound. * @return {@link Query} object, so you can chain this call. * *
@@ -396,10 +380,8 @@ public Query greaterThanOrEqualTo(String key, Object value) { /** * Add a constraint to the query that requires a particular key's entry to be not equal to the provided value. * - * @param key - * The key to be constrained. - * @param value - * The object that must not be equaled. + * @param key The key to be constrained. + * @param value The object that must not be equaled. * @return {@link Query} object, so you can chain this call. * *
@@ -429,10 +411,8 @@ public Query notEqualTo(@NotNull String key, Object value) { /** * Add a constraint to the query that requires a particular key's entry to be contained in the provided array. * - * @param key - * The key to be constrained. - * @param values - * The possible values for the key's object. + * @param key The key to be constrained. + * @param values The possible values for the key's object. * @return {@link Query} object, so you can chain this call.
* *
@@ -467,10 +447,8 @@ public Query containedIn(@NotNull String key, Object[] values) { * Add a constraint to the query that requires a particular key entry's value not be contained in the provided * array. * - * @param key - * The key to be constrained. - * @param values - * The list of values the key object should not be. + * @param key The key to be constrained. + * @param values The list of values the key object should not be. * @return {@link Query} object, so you can chain this call. * *
@@ -504,8 +482,7 @@ public Query notContainedIn(@NotNull String key, Object[] values) { /** * Add a constraint that requires, a specified key exists in response. * - * @param key - * The key to be constrained. + * @param key The key to be constrained. * @return {@link Query} object, so you can chain this call. * *
@@ -535,8 +512,7 @@ public Query exists(@NotNull String key) { /** * Add a constraint that requires, a specified key does not exist in response. * - * @param key - * The key to be constrained. + * @param key The key to be constrained. * @return {@link Query} object, so you can chain this call.
* * @@ -568,8 +544,7 @@ public Query notExists(@NotNull String key) { /** * Add a constraint that requires a particular reference key details. * - * @param key - * key that to be constrained. + * @param key key that to be constrained. * @return {@link Query} object, so you can chain this call. * *
@@ -593,8 +568,7 @@ public Query includeReference(String key) { /** * Include tags with which to search entries. * - * @param tags - * Comma separated array of tags with which to search entries. + * @param tags Comma separated array of tags with which to search entries. * @return {@link Query} object, so you can chain this call.
* *
@@ -617,8 +591,7 @@ public Query tags(@NotNull String[] tags) { * Sort the results in ascending order with the given key.
Sort the returned entries in ascending order of the * provided key. * - * @param key - * The key to order by. + * @param key The key to order by. * @return {@link Query} object, so you can chain this call.
* *
@@ -641,8 +614,7 @@ public Query ascending(@NotNull String key) { * Sort the results in descending order with the given key.
Sort the returned entries in descending order of * the provided key. * - * @param key - * The key to order by. + * @param key The key to order by. * @return {@link Query} object, so you can chain this call.
* *
@@ -663,8 +635,7 @@ public Query descending(@NotNull String key) { /** * Specifies list of field ids that would be 'excluded' from the response. * - * @param fieldUid - * field uid which get 'excluded' from the response. + * @param fieldUid field uid which get 'excluded' from the response. * @return {@link Query} object, so you can chain this call. * *
@@ -695,8 +666,7 @@ public Query except(@NotNull List fieldUid) { /** * Specifies list of field ids that would be 'excluded' from the response. * - * @param fieldIds - * field uid which get 'excluded' from the response. + * @param fieldIds field uid which get 'excluded' from the response. * @return {@link Query} object, so you can chain this call.
* *
@@ -724,8 +694,7 @@ public Query except(@NotNull String[] fieldIds) { /** * Specifies an array of 'only' keys in BASE object that would be 'included' in the response. * - * @param fieldUid - * Array of the 'only' reference keys to be included in response. + * @param fieldUid Array of the 'only' reference keys to be included in response. * @return {@link Query} object, so you can chain this call.
* *
@@ -753,10 +722,8 @@ public Query only(@NotNull String[] fieldUid) { /** * Specifies an array of 'only' keys that would be 'included' in the response. * - * @param fieldUid - * Array of the 'only' reference keys to be included in response. - * @param referenceFieldUid - * Key who has reference to some other class object. + * @param fieldUid Array of the 'only' reference keys to be included in response. + * @param referenceFieldUid Key who has reference to some other class object. * @return {@link Query} object, so you can chain this call.
* * @@ -792,10 +759,8 @@ public Query onlyWithReferenceUid(@NotNull List fieldUid, @NotNull Strin /** * Specifies an array of 'except' keys that would be 'excluded' in the response. * - * @param fieldUid - * Array of the 'except' reference keys to be excluded in response. - * @param referenceFieldUid - * Key who has reference to some other class object. + * @param fieldUid Array of the 'except' reference keys to be excluded in response. + * @param referenceFieldUid Key who has reference to some other class object. * @return {@link Query} object, so you can chain this call.
* *
@@ -897,8 +862,7 @@ public Query includeContentType() { /** * The number of objects to skip before returning any. * - * @param number - * No of objects to skip from returned objects + * @param number No of objects to skip from returned objects * @return {@link Query} object, so you can chain this call. *

* Note: The skip parameter can be used for pagination, @@ -922,8 +886,7 @@ public Query skip(int number) { /** * A limit on the number of objects to return. * - * @param number - * No of objects to limit. + * @param number No of objects to limit. * @return {@link Query} object, so you can chain this call. *

* Note: The limit parameter can be used for pagination, " @@ -948,10 +911,8 @@ public Query limit(int number) { * Add a regular expression constraint for finding string values that match the provided regular expression. This * may be slow for large data sets. * - * @param key - * The key to be constrained. - * @param regex - * The regular expression pattern to match. + * @param key The key to be constrained. + * @param regex The regular expression pattern to match. * @return {@link Query} object, so you can chain this call.
* *
@@ -983,21 +944,18 @@ public Query regex(@NotNull String key, @NotNull String regex) { * Add a regular expression constraint for finding string values that match the provided regular expression. This * may be slow for large data sets. * - * @param key - * The key to be constrained. - * @param regex - * The regular expression pattern to match - * @param modifiers - * Any of the following supported Regular expression modifiers. - *

- * use i for case-insensitive matching. - *

- *

- * use m for making dot match newlines. - *

- *

- * use x for ignoring whitespace in regex - *

+ * @param key The key to be constrained. + * @param regex The regular expression pattern to match + * @param modifiers Any of the following supported Regular expression modifiers. + *

+ * use i for case-insensitive matching. + *

+ *

+ * use m for making dot match newlines. + *

+ *

+ * use x for ignoring whitespace in regex + *

* @return {@link Query} object, so you can chain this call.
* *
@@ -1038,8 +996,7 @@ public Query regex(@NotNull String key, @NotNull String regex, String modifiers) /** * set Language using locale code. * - * @param locale - * {@link String} value + * @param locale {@link String} value * @return {@link Query} object, so you can chain this call
*
*
@@ -1059,8 +1016,7 @@ public Query locale(@NotNull String locale) { /** * This method provides only the entries matching the specified value. * - * @param value - * value used to match or compare + * @param value value used to match or compare * @return {@link Query} object, so you can chain this call.
* *
@@ -1084,8 +1040,7 @@ public Query search(@NotNull String value) { /** * Execute a Query and Caches its result (Optional) * - * @param callback - * {@link QueryResultsCallBack} object to notify the application when the request has completed. + * @param callback {@link QueryResultsCallBack} object to notify the application when the request has completed. * @return {@linkplain Query} object, so you can chain this call.
* * @@ -1123,8 +1078,7 @@ public Query find(QueryResultsCallBack callback) { /** * Execute a Query and Caches its result (Optional) * - * @param callBack - * {@link QueryResultsCallBack} object to notify the application when the request has completed. + * @param callBack {@link QueryResultsCallBack} object to notify the application when the request has completed. * @return {@linkplain Query} object, so you can chain this call.
* *
@@ -1294,10 +1248,8 @@ public void getResultObject(List objects, JSONObject jsonObject, boolean /** * This method adds key and value to an Entry. Parameters: * - * @param key: - * The key as string which needs to be added to the Query - * @param value: - * The value as string which needs to be added to the Query + * @param key: The key as string which needs to be added to the Query + * @param value: The value as string which needs to be added to the Query * @return - Query * *
@@ -1349,10 +1301,8 @@ public Query includeReferenceContentTypUid() { * Get entries having values based on referenced fields. This query retrieves all entries that satisfy the query * conditions made on referenced fields. * - * @param key - * The key to be constrained - * @param queryObject - * {@link Query} object, so you can chain this call + * @param key The key to be constrained + * @param queryObject {@link Query} object, so you can chain this call * @return {@link Query} object, so you can chain this call
* *
@@ -1376,10 +1326,8 @@ public Query whereIn(@NotNull String key, Query queryObject) { * Get entries having values based on referenced fields. This query works the opposite of $in_query and retrieves * all entries that does not satisfy query conditions made on referenced fields. * - * @param key - * The key to be constrained - * @param queryObject - * {@link Query} object, so you can chain this call + * @param key The key to be constrained + * @param queryObject {@link Query} object, so you can chain this call * @return {@link Query} object, so you can chain this call * *
diff --git a/src/main/java/com/contentstack/sdk/Stack.java b/src/main/java/com/contentstack/sdk/Stack.java index a9a89449..73aaae64 100644 --- a/src/main/java/com/contentstack/sdk/Stack.java +++ b/src/main/java/com/contentstack/sdk/Stack.java @@ -105,8 +105,7 @@ private void includeLivePreview() { * Contentstack. You can set up the base URL and environment across which you want to preview content. *

* - * @param query - * the query of type {@link HashMap} + * @param query the query of type {@link HashMap} * @return stack *

* Example @@ -117,8 +116,7 @@ private void includeLivePreview() { *

* stack.livePreviewQuery(queryMap) *

- * @throws IOException - * IO Exception + * @throws IOException IO Exception */ public Stack livePreviewQuery(Map query) throws IOException { config.livePreviewHash = query.get(LIVE_PREVIEW); @@ -154,9 +152,8 @@ public Stack livePreviewQuery(Map query) throws IOException { * content for your application, you are required to first create a content type, and then create entries using the * content type. * - * @param contentTypeUid - * Enter the unique ID of the content type of which you want to retrieve the entries. The UID is often based - * on the title of the content type and it is unique across a stack. + * @param contentTypeUid Enter the unique ID of the content type of which you want to retrieve the entries. The UID is often based + * on the title of the content type, and it is unique across a stack. * @return the {@link ContentType} *

* Example @@ -179,8 +176,7 @@ public ContentType contentType(String contentTypeUid) { * The Get a single asset request fetches the latest version of a specific asset of a particular stack. *

* - * @param uid - * uid of {@link Asset} + * @param uid uid of {@link Asset} * @return {@link Asset} instance Tip: If no version is mentioned, the request will retrieve the latest * published version of the asset. To retrieve a specific version, use the version parameter, keep the environment * parameter blank, and use the management token instead of the delivery token. @@ -241,10 +237,9 @@ public String getDeliveryToken() { /** * Removes Header by key * - * @param headerKey - * of the header - *

- * Example: stack.removeHeader("delivery_token"); + * @param headerKey of the header + *

+ * Example: stack.removeHeader("delivery_token"); */ public void removeHeader(String headerKey) { headers.remove(headerKey); @@ -253,10 +248,8 @@ public void removeHeader(String headerKey) { /** * Adds header to the stack * - * @param headerKey - * the header key - * @param headerValue - * the header value + * @param headerKey the header key + * @param headerValue the header value */ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { if (!headerKey.isEmpty() && !headerValue.isEmpty()) { @@ -269,10 +262,8 @@ public void setHeader(@NotNull String headerKey, @NotNull String headerValue) { * parameters that you can add to the URL to retrieve, manipulate (or convert) image files and display it to your * web or mobile properties. * - * @param imageUrl - * the image url - * @param parameters - * the parameters {@link LinkedHashMap} + * @param imageUrl the image url + * @param parameters the parameters {@link LinkedHashMap} * @return the string */ public String imageTransform(@NotNull String imageUrl, @NotNull Map parameters) { @@ -296,11 +287,9 @@ protected String getQueryParam(Map params) { * The Get all content types call returns comprehensive information of all the content types available in a * particular stack in your account.. * - * @param params - * query parameters - * @param callback - * ContentTypesCallback This call returns comprehensive information of all the content types available in a - * particular stack in your account. + * @param params query parameters + * @param callback ContentTypesCallback This call returns comprehensive information of all the content types available in a + * particular stack in your account. */ public void getContentTypes(@NotNull JSONObject params, final ContentTypesCallback callback) { Iterator keys = params.keys(); @@ -321,8 +310,7 @@ public void getContentTypes(@NotNull JSONObject params, final ContentTypesCallba * the specified stack in response. The response also contains a sync token, which you need to store, since this * token is used to get subsequent delta * - * @param syncCallBack - * returns callback for sync result. + * @param syncCallBack returns callback for sync result. */ public void sync(SyncResultCallBack syncCallBack) { syncParams = new JSONObject(); @@ -333,21 +321,19 @@ public void sync(SyncResultCallBack syncCallBack) { /** * Sync pagination token. * - * @param paginationToken - * If the response is paginated, use the pagination token under this parameter. - * @param syncCallBack - * returns callback for sync result - *

- * If the result of the initial sync (or subsequent sync) contains more than 100 records, the response would - * be paginated. It provides pagination token in the response. However, you do not have to use the - * pagination token manually to get the next batch, the SDK does that automatically until the sync is - * complete. Pagination token can be used in case you want to fetch only selected batches. It is especially - * useful if the sync process is interrupted midway (due to network issues, etc.). In such cases, this token - * can be used to restart the sync process from where it was interrupted.
- *
- * Example :
- * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); - * stack.syncPaginationToken("paginationToken) + * @param paginationToken If the response is paginated, use the pagination token under this parameter. + * @param syncCallBack returns callback for sync result + *

+ * If the result of the initial sync (or subsequent sync) contains more than 100 records, the response would + * be paginated. It provides pagination token in the response. However, you do not have to use the + * pagination token manually to get the next batch, the SDK does that automatically until the sync is + * complete. Pagination token can be used in case you want to fetch only selected batches. It is especially + * useful if the sync process is interrupted midway (due to network issues, etc.). In such cases, this token + * can be used to restart the sync process from where it was interrupted.
+ *
+ * Example :
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncPaginationToken("paginationToken) */ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallBack syncCallBack) { syncParams = new JSONObject(); @@ -358,21 +344,19 @@ public void syncPaginationToken(@NotNull String paginationToken, SyncResultCallB /** * Sync token. * - * @param syncToken - * Use the sync token that you received in the previous/initial sync under this parameter. - * @param syncCallBack - * returns callback for sync result - *

- * You can use the sync token (that you receive after initial sync) to get the updated content next time. - * The sync token fetches only the content that was added after your last sync, and the details of the - * content that was deleted or updated.
- *
- * Example :
- *

-     *                                                                                                                                                                                                                                                                                             Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
-     *                                                                                                                                                                                                                                                                                             stack.syncToken("syncToken")
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     stack.syncToken(sync_token, new SyncResultCallBack()                                                                                                                                                                                                               ){ }
-     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     
+ * @param syncToken Use the sync token that you received in the previous/initial sync under this parameter. + * @param syncCallBack returns callback for sync result + *

+ * You can use the sync token (that you receive after initial sync) to get the updated content next time. + * The sync token fetches only the content that was added after your last sync, and the details of the + * content that was deleted or updated.
+ *
+ * Example :
+ *

+     *                                                                                                                                                                                                                                                                                                                                                         Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment");
+     *                                                                                                                                                                                                                                                                                                                                                         stack.syncToken("syncToken")
+     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 stack.syncToken(sync_token, new SyncResultCallBack()                                                                                                                                                                                                               ){ }
+     *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 
*/ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { syncParams = new JSONObject(); @@ -383,17 +367,15 @@ public void syncToken(String syncToken, SyncResultCallBack syncCallBack) { /** * Sync from date. * - * @param fromDate - * Enter the start date for initial sync. - * @param syncCallBack - * Returns callback for sync result. - *

- * You can also initialize sync with entries published after a specific date. To do this, use syncWithDate - * and specify the start date as its value.
- *
- * Example :
- * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); - * stack.syncFromDate("fromDate") + * @param fromDate Enter the start date for initial sync. + * @param syncCallBack Returns callback for sync result. + *

+ * You can also initialize sync with entries published after a specific date. To do this, use syncWithDate + * and specify the start date as its value.
+ *
+ * Example :
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); + * stack.syncFromDate("fromDate") */ public void syncFromDate(@NotNull Date fromDate, SyncResultCallBack syncCallBack) { String newFromDate = convertUTCToISO(fromDate); @@ -413,18 +395,16 @@ protected String convertUTCToISO(Date date) { /** * Sync content type. * - * @param contentType - * Provide uid of your content_type - * @param syncCallBack - * Returns callback for sync result. - *

- * You can also initialize sync with entries of only specific content_type. To do this, use syncContentType - * and specify the content type uid as its value. However, if you do this, the subsequent syncs will only - * include the entries of the specified content_type.
- *
- * Example : - *

- * stack.syncContentType(String content_type, new SyncResultCallBack()){ } + * @param contentType Provide uid of your content_type + * @param syncCallBack Returns callback for sync result. + *

+ * You can also initialize sync with entries of only specific content_type. To do this, use syncContentType + * and specify the content type uid as its value. However, if you do this, the subsequent syncs will only + * include the entries of the specified content_type.
+ *
+ * Example : + *

+ * stack.syncContentType(String content_type, new SyncResultCallBack()){ } */ public void syncContentType(@NotNull String contentType, SyncResultCallBack syncCallBack) { syncParams = new JSONObject(); @@ -436,18 +416,16 @@ public void syncContentType(@NotNull String contentType, SyncResultCallBack sync /** * Sync locale. * - * @param localeCode - * Select the required locale code. - * @param syncCallBack - * Returns callback for sync result. - *

- * You can also initialize sync with entries of only specific locales. To do this, use syncLocale and - * specify the locale code as its value. However, if you do this, the subsequent syncs will only include the - * entries of the specified locales.
- *
- * Example :
- * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); stack.syncContentType(String - * content_type, new SyncResultCallBack()){ } + * @param localeCode Select the required locale code. + * @param syncCallBack Returns callback for sync result. + *

+ * You can also initialize sync with entries of only specific locales. To do this, use syncLocale and + * specify the locale code as its value. However, if you do this, the subsequent syncs will only include the + * entries of the specified locales.
+ *
+ * Example :
+ * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); stack.syncContentType(String + * content_type, new SyncResultCallBack()){ } */ public void syncLocale(String localeCode, SyncResultCallBack syncCallBack) { syncParams = new JSONObject(); @@ -459,25 +437,23 @@ public void syncLocale(String localeCode, SyncResultCallBack syncCallBack) { /** * Sync publish type. * - * @param publishType - * Use the type parameter to get a specific type of content like - *

- * (asset_published, entry_published, asset_unpublished, asset_deleted, entry_unpublished, entry_deleted, - * content_type_deleted.) - * @param syncCallBack - * returns callback for sync result. - *

- * Use the type parameter to get a specific type of content. You can pass one of the following values: - * asset_published, entry_published, asset_unpublished, asset_deleted, entry_unpublished, entry_deleted, - * content_type_deleted. If you do not specify any value, it will bring all published entries and published - * assets. - *
- *
- * Example :
- * - * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); * - * stack.syncPublishType(PublishType) - * + * @param publishType Use the type parameter to get a specific type of content like + *

+ * (asset_published, entry_published, asset_unpublished, asset_deleted, entry_unpublished, entry_deleted, + * content_type_deleted.) + * @param syncCallBack returns callback for sync result. + *

+ * Use the type parameter to get a specific type of content. You can pass one of the following values: + * asset_published, entry_published, asset_unpublished, asset_deleted, entry_unpublished, entry_deleted, + * content_type_deleted. If you do not specify any value, it will bring all published entries and published + * assets. + *
+ *
+ * Example :
+ * + * Stack stack = contentstack.Stack("apiKey", "deliveryToken", "environment"); * + * stack.syncPublishType(PublishType) + * */ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCallBack) { syncParams = new JSONObject(); @@ -489,22 +465,17 @@ public void syncPublishType(PublishType publishType, SyncResultCallBack syncCall /** * Sync. * - * @param contentType - * your content type id - * @param fromDate - * start date - * @param localeCode - * language as language code - * @param publishType - * type as PublishType - * @param syncCallBack - * Callback - *

- * You can also initialize sync with entries that satisfy multiple parameters. To do this, use syncWith and - * specify the parameters. However, if you do this, the subsequent syncs will only include the entries of - * the specified parameters
- *
- * Example :
+ * @param contentType your content type id + * @param fromDate start date + * @param localeCode language as language code + * @param publishType type as PublishType + * @param syncCallBack Callback + *

+ * You can also initialize sync with entries that satisfy multiple parameters. To do this, use syncWith and + * specify the parameters. However, if you do this, the subsequent syncs will only include the entries of + * the specified parameters
+ *
+ * Example :
*/ public void sync(String contentType, Date fromDate, String localeCode, PublishType publishType, SyncResultCallBack syncCallBack) { @@ -547,7 +518,7 @@ private void fetchFromNetwork(String urlString, JSONObject urlQueries, private HashMap getUrlParams(JSONObject jsonQuery) { HashMap hashMap = new HashMap<>(); - if (jsonQuery != null && jsonQuery.length() > 0) { + if (jsonQuery != null && !jsonQuery.isEmpty()) { Iterator iteString = jsonQuery.keys(); while (iteString.hasNext()) { String key = iteString.next(); @@ -558,11 +529,16 @@ private HashMap getUrlParams(JSONObject jsonQuery) { return hashMap; } + + public Taxonomy taxonomy() { + return new Taxonomy(this.service,this.config, this.headers); + } + + /** * The enum Publish type. */ public enum PublishType { - //asset_deleted, asset_published, asset_unpublished, content_type_deleted, entry_deleted, entry_published, // Breaking change in v3.11.0 ASSET_DELETED, ASSET_PUBLISHED, diff --git a/src/main/java/com/contentstack/sdk/Taxonomy.java b/src/main/java/com/contentstack/sdk/Taxonomy.java new file mode 100644 index 00000000..68866b6c --- /dev/null +++ b/src/main/java/com/contentstack/sdk/Taxonomy.java @@ -0,0 +1,125 @@ +package com.contentstack.sdk; + +import okhttp3.Request; +import okhttp3.ResponseBody; +import retrofit2.Call; +import retrofit2.Response; + +import java.io.IOException; +import java.util.HashMap; +import java.util.LinkedHashMap; +import java.util.Map; + +/** + * The type Taxonomy. + * + * @author Shailesh Mishra
Taxonomy :

Taxonomy, currently in the Early Access Phase simplifies the process of organizing content in your system, making it effortless to find and retrieve information. + */ +public class Taxonomy { + + + protected LinkedHashMap headers; + protected APIService service; + protected HashMap query = new HashMap<>(); + protected Config config; + + /** + * Instantiates a new Taxonomy. + * + * @param service the service + * @param config the config + * @param headers the headers + */ + public Taxonomy(APIService service, Config config, LinkedHashMap headers) { + this.service = service; + this.headers = headers; + this.config = config; + } + + /** + * You can retrieve filtered entries using taxonomy through two different endpoints: + * + * @param queryParams the query parameters should be like below + *

    + *
  • IN Operator : Get all entries for a specific taxonomy that satisfy the given conditions provided in the '$in' query.
    Your query should be as follows:
    {"taxonomies.taxonomy_uid" : { "$in" : ["term_uid1" , "term_uid2" ] }}

  • OR Operator : Get all entries for a specific taxonomy that satisfy at least one of the given conditions provided in the “$or” query.
    Your query should be as follows:
    query={ $or: [ { "taxonomies.taxonomy_uid_1" : "term_uid1" }, { "taxonomies.taxonomy_uid_2" : "term_uid2" } ] } + *
  • + *
    + *
  • + * AND Operator :
    + * Get all entries for a specific taxonomy that satisfy all the conditions provided in the “$and” query.
    + *

    + * Your query should be as follows:
    + * + * { + * $and: [ + * { "taxonomies.taxonomy_uid_1" : "term_uid1" }, + * { "taxonomies.taxonomy_uid_2" : "term_uid2" } + * ] + * } + * + * + *

  • + *
    + * + *
  • + * Exists Operator :
    + * Get all entries for a specific taxonomy that if the value of the field, mentioned in the condition, exists.
    + *

    + * Your query should be as follows: + * + * {"taxonomies.taxonomy_uid" : { "$exists": true }} + * + *


  • + *
  • + * Equal and Below Operator :
    + * Get all entries for a specific taxonomy that match a specific term and all its descendant terms, requiring only the target term and a specified level.
    + *

    + * Your query should be as follows: + * + * { + * "taxonomies.taxonomy_uid" : { "$eq_below": "term_uid", "level" : 2}} + * + *

  • + * + * + *
+ * @return instance of {@link Taxonomy} + */ + public Taxonomy query(Map queryParams) { + query.putAll(queryParams); + return this; + } + + /** + * Make request call. + * + * @return the call + */ + Call makeRequest() { + HashMap map = new HashMap<>(); + map.put("query", query); + return this.service.getTaxonomy(this.headers, map); + } + + + /** + * Find. + * + * @param callback the callback + */ + public void find(TaxonomyCallback callback) { + try { + Response response = makeRequest().execute(); + if (response.isSuccessful()) { + callback.onResponse(response.body()); + } else { + Request request = makeRequest().request(); + callback.onFailure(request, response.errorBody()); + } + } catch (IOException e) { + throw new RuntimeException(e); + } + } +} + + diff --git a/src/main/java/com/contentstack/sdk/TaxonomyCallback.java b/src/main/java/com/contentstack/sdk/TaxonomyCallback.java new file mode 100644 index 00000000..3de08db1 --- /dev/null +++ b/src/main/java/com/contentstack/sdk/TaxonomyCallback.java @@ -0,0 +1,28 @@ +package com.contentstack.sdk; + +import okhttp3.Request; +import okhttp3.ResponseBody; + +public interface TaxonomyCallback { + + /** + * Called when the HTTP response was successfully returned by the remote server. The callback may + * proceed to read the response body. The response is still live until + * its response body is {@linkplain ResponseBody closed}. The recipient of the callback may + * consume the response body on another thread. + * + *

Note that transport-layer success (receiving a HTTP response code, headers and body) does + * not necessarily indicate application-layer success: {@code response} may still indicate an + * unhappy HTTP response code like 404 or 500. + */ + void onResponse(ResponseBody response); + + /** + * Called when the request could not be executed due to cancellation, a connectivity problem or + * timeout. Because networks can fail during an exchange, it is possible that the remote server + * accepted the request before the failure. + */ + void onFailure(Request request, ResponseBody errorMessage); + + +} \ No newline at end of file diff --git a/src/test/java/com/contentstack/sdk/Credentials.java b/src/test/java/com/contentstack/sdk/Credentials.java index 9b5bb2c5..33d6e556 100644 --- a/src/test/java/com/contentstack/sdk/Credentials.java +++ b/src/test/java/com/contentstack/sdk/Credentials.java @@ -15,7 +15,6 @@ private static String envChecker() { if (githubActions != null && githubActions.equals("true")) { System.out.println("Tests are running in GitHub Actions environment."); String mySecretKey = System.getenv("API_KEY"); - System.out.println("My Secret Key: " + mySecretKey); return "GitHub"; } else { System.out.println("Tests are running in a local environment."); @@ -65,13 +64,14 @@ private Credentials() throws AccessException { public static Stack getStack() { if (stack == null) { var envCheck = envChecker(); - System.out.println(envCheck); + System.out.println("idendified env file detected " + envCheck); synchronized (Credentials.class) { if (stack == null) { try { Config config = new Config(); config.setHost(HOST); stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENVIRONMENT, config); + System.out.println(stack); } catch (IllegalAccessException e) { throw new RuntimeException(e); } diff --git a/src/test/java/com/contentstack/sdk/TaxonomyTest.java b/src/test/java/com/contentstack/sdk/TaxonomyTest.java new file mode 100644 index 00000000..27b16972 --- /dev/null +++ b/src/test/java/com/contentstack/sdk/TaxonomyTest.java @@ -0,0 +1,73 @@ +package com.contentstack.sdk; + +import okhttp3.*; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Test; + +import java.io.IOException; +import java.util.HashMap; + + +public class TaxonomyTest { + + private final Taxonomy taxonomy = Credentials.getStack().taxonomy(); + + @Test + void testInstance() { + Assertions.assertNotNull(taxonomy); + } + + @Test + void testInOperator() { + HashMap query = new HashMap<>(); + query.put("taxonomies.taxonomy_uid", new HashMap() {{ + put("$in", new String[]{"term_uid1", "term_uid2"}); + }}); + + taxonomy.query(query).find(new TaxonomyCallback() { + @Override + public void onFailure(Request request, ResponseBody errorMessage) { + System.out.println("Failing API call : "+errorMessage.toString()); + + } + + @Override + public void onResponse(Request request, ResponseBody response) { + System.out.println("Response : "+response.toString()); + + } + }); + } + + +// @Test +// void testTaxonomyIn() { +// String[] value = {"term_uid1", "term_uid2"}; // ["term_uid1" , "term_uid2" ] +// +// Request request = taxonomy.inOperator("taxonomies.taxonomy_uid", value).find().request(); +// taxonomy.find(new Callback() { +// @Override +// public void onResponse(Call call, Response response) { +// call.request().url(); +// } +// +// @Override +// public void onFailure(Call call, Throwable t) { +// +// } +// }); +// Assertions.assertEquals(3, request.headers().size()); +// Assertions.assertEquals("GET", request.method().toString(), "test method are being passed though payload"); +// Assertions.assertEquals("cdn.contentstack.io", request.url().host()); +// Assertions.assertNull(request.url().encodedFragment(), "We do not expect any fragment"); +// Assertions.assertEquals("/taxonomies/entries", request.url().encodedPath()); +// Assertions.assertEquals(2, Arrays.stream(request.url().encodedPathSegments().stream().toArray()).count()); +// Assertions.assertEquals("", request.url().query()); +// Assertions.assertEquals("", request.url().encodedQuery()); +// Assertions.assertEquals("", request.url().queryParameterNames()); +// Assertions.assertEquals("", request.url(), "test url are being passed though payload"); +// Assertions.assertEquals("", request.body().contentType().toString(), "test content type are being passed though payload"); +// } + + +} diff --git a/src/test/java/com/contentstack/sdk/TestAsset.java b/src/test/java/com/contentstack/sdk/TestAsset.java index 0991b583..accc173f 100644 --- a/src/test/java/com/contentstack/sdk/TestAsset.java +++ b/src/test/java/com/contentstack/sdk/TestAsset.java @@ -14,16 +14,14 @@ class TestAsset { private String assetUid; private final Stack stack = Credentials.getStack(); - private String envChecker() { + private void envChecker() { String githubActions = System.getenv("GITHUB_ACTIONS"); if (githubActions != null && githubActions.equals("true")) { System.out.println("Tests are running in GitHub Actions environment."); String mySecretKey = System.getenv("API_KEY"); System.out.println("My Secret Key: " + mySecretKey); - return "GitHub"; } else { System.out.println("Tests are running in a local environment."); - return "local"; } } From a046fa01ede993698f63e677fd036e3669bdc18b Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Wed, 13 Dec 2023 19:10:54 +0530 Subject: [PATCH 096/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- .../com/contentstack/sdk/TaxonomyTest.java | 76 +++++++++++-------- 1 file changed, 46 insertions(+), 30 deletions(-) diff --git a/src/test/java/com/contentstack/sdk/TaxonomyTest.java b/src/test/java/com/contentstack/sdk/TaxonomyTest.java index 27b16972..f059a5a1 100644 --- a/src/test/java/com/contentstack/sdk/TaxonomyTest.java +++ b/src/test/java/com/contentstack/sdk/TaxonomyTest.java @@ -4,7 +4,7 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import java.io.IOException; +import java.util.Arrays; import java.util.HashMap; @@ -32,7 +32,7 @@ public void onFailure(Request request, ResponseBody errorMessage) { } @Override - public void onResponse(Request request, ResponseBody response) { + public void onResponse(ResponseBody response) { System.out.println("Response : "+response.toString()); } @@ -40,34 +40,50 @@ public void onResponse(Request request, ResponseBody response) { } -// @Test -// void testTaxonomyIn() { -// String[] value = {"term_uid1", "term_uid2"}; // ["term_uid1" , "term_uid2" ] -// -// Request request = taxonomy.inOperator("taxonomies.taxonomy_uid", value).find().request(); -// taxonomy.find(new Callback() { -// @Override -// public void onResponse(Call call, Response response) { -// call.request().url(); -// } -// -// @Override -// public void onFailure(Call call, Throwable t) { -// -// } -// }); -// Assertions.assertEquals(3, request.headers().size()); -// Assertions.assertEquals("GET", request.method().toString(), "test method are being passed though payload"); -// Assertions.assertEquals("cdn.contentstack.io", request.url().host()); -// Assertions.assertNull(request.url().encodedFragment(), "We do not expect any fragment"); -// Assertions.assertEquals("/taxonomies/entries", request.url().encodedPath()); -// Assertions.assertEquals(2, Arrays.stream(request.url().encodedPathSegments().stream().toArray()).count()); -// Assertions.assertEquals("", request.url().query()); -// Assertions.assertEquals("", request.url().encodedQuery()); -// Assertions.assertEquals("", request.url().queryParameterNames()); -// Assertions.assertEquals("", request.url(), "test url are being passed though payload"); -// Assertions.assertEquals("", request.body().contentType().toString(), "test content type are being passed though payload"); -// } + @Test + void testUnitInOperator() { + HashMap query = new HashMap<>(); + query.put("taxonomies.taxonomy_uid", new HashMap() {{ + put("$in", new String[]{"term_uid1", "term_uid2"}); + }}); + + taxonomy.query(query); + Request req = taxonomy.makeRequest().request(); + Assertions.assertEquals(3, req.headers().size()); + Assertions.assertEquals("GET", req.method().toString(), "test method are being passed though payload"); + Assertions.assertEquals("cdn.contentstack.io", req.url().host()); + Assertions.assertNull(req.url().encodedFragment(), "We do not expect any fragment"); + Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); + Assertions.assertEquals(3, Arrays.stream(req.url().encodedPathSegments().stream().toArray()).count()); + Assertions.assertNotNull( req.url().query()); + Assertions.assertNotNull(req.url().encodedQuery()); + Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); + } + + @Test + void testUnitOrOperator() { + HashMap query = new HashMap<>(); + query.put("taxonomies.taxonomy_uid", new HashMap() {{ + put("$in", new String[]{"term_uid1", "term_uid2"}); + }}); + + taxonomy.query(query); + Request req = taxonomy.makeRequest().request(); + Assertions.assertEquals(3, req.headers().size()); + Assertions.assertEquals("GET", req.method().toString(), "test method are being passed though payload"); + Assertions.assertEquals("cdn.contentstack.io", req.url().host()); + Assertions.assertNull(req.url().encodedFragment(), "We do not expect any fragment"); + Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); + Assertions.assertEquals(3, Arrays.stream(req.url().encodedPathSegments().stream().toArray()).count()); + Assertions.assertNotNull( req.url().query()); + Assertions.assertNotNull(req.url().encodedQuery()); + Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); + } + + + + + } From fe28d6d8a7b4591557535404249ad68ebf04d88e Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 14 Dec 2023 00:03:18 +0530 Subject: [PATCH 097/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- .../java/com/contentstack/sdk/Taxonomy.java | 74 ++++++++++++++++++- .../com/contentstack/sdk/TaxonomyTest.java | 55 +++++++++----- 2 files changed, 111 insertions(+), 18 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/Taxonomy.java b/src/main/java/com/contentstack/sdk/Taxonomy.java index 68866b6c..708759cc 100644 --- a/src/main/java/com/contentstack/sdk/Taxonomy.java +++ b/src/main/java/com/contentstack/sdk/Taxonomy.java @@ -2,12 +2,14 @@ import okhttp3.Request; import okhttp3.ResponseBody; +import org.jetbrains.annotations.NotNull; import retrofit2.Call; import retrofit2.Response; import java.io.IOException; import java.util.HashMap; import java.util.LinkedHashMap; +import java.util.List; import java.util.Map; /** @@ -86,7 +88,75 @@ public Taxonomy(APIService service, Config config, LinkedHashMap * @return instance of {@link Taxonomy} */ public Taxonomy query(Map queryParams) { - query.putAll(queryParams); + this.query.putAll(queryParams); + return this; + } + + + /** + * Get all entries for a specific taxonomy that satisfy the given conditions provided in the query. + * + * @param key the key of the taxonomy to query + * @param listOfItems the list of taxonomy fields + * Example: If you want to retrieve entries with the color taxonomy applied and linked to the term red and/or yellow. + * + * String key = "taxonomies.taxonomy_uid"; + * String[] listOfItem = {"term_uid1", "term_uid2"}; + * taxonomy.in(key, listOfItem); + * taxonomy.query(query).find(new TaxonomyCallback() { + * @Override public void onFailure(Request request, ResponseBody errorMessage) { + * System.out.println("Failing API call : " + errorMessage.toString()); + *

+ * } + * @Override public void onResponse(ResponseBody response) { + * System.out.println("Response : " + response.toString()); + *

+ * } + * }); + * + */ + public Taxonomy in(@NotNull String key, @NotNull String[] listOfItems) { + HashMap param = new HashMap<>(); + param.put("$in", listOfItems); + this.query.put(key, param); + return this; + } + + + public Taxonomy or(@NotNull List> listOfItems) { + for (int i = 0; i < listOfItems.size(); i++) { + HashMap param = listOfItems.get(i); + + if (i > 0) { + this.query.put("$or", listOfItems.toArray()); + } + + this.query.put("$or", param); + } + + return this; + } + + + public Taxonomy and(@NotNull List> listOfItems) { + for (int i = 0; i < listOfItems.size(); i++) { + HashMap param = listOfItems.get(i); + + if (i > 0) { + this.query.put("$and", listOfItems.toArray()); + } + + this.query.put("$and", param); + } + + return this; + } + + + public Taxonomy exists(@NotNull String name, @NotNull Boolean value) { + HashMap param = new HashMap<>(); + param.put("$exists", value); + this.query.put(name, param); return this; } @@ -120,6 +190,8 @@ public void find(TaxonomyCallback callback) { throw new RuntimeException(e); } } + + } diff --git a/src/test/java/com/contentstack/sdk/TaxonomyTest.java b/src/test/java/com/contentstack/sdk/TaxonomyTest.java index f059a5a1..fec99319 100644 --- a/src/test/java/com/contentstack/sdk/TaxonomyTest.java +++ b/src/test/java/com/contentstack/sdk/TaxonomyTest.java @@ -1,20 +1,24 @@ package com.contentstack.sdk; -import okhttp3.*; +import okhttp3.Request; +import okhttp3.ResponseBody; +import org.json.JSONObject; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; +import java.util.ArrayList; import java.util.Arrays; import java.util.HashMap; +import java.util.List; public class TaxonomyTest { - private final Taxonomy taxonomy = Credentials.getStack().taxonomy(); + private final Stack stack = Credentials.getStack(); @Test void testInstance() { - Assertions.assertNotNull(taxonomy); + Assertions.assertNotNull(stack); } @Test @@ -24,16 +28,16 @@ void testInOperator() { put("$in", new String[]{"term_uid1", "term_uid2"}); }}); - taxonomy.query(query).find(new TaxonomyCallback() { + stack.taxonomy().query(query).find(new TaxonomyCallback() { @Override public void onFailure(Request request, ResponseBody errorMessage) { - System.out.println("Failing API call : "+errorMessage.toString()); + System.out.println("Failing API call : " + errorMessage.toString()); } @Override public void onResponse(ResponseBody response) { - System.out.println("Response : "+response.toString()); + System.out.println("Response : " + response.toString()); } }); @@ -46,7 +50,7 @@ void testUnitInOperator() { query.put("taxonomies.taxonomy_uid", new HashMap() {{ put("$in", new String[]{"term_uid1", "term_uid2"}); }}); - + Taxonomy taxonomy = stack.taxonomy(); taxonomy.query(query); Request req = taxonomy.makeRequest().request(); Assertions.assertEquals(3, req.headers().size()); @@ -55,19 +59,17 @@ void testUnitInOperator() { Assertions.assertNull(req.url().encodedFragment(), "We do not expect any fragment"); Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); Assertions.assertEquals(3, Arrays.stream(req.url().encodedPathSegments().stream().toArray()).count()); - Assertions.assertNotNull( req.url().query()); + Assertions.assertNotNull(req.url().query()); Assertions.assertNotNull(req.url().encodedQuery()); Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); } @Test - void testUnitOrOperator() { - HashMap query = new HashMap<>(); - query.put("taxonomies.taxonomy_uid", new HashMap() {{ - put("$in", new String[]{"term_uid1", "term_uid2"}); - }}); - - taxonomy.query(query); + void testUnitINOperator() { + Taxonomy taxonomy = stack.taxonomy(); + String key = "taxonomies.taxonomy_uid"; + String[] listOfItem = {"term_uid1", "term_uid2"}; + taxonomy.in(key, listOfItem); Request req = taxonomy.makeRequest().request(); Assertions.assertEquals(3, req.headers().size()); Assertions.assertEquals("GET", req.method().toString(), "test method are being passed though payload"); @@ -75,15 +77,34 @@ void testUnitOrOperator() { Assertions.assertNull(req.url().encodedFragment(), "We do not expect any fragment"); Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); Assertions.assertEquals(3, Arrays.stream(req.url().encodedPathSegments().stream().toArray()).count()); - Assertions.assertNotNull( req.url().query()); + Assertions.assertNotNull(req.url().query()); Assertions.assertNotNull(req.url().encodedQuery()); Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); } + @Test + void testUnitOr() { + Taxonomy taxonomy = stack.taxonomy(); + List> listOfItems = new ArrayList<>(); + HashMap items = new HashMap<>(); + items.put("taxonomies.taxonomy_uid_1", "term_uid1"); + items.put("taxonomies.taxonomy_uid_2", "term_uid2"); + listOfItems.add(items); - + taxonomy.or(listOfItems); + Request req = taxonomy.makeRequest().request(); + Assertions.assertEquals(3, req.headers().size()); + Assertions.assertEquals("GET", req.method().toString(), "test method are being passed though payload"); + Assertions.assertEquals("cdn.contentstack.io", req.url().host()); + Assertions.assertNull(req.url().encodedFragment(), "We do not expect any fragment"); + Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); + Assertions.assertEquals(3, Arrays.stream(req.url().encodedPathSegments().stream().toArray()).count()); + Assertions.assertNotNull(req.url().query()); + Assertions.assertNotNull(req.url().encodedQuery()); + Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); + } } From f521de83783cb716c7da4868df3aec7e4ad30293 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Thu, 14 Dec 2023 19:04:30 +0530 Subject: [PATCH 098/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- .../java/com/contentstack/sdk/APIService.java | 2 +- .../java/com/contentstack/sdk/Taxonomy.java | 309 +++++++++++++----- .../com/contentstack/sdk/Credentials.java | 1 - .../com/contentstack/sdk/TaxonomyTest.java | 139 ++++---- 4 files changed, 297 insertions(+), 154 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/APIService.java b/src/main/java/com/contentstack/sdk/APIService.java index e178b7af..a14af8e5 100644 --- a/src/main/java/com/contentstack/sdk/APIService.java +++ b/src/main/java/com/contentstack/sdk/APIService.java @@ -23,5 +23,5 @@ Call getRequest( @GET("v3/taxonomies/entries") Call getTaxonomy( @HeaderMap Map headers, - @QueryMap(encoded = true) Map query); + @QueryMap Map query); } diff --git a/src/main/java/com/contentstack/sdk/Taxonomy.java b/src/main/java/com/contentstack/sdk/Taxonomy.java index 708759cc..207607f9 100644 --- a/src/main/java/com/contentstack/sdk/Taxonomy.java +++ b/src/main/java/com/contentstack/sdk/Taxonomy.java @@ -7,10 +7,8 @@ import retrofit2.Response; import java.io.IOException; -import java.util.HashMap; -import java.util.LinkedHashMap; -import java.util.List; -import java.util.Map; +import java.util.*; +import java.util.stream.Collectors; /** * The type Taxonomy. @@ -38,134 +36,265 @@ public Taxonomy(APIService service, Config config, LinkedHashMap this.config = config; } + /** - * You can retrieve filtered entries using taxonomy through two different endpoints: - * - * @param queryParams the query parameters should be like below - *

    - *
  • IN Operator : Get all entries for a specific taxonomy that satisfy the given conditions provided in the '$in' query.
    Your query should be as follows:
    {"taxonomies.taxonomy_uid" : { "$in" : ["term_uid1" , "term_uid2" ] }}

  • OR Operator : Get all entries for a specific taxonomy that satisfy at least one of the given conditions provided in the “$or” query.
    Your query should be as follows:
    query={ $or: [ { "taxonomies.taxonomy_uid_1" : "term_uid1" }, { "taxonomies.taxonomy_uid_2" : "term_uid2" } ] } - *
  • - *
    - *
  • - * AND Operator :
    - * Get all entries for a specific taxonomy that satisfy all the conditions provided in the “$and” query.
    - *

    - * Your query should be as follows:
    - * - * { - * $and: [ - * { "taxonomies.taxonomy_uid_1" : "term_uid1" }, - * { "taxonomies.taxonomy_uid_2" : "term_uid2" } - * ] - * } - * - * - *

  • - *
    - * - *
  • - * Exists Operator :
    - * Get all entries for a specific taxonomy that if the value of the field, mentioned in the condition, exists.
    - *

    - * Your query should be as follows: - * - * {"taxonomies.taxonomy_uid" : { "$exists": true }} - * - *


  • - *
  • - * Equal and Below Operator :
    - * Get all entries for a specific taxonomy that match a specific term and all its descendant terms, requiring only the target term and a specified level.
    - *

    - * Your query should be as follows: - * - * { - * "taxonomies.taxonomy_uid" : { "$eq_below": "term_uid", "level" : 2}} - * - *

  • - * - * - *
- * @return instance of {@link Taxonomy} + * Get all entries for a specific taxonomy that satisfy the given conditions provided in the '$in' query. + * Your query should be as follows: + *

+ *

+     * {"taxonomies.taxonomy_uid" : { "$in" : ["term_uid1" , "term_uid2" ] }}
+     * 
+ *

+ * Example: If you want to retrieve entries with the color taxonomy applied and linked to the term red and/or yellow. + *

+ *

+     * {"taxonomies.color" : { "$in" : ["red" , "yellow" ] }}
+     * 
+ * + * @param taxonomy the key of the taxonomy to query + * @param listOfItems the list of taxonomy fields + * @return an instance of the Taxonomy with the specified conditions added to the query */ - public Taxonomy query(Map queryParams) { - this.query.putAll(queryParams); + public Taxonomy in(String taxonomy, String[] listOfItems) { + String formattedValues = Arrays.stream(listOfItems).map(value -> "\"" + value.trim() + "\"").collect(Collectors.joining(" , ")); + + String stringify = "{ \"$in\" : [" + formattedValues + "] }}"; + this.query.put(taxonomy, stringify); return this; } /** - * Get all entries for a specific taxonomy that satisfy the given conditions provided in the query. - * - * @param key the key of the taxonomy to query - * @param listOfItems the list of taxonomy fields - * Example: If you want to retrieve entries with the color taxonomy applied and linked to the term red and/or yellow. - * - * String key = "taxonomies.taxonomy_uid"; - * String[] listOfItem = {"term_uid1", "term_uid2"}; - * taxonomy.in(key, listOfItem); - * taxonomy.query(query).find(new TaxonomyCallback() { - * @Override public void onFailure(Request request, ResponseBody errorMessage) { - * System.out.println("Failing API call : " + errorMessage.toString()); + * OR Operator : *

- * } - * @Override public void onResponse(ResponseBody response) { - * System.out.println("Response : " + response.toString()); + * Get all entries for a specific taxonomy that satisfy at least one of the given conditions provided in the “$or” query. *

- * } - * }); - * + * Your query should be as follows: + *

+ *

+     *
+     * { $or: [
+     * { "taxonomies.taxonomy_uid_1" : "term_uid1" },
+     * { "taxonomies.taxonomy_uid_2" : "term_uid2" }
+     * ]}
+     *
+     * 
+ * Example: If you want to retrieve entries with either the color or size taxonomy applied and linked to the terms yellow and small, respectively. + *
+ *
+     *
+     * {$or: [
+     * { "taxonomies.color" : "yellow" },
+     * { "taxonomies.size" : "small" }
+     * ]}
+     *
+     *
+     * 
+ * + * @param listOfItems + * @return */ - public Taxonomy in(@NotNull String key, @NotNull String[] listOfItems) { - HashMap param = new HashMap<>(); - param.put("$in", listOfItems); - this.query.put(key, param); - return this; - } - - public Taxonomy or(@NotNull List> listOfItems) { for (int i = 0; i < listOfItems.size(); i++) { HashMap param = listOfItems.get(i); - if (i > 0) { this.query.put("$or", listOfItems.toArray()); } - this.query.put("$or", param); } - return this; } + /** + * AND Operator : + *

+ * Get all entries for a specific taxonomy that satisfy all the conditions provided in the “$and” query. + *

+ * Your query should be as follows: + * + *

+     * {
+     * $and: [
+     * { "taxonomies.taxonomy_uid_1" : "term_uid1" },
+     * { "taxonomies.taxonomy_uid_2" : "term_uid2" }
+     * ]
+     * }
+     * 
+ * Example: If you want to retrieve entries with the color and computers taxonomies applied and linked to the terms red and laptop, respectively. + * + *
+     * {
+     * $and: [
+     * { "taxonomies.color" : "red" },
+     * { "taxonomies.computers" : "laptop" }
+     * ]
+     * }
+     * 
+ * + * @param listOfItems the list of items to that you want to include in the query string + * @return instance of the Taxonomy + */ public Taxonomy and(@NotNull List> listOfItems) { for (int i = 0; i < listOfItems.size(); i++) { HashMap param = listOfItems.get(i); - if (i > 0) { this.query.put("$and", listOfItems.toArray()); } - this.query.put("$and", param); } - return this; } - public Taxonomy exists(@NotNull String name, @NotNull Boolean value) { + /** + * Exists Operator : + *

+ * Get all entries for a specific taxonomy that if the value of the field, mentioned in the condition, exists. + *

+ * Your query should be as follows: + *

+     * {"taxonomies.taxonomy_uid" : { "$exists": true }}
+     * 
+ * Example: If you want to retrieve entries with the color taxonomy applied. + *
+     * {"taxonomies.color" : { "$exists": true }}
+     * 
+ * + * @param taxonomy the taxonomy + * @param value the value of the field + * @return instance of Taxonomy + */ + public Taxonomy exists(@NotNull String taxonomy, @NotNull Boolean value) { HashMap param = new HashMap<>(); param.put("$exists", value); - this.query.put(name, param); + this.query.put(taxonomy, param); return this; } + + /** + * Equal and Below Operator : + *

+ * Get all entries for a specific taxonomy that match a specific term and all its descendant terms, requiring only the target term and a specified level. + *

+ * Note: If you don't specify the level, the default behavior is to retrieve terms up to level 10. + * + *

{"taxonomies.taxonomy_uid" : { "$eq_below": "term_uid", "level" : 2}}
+ * + * Example: If you want to retrieve all entries with terms nested under blue, such as navy blue and sky blue, while also matching entries with the target term blue. + * + *
{"taxonomies.color" : { "$eq_below": "blue" }}
+ * + * @param taxonomy the taxonomy + * @param termsUid the term uid + * @return instance of Taxonomy + */ + public Taxonomy equalAndBelow(@NotNull String taxonomy, @NotNull String termsUid) { + HashMap param = new HashMap<>(); + param.put("$eq_below", termsUid); + this.query.put(taxonomy, param); + return this; + } + + /** + * Note: If you don't specify the level, the default behavior is to retrieve terms up to level 10. + * + * @param taxonomy the taxonomy + * @param termsUid the terms + * @param level the level to retrieve terms up to mentioned level + * @return instance of Taxonomy + */ + public Taxonomy equalAndBelowWithLevel(@NotNull String taxonomy, @NotNull String termsUid, @NotNull int level) { + Map innerMap = new HashMap<>(); + innerMap.put("$eq_below", termsUid + ", level: " + level); + this.query.put(taxonomy, innerMap); + return this; + } + + + /** + * Below Operator + *
+ *

+ * Get all entries for a specific taxonomy that match all of their descendant terms by specifying only the target term and a specific level. + *
+ * Note: If you don't specify the level, the default behavior is to retrieve terms up to level 10. + *
+ *

{"taxonomies.taxonomy_uid" : { "$below": "term_uid", "level" : 2}}
+ * + * Example: If you want to retrieve all entries containing terms nested under blue, such as navy blue and sky blue, but exclude entries that solely have the target term blue. + * + *
{"taxonomies.color" : { "$below": "blue" }}
+ * + * @param taxonomy the taxonomy + * @param termsUid the terms uid + * @return instance of Taxonomy + */ + public Taxonomy below(@NotNull String taxonomy, @NotNull String termsUid) { + HashMap param = new HashMap<>(); + param.put("$below", termsUid); + this.query.put(taxonomy, param); + return this; + } + + + /** + * Equal and Above Operator : + *

+ * Get all entries for a specific taxonomy that match a specific term and all its ancestor terms, requiring only the target term and a specified level. + * + * Note: If you don't specify the level, the default behavior is to retrieve terms up to level 10. + *

+ *

{"taxonomies.taxonomy_uid": { "$eq_above": "term_uid", "level": 2 }}
+ *

+ * Example: If you want to obtain all entries that include the term led and its parent term tv. + *

+ *

{"taxonomies.appliances": { "$eq_above": "led"}}
+ * + * @param taxonomy the taxonomy + * @param termUid the term uid + * @return instance of Taxonomy + */ + public Taxonomy equalAbove(@NotNull String taxonomy, @NotNull String termUid) { + Map innerMap = new HashMap<>(); + innerMap.put("$eq_above", termUid); + this.query.put(taxonomy, innerMap); + return this; + } + + + /** + * Above Operator : + *

+ * Get all entries for a specific taxonomy that match only the parent term(s) of a specified target term, excluding the target term itself. You can also specify a specific level. + *

+ * Note: If you don't specify the level, the default behavior is to retrieve terms up to level 10. + * + *

{ "taxonomies.taxonomy_uid": { "$above": "term_uid", "level": 2 }}
+ *

+ * Example: If you wish to match entries with the term tv but exclude the target term led. + * + *

{"taxonomies.appliances": { "$above": "led" }}
+ * + * @param taxonomy the taxonomy + * @param termUid the term uid + * @return instance of {@link Taxonomy} + */ + public Taxonomy above(@NotNull String taxonomy, @NotNull String termUid) { + Map innerMap = new HashMap<>(); + innerMap.put("$above", termUid); + this.query.put(taxonomy, innerMap); + return this; + } + + /** - * Make request call. + * To verify the payload * - * @return the call + * @return instance of Call */ - Call makeRequest() { + protected Call makeRequest() { HashMap map = new HashMap<>(); map.put("query", query); return this.service.getTaxonomy(this.headers, map); diff --git a/src/test/java/com/contentstack/sdk/Credentials.java b/src/test/java/com/contentstack/sdk/Credentials.java index 33d6e556..7a01db0f 100644 --- a/src/test/java/com/contentstack/sdk/Credentials.java +++ b/src/test/java/com/contentstack/sdk/Credentials.java @@ -71,7 +71,6 @@ public static Stack getStack() { Config config = new Config(); config.setHost(HOST); stack = Contentstack.stack(API_KEY, DELIVERY_TOKEN, ENVIRONMENT, config); - System.out.println(stack); } catch (IllegalAccessException e) { throw new RuntimeException(e); } diff --git a/src/test/java/com/contentstack/sdk/TaxonomyTest.java b/src/test/java/com/contentstack/sdk/TaxonomyTest.java index fec99319..91d5f5d6 100644 --- a/src/test/java/com/contentstack/sdk/TaxonomyTest.java +++ b/src/test/java/com/contentstack/sdk/TaxonomyTest.java @@ -1,13 +1,14 @@ package com.contentstack.sdk; +import okhttp3.HttpUrl; import okhttp3.Request; -import okhttp3.ResponseBody; -import org.json.JSONObject; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; +import java.io.UnsupportedEncodingException; +import java.net.URLDecoder; +import java.nio.charset.StandardCharsets; import java.util.ArrayList; -import java.util.Arrays; import java.util.HashMap; import java.util.List; @@ -22,88 +23,102 @@ void testInstance() { } @Test - void testInOperator() { - HashMap query = new HashMap<>(); - query.put("taxonomies.taxonomy_uid", new HashMap() {{ - put("$in", new String[]{"term_uid1", "term_uid2"}); - }}); - - stack.taxonomy().query(query).find(new TaxonomyCallback() { - @Override - public void onFailure(Request request, ResponseBody errorMessage) { - System.out.println("Failing API call : " + errorMessage.toString()); - - } - - @Override - public void onResponse(ResponseBody response) { - System.out.println("Response : " + response.toString()); - - } - }); - } - - - @Test - void testUnitInOperator() { - HashMap query = new HashMap<>(); - query.put("taxonomies.taxonomy_uid", new HashMap() {{ - put("$in", new String[]{"term_uid1", "term_uid2"}); - }}); + void operationIn() { Taxonomy taxonomy = stack.taxonomy(); - taxonomy.query(query); - Request req = taxonomy.makeRequest().request(); + String[] listOfItem = {"red", "yellow"}; + Request req = taxonomy.in("taxonomies.color", listOfItem).makeRequest().request(); + Assertions.assertEquals(3, req.headers().size()); - Assertions.assertEquals("GET", req.method().toString(), "test method are being passed though payload"); + Assertions.assertEquals("GET", req.method()); Assertions.assertEquals("cdn.contentstack.io", req.url().host()); - Assertions.assertNull(req.url().encodedFragment(), "We do not expect any fragment"); Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); - Assertions.assertEquals(3, Arrays.stream(req.url().encodedPathSegments().stream().toArray()).count()); - Assertions.assertNotNull(req.url().query()); - Assertions.assertNotNull(req.url().encodedQuery()); Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); } + @Test - void testUnitINOperator() { + void operationOr() { Taxonomy taxonomy = stack.taxonomy(); - String key = "taxonomies.taxonomy_uid"; - String[] listOfItem = {"term_uid1", "term_uid2"}; - taxonomy.in(key, listOfItem); + + List> listOfItems = new ArrayList<>(); + HashMap items = new HashMap<>(); + items.put("taxonomies.taxonomy_uid_1", "term_uid1"); + items.put("taxonomies.taxonomy_uid_2", "term_uid2"); + listOfItems.add(items); + taxonomy.or(listOfItems); Request req = taxonomy.makeRequest().request(); - Assertions.assertEquals(3, req.headers().size()); - Assertions.assertEquals("GET", req.method().toString(), "test method are being passed though payload"); - Assertions.assertEquals("cdn.contentstack.io", req.url().host()); - Assertions.assertNull(req.url().encodedFragment(), "We do not expect any fragment"); - Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); - Assertions.assertEquals(3, Arrays.stream(req.url().encodedPathSegments().stream().toArray()).count()); - Assertions.assertNotNull(req.url().query()); - Assertions.assertNotNull(req.url().encodedQuery()); + Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); + } + public static String decodeUrl(HttpUrl encodedUrl) { + String decodedUrl = null; + try { + decodedUrl = URLDecoder.decode(encodedUrl.toString(), StandardCharsets.UTF_8.toString()); + return decodedUrl; + } catch (UnsupportedEncodingException e) { + e.printStackTrace(); // Handle the exception according to your requirements + } + return decodedUrl; + } @Test - void testUnitOr() { + void operatorAnd() { Taxonomy taxonomy = stack.taxonomy(); - List> listOfItems = new ArrayList<>(); HashMap items = new HashMap<>(); items.put("taxonomies.taxonomy_uid_1", "term_uid1"); items.put("taxonomies.taxonomy_uid_2", "term_uid2"); listOfItems.add(items); + taxonomy.and(listOfItems); - taxonomy.or(listOfItems); Request req = taxonomy.makeRequest().request(); - Assertions.assertEquals(3, req.headers().size()); - Assertions.assertEquals("GET", req.method().toString(), "test method are being passed though payload"); - Assertions.assertEquals("cdn.contentstack.io", req.url().host()); - Assertions.assertNull(req.url().encodedFragment(), "We do not expect any fragment"); - Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); - Assertions.assertEquals(3, Arrays.stream(req.url().encodedPathSegments().stream().toArray()).count()); - Assertions.assertNotNull(req.url().query()); - Assertions.assertNotNull(req.url().encodedQuery()); - Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); + } + + + @Test + void operationExists() { + // create instance of taxonomy + Taxonomy taxonomy = stack.taxonomy().exists("listOfItems", true); + Request req = taxonomy.makeRequest().request(); + Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + } + + + @Test + void operationEqualAndBelow() { + // create instance of taxonomy + Taxonomy taxonomy = stack.taxonomy().equalAndBelow("listOfItems", "uid1"); + Request req = taxonomy.makeRequest().request(); + Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + } + + + @Test + void operationBelow() { + Taxonomy taxonomy = stack.taxonomy().equalAndBelowWithLevel("listOfItems", "uid1", 3); + Request req = taxonomy.makeRequest().request(); + Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + + } + + + @Test + void operationEqualAbove() { + Taxonomy taxonomy = stack.taxonomy().equalAbove("listOfItems", "uid1"); + Request req = taxonomy.makeRequest().request(); + Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + + } + + + @Test + void above() { + Taxonomy taxonomy = stack.taxonomy().above("listOfItems", "uid1"); + Request req = taxonomy.makeRequest().request(); + Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + } From 2343fb989e8cb76cbc3b1a28241b25f87291d2ab Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 15 Dec 2023 00:48:32 +0530 Subject: [PATCH 099/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- .../java/com/contentstack/sdk/APIService.java | 4 +- .../java/com/contentstack/sdk/Taxonomy.java | 102 ++++++++---------- .../contentstack/sdk/TaxonomyCallback.java | 19 ---- .../com/contentstack/sdk/TaxonomyTest.java | 85 +++++++-------- 4 files changed, 91 insertions(+), 119 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/APIService.java b/src/main/java/com/contentstack/sdk/APIService.java index a14af8e5..5bf3462b 100644 --- a/src/main/java/com/contentstack/sdk/APIService.java +++ b/src/main/java/com/contentstack/sdk/APIService.java @@ -4,7 +4,7 @@ import retrofit2.Call; import retrofit2.http.GET; import retrofit2.http.HeaderMap; -import retrofit2.http.QueryMap; +import retrofit2.http.Query; import retrofit2.http.Url; import java.util.LinkedHashMap; @@ -23,5 +23,5 @@ Call getRequest( @GET("v3/taxonomies/entries") Call getTaxonomy( @HeaderMap Map headers, - @QueryMap Map query); + @Query("query") String query); } diff --git a/src/main/java/com/contentstack/sdk/Taxonomy.java b/src/main/java/com/contentstack/sdk/Taxonomy.java index 207607f9..308f4188 100644 --- a/src/main/java/com/contentstack/sdk/Taxonomy.java +++ b/src/main/java/com/contentstack/sdk/Taxonomy.java @@ -1,36 +1,47 @@ package com.contentstack.sdk; -import okhttp3.Request; import okhttp3.ResponseBody; import org.jetbrains.annotations.NotNull; +import org.json.JSONObject; import retrofit2.Call; -import retrofit2.Response; import java.io.IOException; -import java.util.*; -import java.util.stream.Collectors; +import java.util.LinkedHashMap; +import java.util.List; /** - * The type Taxonomy. - * - * @author Shailesh Mishra
Taxonomy :

Taxonomy, currently in the Early Access Phase simplifies the process of organizing content in your system, making it effortless to find and retrieve information. + * @author Shailesh Mishra + *
+ * Taxonomy : + * Taxonomy, currently in the Early Access Phase simplifies + * the process of organizing content in your system, making + * it effortless to find and retrieve information. + * @implSpec To implement the taxonomy use below code + *

+ *     {@code
+ *     Stack stack = Contentstack.stack("API_KEY", "DELIVERY_TOKEN", "ENVIRONMENT");
+ *     Taxonomy taxonomy = stack.taxonomy()
+ *     }
+ * 
+ * @see headers; protected APIService service; - protected HashMap query = new HashMap<>(); + protected JSONObject query = new JSONObject(); protected Config config; /** * Instantiates a new Taxonomy. * - * @param service the service - * @param config the config - * @param headers the headers + * @param service the service of type {@link APIService} + * @param config the config of type {@link Config} + * @param headers the headers of the {@link LinkedHashMap} */ - public Taxonomy(APIService service, Config config, LinkedHashMap headers) { + protected Taxonomy(APIService service, Config config, LinkedHashMap headers) { this.service = service; this.headers = headers; this.config = config; @@ -55,11 +66,10 @@ public Taxonomy(APIService service, Config config, LinkedHashMap * @param listOfItems the list of taxonomy fields * @return an instance of the Taxonomy with the specified conditions added to the query */ - public Taxonomy in(String taxonomy, String[] listOfItems) { - String formattedValues = Arrays.stream(listOfItems).map(value -> "\"" + value.trim() + "\"").collect(Collectors.joining(" , ")); - - String stringify = "{ \"$in\" : [" + formattedValues + "] }}"; - this.query.put(taxonomy, stringify); + public Taxonomy in(String taxonomy, List listOfItems) { + JSONObject innerObj = new JSONObject(); + innerObj.put("$in", listOfItems); + this.query.put(taxonomy, innerObj); return this; } @@ -79,29 +89,22 @@ public Taxonomy in(String taxonomy, String[] listOfItems) { * ]} * * - * Example: If you want to retrieve entries with either the color or size taxonomy applied and linked to the terms yellow and small, respectively. + * Example: If you want to retrieve entries with either the color or size taxonomy applied and linked to the terms yellow and small, respectively. *
*
      *
-     * {$or: [
+     * { $or: [
      * { "taxonomies.color" : "yellow" },
      * { "taxonomies.size" : "small" }
      * ]}
      *
-     *
      * 
* - * @param listOfItems - * @return + * @param listOfItems the list of items + * @return instance {@link Taxonomy} */ - public Taxonomy or(@NotNull List> listOfItems) { - for (int i = 0; i < listOfItems.size(); i++) { - HashMap param = listOfItems.get(i); - if (i > 0) { - this.query.put("$or", listOfItems.toArray()); - } - this.query.put("$or", param); - } + public Taxonomy or(@NotNull List listOfItems) { + this.query.put("$or", listOfItems); return this; } @@ -135,14 +138,8 @@ public Taxonomy or(@NotNull List> listOfItems) { * @param listOfItems the list of items to that you want to include in the query string * @return instance of the Taxonomy */ - public Taxonomy and(@NotNull List> listOfItems) { - for (int i = 0; i < listOfItems.size(); i++) { - HashMap param = listOfItems.get(i); - if (i > 0) { - this.query.put("$and", listOfItems.toArray()); - } - this.query.put("$and", param); - } + public Taxonomy and(@NotNull List listOfItems) { + this.query.put("$and", listOfItems.toString()); return this; } @@ -166,9 +163,9 @@ public Taxonomy and(@NotNull List> listOfItems) { * @return instance of Taxonomy */ public Taxonomy exists(@NotNull String taxonomy, @NotNull Boolean value) { - HashMap param = new HashMap<>(); - param.put("$exists", value); - this.query.put(taxonomy, param); + JSONObject json = new JSONObject(); + json.put("$exists", value); + this.query.put(taxonomy, json); return this; } @@ -191,7 +188,7 @@ public Taxonomy exists(@NotNull String taxonomy, @NotNull Boolean value) { * @return instance of Taxonomy */ public Taxonomy equalAndBelow(@NotNull String taxonomy, @NotNull String termsUid) { - HashMap param = new HashMap<>(); + JSONObject param = new JSONObject(); param.put("$eq_below", termsUid); this.query.put(taxonomy, param); return this; @@ -206,7 +203,7 @@ public Taxonomy equalAndBelow(@NotNull String taxonomy, @NotNull String termsUid * @return instance of Taxonomy */ public Taxonomy equalAndBelowWithLevel(@NotNull String taxonomy, @NotNull String termsUid, @NotNull int level) { - Map innerMap = new HashMap<>(); + JSONObject innerMap = new JSONObject(); innerMap.put("$eq_below", termsUid + ", level: " + level); this.query.put(taxonomy, innerMap); return this; @@ -232,7 +229,7 @@ public Taxonomy equalAndBelowWithLevel(@NotNull String taxonomy, @NotNull String * @return instance of Taxonomy */ public Taxonomy below(@NotNull String taxonomy, @NotNull String termsUid) { - HashMap param = new HashMap<>(); + JSONObject param = new JSONObject(); param.put("$below", termsUid); this.query.put(taxonomy, param); return this; @@ -257,7 +254,7 @@ public Taxonomy below(@NotNull String taxonomy, @NotNull String termsUid) { * @return instance of Taxonomy */ public Taxonomy equalAbove(@NotNull String taxonomy, @NotNull String termUid) { - Map innerMap = new HashMap<>(); + JSONObject innerMap = new JSONObject(); innerMap.put("$eq_above", termUid); this.query.put(taxonomy, innerMap); return this; @@ -282,7 +279,7 @@ public Taxonomy equalAbove(@NotNull String taxonomy, @NotNull String termUid) { * @return instance of {@link Taxonomy} */ public Taxonomy above(@NotNull String taxonomy, @NotNull String termUid) { - Map innerMap = new HashMap<>(); + JSONObject innerMap = new JSONObject(); innerMap.put("$above", termUid); this.query.put(taxonomy, innerMap); return this; @@ -295,9 +292,7 @@ public Taxonomy above(@NotNull String taxonomy, @NotNull String termUid) { * @return instance of Call */ protected Call makeRequest() { - HashMap map = new HashMap<>(); - map.put("query", query); - return this.service.getTaxonomy(this.headers, map); + return this.service.getTaxonomy(this.headers, this.query.toString()); } @@ -308,13 +303,8 @@ protected Call makeRequest() { */ public void find(TaxonomyCallback callback) { try { - Response response = makeRequest().execute(); - if (response.isSuccessful()) { - callback.onResponse(response.body()); - } else { - Request request = makeRequest().request(); - callback.onFailure(request, response.errorBody()); - } + ResponseBody response = makeRequest().execute().body(); + callback.onResponse(response); } catch (IOException e) { throw new RuntimeException(e); } diff --git a/src/main/java/com/contentstack/sdk/TaxonomyCallback.java b/src/main/java/com/contentstack/sdk/TaxonomyCallback.java index 3de08db1..2a52fa89 100644 --- a/src/main/java/com/contentstack/sdk/TaxonomyCallback.java +++ b/src/main/java/com/contentstack/sdk/TaxonomyCallback.java @@ -1,28 +1,9 @@ package com.contentstack.sdk; -import okhttp3.Request; import okhttp3.ResponseBody; public interface TaxonomyCallback { - /** - * Called when the HTTP response was successfully returned by the remote server. The callback may - * proceed to read the response body. The response is still live until - * its response body is {@linkplain ResponseBody closed}. The recipient of the callback may - * consume the response body on another thread. - * - *

Note that transport-layer success (receiving a HTTP response code, headers and body) does - * not necessarily indicate application-layer success: {@code response} may still indicate an - * unhappy HTTP response code like 404 or 500. - */ void onResponse(ResponseBody response); - /** - * Called when the request could not be executed due to cancellation, a connectivity problem or - * timeout. Because networks can fail during an exchange, it is possible that the remote server - * accepted the request before the failure. - */ - void onFailure(Request request, ResponseBody errorMessage); - - } \ No newline at end of file diff --git a/src/test/java/com/contentstack/sdk/TaxonomyTest.java b/src/test/java/com/contentstack/sdk/TaxonomyTest.java index 91d5f5d6..e945348e 100644 --- a/src/test/java/com/contentstack/sdk/TaxonomyTest.java +++ b/src/test/java/com/contentstack/sdk/TaxonomyTest.java @@ -1,15 +1,11 @@ package com.contentstack.sdk; -import okhttp3.HttpUrl; import okhttp3.Request; +import org.json.JSONObject; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import java.io.UnsupportedEncodingException; -import java.net.URLDecoder; -import java.nio.charset.StandardCharsets; import java.util.ArrayList; -import java.util.HashMap; import java.util.List; @@ -25,99 +21,104 @@ void testInstance() { @Test void operationIn() { Taxonomy taxonomy = stack.taxonomy(); - String[] listOfItem = {"red", "yellow"}; - Request req = taxonomy.in("taxonomies.color", listOfItem).makeRequest().request(); - + List listOfItems = new ArrayList<>(); + listOfItems.add("red"); + listOfItems.add("yellow"); + Request req = taxonomy.in("taxonomies.color", listOfItems).makeRequest().request(); Assertions.assertEquals(3, req.headers().size()); Assertions.assertEquals("GET", req.method()); Assertions.assertEquals("cdn.contentstack.io", req.url().host()); Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); - Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); + Assertions.assertEquals("query={\"taxonomies.color\":{\"$in\":[\"red\",\"yellow\"]}}", req.url().query()); } @Test void operationOr() { + +// query={ $or: [ +// { "taxonomies.taxonomy_uid_1" : "term_uid1" }, +// { "taxonomies.taxonomy_uid_2" : "term_uid2" } +// ]} + Taxonomy taxonomy = stack.taxonomy(); - List> listOfItems = new ArrayList<>(); - HashMap items = new HashMap<>(); - items.put("taxonomies.taxonomy_uid_1", "term_uid1"); - items.put("taxonomies.taxonomy_uid_2", "term_uid2"); - listOfItems.add(items); + List listOfItems = new ArrayList<>(); + JSONObject item1 = new JSONObject(); + item1.put("taxonomies.color", "yellow"); + JSONObject item2 = new JSONObject(); + item2.put("taxonomies.size", "small"); + listOfItems.add(item1); + listOfItems.add(item2); taxonomy.or(listOfItems); Request req = taxonomy.makeRequest().request(); - Assertions.assertEquals("[query]", req.url().queryParameterNames().toString()); - - } + Assertions.assertEquals("query={\"$or\":[{\"taxonomies.color\":\"yellow\"},{\"taxonomies.size\":\"small\"}]}", req.url().query()); - public static String decodeUrl(HttpUrl encodedUrl) { - String decodedUrl = null; - try { - decodedUrl = URLDecoder.decode(encodedUrl.toString(), StandardCharsets.UTF_8.toString()); - return decodedUrl; - } catch (UnsupportedEncodingException e) { - e.printStackTrace(); // Handle the exception according to your requirements - } - return decodedUrl; } @Test void operatorAnd() { Taxonomy taxonomy = stack.taxonomy(); - List> listOfItems = new ArrayList<>(); - HashMap items = new HashMap<>(); - items.put("taxonomies.taxonomy_uid_1", "term_uid1"); - items.put("taxonomies.taxonomy_uid_2", "term_uid2"); - listOfItems.add(items); + List listOfItems = new ArrayList<>(); + JSONObject items1 = new JSONObject(); + items1.put("taxonomies.color", "green"); + JSONObject items2 = new JSONObject(); + items2.put("taxonomies.computers", "laptop"); + listOfItems.add(items1); + listOfItems.add(items2); taxonomy.and(listOfItems); + // {$and: [{"taxonomies.color" : "green" }, { "taxonomies.computers" : "laptop" }]} Request req = taxonomy.makeRequest().request(); + Assertions.assertEquals("query={\"$and\":\"[{\\\"taxonomies.color\\\":\\\"green\\\"}, {\\\"taxonomies.computers\\\":\\\"laptop\\\"}]\"}", req.url().query()); } @Test void operationExists() { // create instance of taxonomy - Taxonomy taxonomy = stack.taxonomy().exists("listOfItems", true); + Taxonomy taxonomy = stack.taxonomy().exists("taxonomies.color", true); Request req = taxonomy.makeRequest().request(); - Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + //{"taxonomies.color" : { "$exists": true }} + //{"taxonomies.color":{"$exists":true}} + Assertions.assertEquals("query={\"taxonomies.color\":{\"$exists\":true}}", req.url().query()); } @Test void operationEqualAndBelow() { // create instance of taxonomy - Taxonomy taxonomy = stack.taxonomy().equalAndBelow("listOfItems", "uid1"); + Taxonomy taxonomy = stack.taxonomy().equalAndBelow("taxonomies.color", "blue"); Request req = taxonomy.makeRequest().request(); - Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + // {"taxonomies.color" : { "$eq_below": "blue" }} + Assertions.assertEquals("query={\"taxonomies.color\":{\"$eq_below\":\"blue\"}}", req.url().query()); } @Test - void operationBelow() { - Taxonomy taxonomy = stack.taxonomy().equalAndBelowWithLevel("listOfItems", "uid1", 3); + void operationBelowWithLevel() { + Taxonomy taxonomy = stack.taxonomy().equalAndBelowWithLevel("taxonomies.color", "blue", 3); Request req = taxonomy.makeRequest().request(); - Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + Assertions.assertEquals("query={\"taxonomies.color\":{\"$eq_below\":\"blue, level: 3\"}}", req.url().query()); } @Test void operationEqualAbove() { - Taxonomy taxonomy = stack.taxonomy().equalAbove("listOfItems", "uid1"); + Taxonomy taxonomy = stack.taxonomy().equalAbove("taxonomies.appliances", "led"); Request req = taxonomy.makeRequest().request(); - Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + Assertions.assertEquals("query={\"taxonomies.appliances\":{\"$eq_above\":\"led\"}}", req.url().query()); } @Test void above() { - Taxonomy taxonomy = stack.taxonomy().above("listOfItems", "uid1"); + Taxonomy taxonomy = stack.taxonomy().above("taxonomies.appliances", "led"); Request req = taxonomy.makeRequest().request(); - Assertions.assertEquals("query={$or={taxonomies.taxonomy_uid_2=term_uid2, taxonomies.taxonomy_uid_1=term_uid1}}", req.url().query()); + Assertions.assertEquals("query={\"taxonomies.appliances\":{\"$above\":\"led\"}}", req.url().query()); } From 5539c4efb9e1b38189bec8e2e13d07f1689fd51a Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 15 Dec 2023 01:15:04 +0530 Subject: [PATCH 100/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- .../com/contentstack/sdk/CSHttpConnection.java | 1 - .../java/com/contentstack/sdk/Taxonomy.java | 18 ++++++++++++++++-- .../com/contentstack/sdk/TaxonomyCallback.java | 3 ++- .../com/contentstack/sdk/TaxonomyTest.java | 12 +++++++++++- 4 files changed, 29 insertions(+), 5 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/CSHttpConnection.java b/src/main/java/com/contentstack/sdk/CSHttpConnection.java index 1bae8449..9eda41c0 100644 --- a/src/main/java/com/contentstack/sdk/CSHttpConnection.java +++ b/src/main/java/com/contentstack/sdk/CSHttpConnection.java @@ -261,7 +261,6 @@ void handleJSONObject(JSONArray arrayEntry, JSONObject jsonObj, int idx) { } void setError(String errResp) { - logger.info(errResp); responseJSON = new JSONObject(errResp); // Parse error string to JSONObject responseJSON.put(ERROR_MESSAGE, responseJSON.optString(ERROR_MESSAGE)); responseJSON.put(ERROR_CODE, responseJSON.optString(ERROR_CODE)); diff --git a/src/main/java/com/contentstack/sdk/Taxonomy.java b/src/main/java/com/contentstack/sdk/Taxonomy.java index 308f4188..cdb7da2e 100644 --- a/src/main/java/com/contentstack/sdk/Taxonomy.java +++ b/src/main/java/com/contentstack/sdk/Taxonomy.java @@ -4,6 +4,7 @@ import org.jetbrains.annotations.NotNull; import org.json.JSONObject; import retrofit2.Call; +import retrofit2.Response; import java.io.IOException; import java.util.LinkedHashMap; @@ -303,8 +304,21 @@ protected Call makeRequest() { */ public void find(TaxonomyCallback callback) { try { - ResponseBody response = makeRequest().execute().body(); - callback.onResponse(response); + Response response = makeRequest().execute(); + + if (response.isSuccessful()) { + JSONObject responseJSON = new JSONObject(response.body().string()); + callback.onResponse(responseJSON, null); + } else { + JSONObject responseJSON = new JSONObject(response.errorBody().string()); + Error error = new Error(); + error.setErrorMessage(responseJSON.optString("error_message")); + error.setErrorCode(responseJSON.optInt("error_code")); + error.setErrorDetail(responseJSON.optString("errors")); + + callback.onResponse(null, error); + } + } catch (IOException e) { throw new RuntimeException(e); } diff --git a/src/main/java/com/contentstack/sdk/TaxonomyCallback.java b/src/main/java/com/contentstack/sdk/TaxonomyCallback.java index 2a52fa89..8bf88217 100644 --- a/src/main/java/com/contentstack/sdk/TaxonomyCallback.java +++ b/src/main/java/com/contentstack/sdk/TaxonomyCallback.java @@ -1,9 +1,10 @@ package com.contentstack.sdk; import okhttp3.ResponseBody; +import org.json.JSONObject; public interface TaxonomyCallback { - void onResponse(ResponseBody response); + void onResponse(JSONObject response, Error error); } \ No newline at end of file diff --git a/src/test/java/com/contentstack/sdk/TaxonomyTest.java b/src/test/java/com/contentstack/sdk/TaxonomyTest.java index e945348e..126e57d9 100644 --- a/src/test/java/com/contentstack/sdk/TaxonomyTest.java +++ b/src/test/java/com/contentstack/sdk/TaxonomyTest.java @@ -1,6 +1,7 @@ package com.contentstack.sdk; import okhttp3.Request; +import okhttp3.ResponseBody; import org.json.JSONObject; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; @@ -25,7 +26,7 @@ void operationIn() { listOfItems.add("red"); listOfItems.add("yellow"); Request req = taxonomy.in("taxonomies.color", listOfItems).makeRequest().request(); - Assertions.assertEquals(3, req.headers().size()); + //Assertions.assertEquals(3, req.headers().size()); Assertions.assertEquals("GET", req.method()); Assertions.assertEquals("cdn.contentstack.io", req.url().host()); Assertions.assertEquals("/v3/taxonomies/entries", req.url().encodedPath()); @@ -119,7 +120,16 @@ void above() { Taxonomy taxonomy = stack.taxonomy().above("taxonomies.appliances", "led"); Request req = taxonomy.makeRequest().request(); Assertions.assertEquals("query={\"taxonomies.appliances\":{\"$above\":\"led\"}}", req.url().query()); + } + @Test + void aboveAPI() { + Taxonomy taxonomy = stack.taxonomy().above("taxonomies.appliances", "led"); + taxonomy.find((response, error) -> { + System.out.println("Successful: " + response); + System.out.println("Error: " + error.errorMessage); + }); + //Assertions.assertEquals("query={\"taxonomies.appliances\":{\"$above\":\"led\"}}", req.url().query()); } From 5c0bf304b3dff112650e754bbd03292fb8326bb7 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 15 Dec 2023 12:59:17 +0530 Subject: [PATCH 101/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- .../java/com/contentstack/sdk/Constants.java | 2 -- .../java/com/contentstack/sdk/Credentials.java | 16 +--------------- 2 files changed, 1 insertion(+), 17 deletions(-) diff --git a/src/main/java/com/contentstack/sdk/Constants.java b/src/main/java/com/contentstack/sdk/Constants.java index 6a31923d..24917225 100644 --- a/src/main/java/com/contentstack/sdk/Constants.java +++ b/src/main/java/com/contentstack/sdk/Constants.java @@ -26,8 +26,6 @@ public class Constants { protected static final String CONTENT_TYPE_UID = "content_type_uid"; protected static final String ENTRY_UID = "entry_uid"; protected static final String LIVE_PREVIEW = "live_preview"; - - protected static final String TaxonomyPath = "/taxonomies/entries?query"; protected static final String SYNCHRONISATION = "stacks/sync"; // Errors protected static final String ERROR_CODE = "error_code"; diff --git a/src/test/java/com/contentstack/sdk/Credentials.java b/src/test/java/com/contentstack/sdk/Credentials.java index 7a01db0f..ea94a290 100644 --- a/src/test/java/com/contentstack/sdk/Credentials.java +++ b/src/test/java/com/contentstack/sdk/Credentials.java @@ -13,18 +13,13 @@ public class Credentials { private static String envChecker() { String githubActions = System.getenv("GITHUB_ACTIONS"); if (githubActions != null && githubActions.equals("true")) { - System.out.println("Tests are running in GitHub Actions environment."); - String mySecretKey = System.getenv("API_KEY"); return "GitHub"; } else { - System.out.println("Tests are running in a local environment."); return "local"; } } public static Dotenv getEnv() { - String currentDirectory = System.getProperty("user.dir"); - File envFile = new File(currentDirectory, "env"); env = Dotenv.configure() .directory("src/test/resources") .filename("env") // instead of '.env', use 'env' @@ -32,15 +27,7 @@ public static Dotenv getEnv() { try { env = Dotenv.load(); } catch (DotenvException ex) { - System.out.println("Could not load from local .env"); -// File envFile = new File(currentDirectory, ".env"); -// try { -// // Create .env file in the current directory -// envFile.createNewFile(); -// } catch (IOException e) { -// System.err.println("An error occurred while creating .env file."); -// e.printStackTrace(); -// } + System.out.println("Could not load.env"); } return env; } @@ -64,7 +51,6 @@ private Credentials() throws AccessException { public static Stack getStack() { if (stack == null) { var envCheck = envChecker(); - System.out.println("idendified env file detected " + envCheck); synchronized (Credentials.class) { if (stack == null) { try { From 5af4976c30fd14710abebc3df1b3cf8c56d0af75 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 15 Dec 2023 13:24:47 +0530 Subject: [PATCH 102/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- src/test/java/com/contentstack/sdk/Credentials.java | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/src/test/java/com/contentstack/sdk/Credentials.java b/src/test/java/com/contentstack/sdk/Credentials.java index ea94a290..ee5ab196 100644 --- a/src/test/java/com/contentstack/sdk/Credentials.java +++ b/src/test/java/com/contentstack/sdk/Credentials.java @@ -2,9 +2,7 @@ import io.github.cdimascio.dotenv.Dotenv; import io.github.cdimascio.dotenv.DotenvException; -import lombok.var; -import java.io.File; import java.rmi.AccessException; public class Credentials { @@ -27,7 +25,7 @@ public static Dotenv getEnv() { try { env = Dotenv.load(); } catch (DotenvException ex) { - System.out.println("Could not load.env"); + ex.getLocalizedMessage(); } return env; } @@ -50,7 +48,7 @@ private Credentials() throws AccessException { public static Stack getStack() { if (stack == null) { - var envCheck = envChecker(); + envChecker(); synchronized (Credentials.class) { if (stack == null) { try { From 74b6813ce3b198236539eb1a4330ba6a7651935a Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 15 Dec 2023 13:27:41 +0530 Subject: [PATCH 103/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- src/test/java/com/contentstack/sdk/TestAsset.java | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/test/java/com/contentstack/sdk/TestAsset.java b/src/test/java/com/contentstack/sdk/TestAsset.java index accc173f..2f77679e 100644 --- a/src/test/java/com/contentstack/sdk/TestAsset.java +++ b/src/test/java/com/contentstack/sdk/TestAsset.java @@ -18,8 +18,6 @@ private void envChecker() { String githubActions = System.getenv("GITHUB_ACTIONS"); if (githubActions != null && githubActions.equals("true")) { System.out.println("Tests are running in GitHub Actions environment."); - String mySecretKey = System.getenv("API_KEY"); - System.out.println("My Secret Key: " + mySecretKey); } else { System.out.println("Tests are running in a local environment."); } From 4c25e36fbfc341573455f04ec11df3f364398ac8 Mon Sep 17 00:00:00 2001 From: Shailesh Mishra Date: Fri, 15 Dec 2023 13:35:25 +0530 Subject: [PATCH 104/104] v1.12.3 - Taxonomy query support - Early Access Feature Support --- CHANGELOG.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f7976ca8..8b000c38 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,8 +2,9 @@ ## v1.13.0 -### Date: 17-Nov-2023 +### Date: 18-Dec-2023 +- Taxonomy Query Support - Updated Latest version of Utils SDK to 1.2.6 - Snyk Issues fixed - Updated dependencies